使用让easyexcel导出带下拉框的excel动态模板。不涉及数据导出,不涉及前端代码。
Controller
@PostMapping("/exportUserTemplate")
public void downloadTemplate(HttpServletRequest request, HttpServletResponse response) {
//导出模板名称
String fileName="xxx.xlsx";
response.setContentType("multipart/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
response.setCharacterEncoding("utf-8");
//编码 防止中文乱码
try {
fileName = URLEncoder.encode(fileName,"UTF-8");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
response.setHeader("Content-disposition","attachment;filename="+fileName);
//excel表头数据
List<UserDownloadTemplateVO> userDownloadTemplateVOList = new UserDownloadTemplateVOList();
try {
//xxxx表示excel下拉框动态数据(一般都是从数据库查出)
//xxx表示模板里sheet的名称
EasyExcel.write(response.getOutputStream(),UserDownloadTemplateVO.class)
.registerWriteHandler(new CustomSheetWriteHandler(xxxx))
.sheet("xxx")
.doWrite(userDownloadTemplateVOList);
} catch (IOException e) {
e.printStackTrace();
}
}
拦截器
public class CustomSheetWriteHandler implements SheetWriteHandler {
//动态下拉框的数据
private List<String> list;
public CustomSheetWriteHandler(List<String> list) {
this.list= list;
}
public CustomSheetWriteHandler() {
}
@Override
public void beforeSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) {
}
@Override
public void afterSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) {
DataValidationHelper helper = writeSheetHolder.getSheet().getDataValidationHelper();
Map<Integer, String[]> mapDropDown = new HashMap<>();
String[] listArray= new String[list.size()];
for (int i = 0; i < list.size(); i++) {
listArray[i] = list.get(i);
}
//定义下拉框中的数据 并添加到map中 这里的key是写死的
//第一个数表示对应的excel字段的序号,第二个则是数组
mapDropDown.put(9, listArray);
//获取工作簿
// 创建sheet,突破下拉框255的限制
//获取一个workbook
Workbook workbook = writeWorkbookHolder.getWorkbook();
//定义sheet的名称
String sheetName = "hidden";
//1.创建一个隐藏的sheet 名称为 providerSheet
Sheet providerSheet = workbook.createSheet(sheetName);
// 设置隐藏
workbook.setSheetHidden(1,true);
//2.循环赋值(为了防止下拉框的行数与隐藏域的行数相对应,将隐藏域加到结束行之后)
for (Map.Entry<Integer, String[]> entry : mapDropDown.entrySet()) {
CellRangeAddressList addressList = new CellRangeAddressList(1, 65535, entry.getKey(), entry.getKey());
String[] values = entry.getValue();
for (int i = 0, length = values.length; i < length; i++) {
// i:表示你开始的行数 0表示你开始的列数
Row row = providerSheet.getRow(i);
if (row == null) {
row = providerSheet.createRow(i);
}
row.createCell(entry.getKey()).setCellValue(values[i]);
}
//4 $A:$A$N代表 以A列1行开始获取N行下拉数据
String excelLine = getExcelLine(entry.getKey());
String refers = "=" + sheetName + "!$" + excelLine + ":$" + excelLine + "$" + (values.length);
//5 将刚才设置的sheet引用到你的下拉列表中
DataValidationConstraint constraint = helper.createFormulaListConstraint(refers);
DataValidation dataValidation = helper.createValidation(constraint, addressList);
writeSheetHolder.getSheet().addValidationData(dataValidation);
}
}
/**
* @param num 列数
* @return java.lang.String
* @Description 返回excel列标A-Z-AA-ZZ
*/
public static String getExcelLine(int num) {
String line = "";
int first = num / 26;
int second = num % 26;
if (first > 0) {
line = (char) ('A' + first - 1) + "";
}
line += (char) ('A' + second) + "";
return line;
}
}
1、如果导出的excel是由多个下拉框的,也可通过新建一个数据然后添加进map。
2、实体类需自己根据需求来,以及动态生成的下拉框也需根据需来。
3、上述导出代码是涉及动态模板导出,不涉及到导出数据(可以理解为此次是下载模板 *** 作)
代码过程中遇到的问题:
ps:问题1:下拉框字数255字符限制问题。 已通过添加隐藏sheet解决
问题2:easyexcel添加拦截器后,用excel打开会有提示部分内容有问题,用 wps打开则没事。 已解决。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)