Java使用excel导入模板, excel中的下拉框设置
service层中的处理 1.处理需要显示在excel下拉框中的内容,存入有个数组中。
List<String> deviceTypeName = objDeviceTypeMapper.selectObjDeviceType(); String[] deviceTypeArr = deviceTypeName.toArray(new String[deviceTypeName.size()]);
2.对字符集,文件名做处理`
response.setContentType("application/vnd.ms-excel"); response.setCharacterEncoding("utf-8"); // 这里URLEncoder.encode可以防止中文乱码 当然和easyexcel没有关系 String fileName = null; fileName = URLEncoder.encode("巡检模板", "UTF-8").replaceAll("\+", "%20"); response.setHeader("Content-disposition", "attachment;filename*=utf-8" + fileName + ".xlsx"); EasyExcel.write(response.getOutputStream(), ObjInspectionItemTemplateVo.class) .registerWriteHandler(new LongestMatchColumnWidthStyleStrategy()).registerWriteHandler( new InspCustomSheetWriteHandler(deviceTypeArr)).sheet("巡检检查项导入模板").doWrite(new ArrayList<>());
3.写一个类 实现SheetWriteHandler , 重写方法后,在afterSheetCreate方法中对表格进行处理, 3.1获取有个workbook 3.2定义sheet名称 3.3创建一个隐藏的sheet 名称为 hidden ,用于存储下拉框内容的数组 3.4如果数组不为空,就对数组中的数据进行处理 3.5将存储下拉框内容的sheet进行隐藏
//获取一个workbook Workbook workbook = writeWorkbookHolder.getWorkbook(); //定义sheet的名称 String deviceTypeHiddenName = "deviceTypeHidden"; //1.创建一个隐藏的sheet 名称为 hidden Sheet deviceTypeHidden = workbook.createSheet(deviceTypeHiddenName); if (deviceTypeArr.length != 0) { // 设备类型 writeSheetHolder.getSheet().addValidationData(deviceTypeDataValidation(workbook, deviceTypeHidden, deviceTypeHiddenName, writeSheetHolder)); } //设置列为隐藏 int hiddenIndex = workbook.getSheetIndex(deviceTypeHiddenName); if (!workbook.isSheetHidden(hiddenIndex)) { workbook.setSheetHidden(hiddenIndex, true); }
4.写一个deviceTypeDataValidation,对下拉框进行处理 4.1循环赋值,将隐藏sheet中的每一行赋值上数组中的内容 确定在隐藏表中的位置 4.2定义下拉框在表中的使用范围 4.3将刚才设置的sheet引用到你的下拉列表中
//2.循环赋值(为了防止下拉框的行数与隐藏域的行数相对应,将隐藏域加到结束行之后) for (int i = 0, length = deviceTypeArr.length; i < length; i++) { // 3:表示你开始的行数 3表示 你开始的列数 sheet.createRow(i).createCell(0).setCellValue(deviceTypeArr[i]); } Name category1Name = workbook.createName(); category1Name.setNameName(hiddenName); //4 A1:A代表隐藏域创建第N列createCell(N)时。以A1列开始A行数据获取下拉数组 String s = hiddenName + "!$A$1:$A$" + (deviceTypeArr.length); category1Name.setRefersToFormula(s); DataValidationHelper helper = writeSheetHolder.getSheet().getDataValidationHelper(); CellRangeAddressList cellRangeAddressList = new CellRangeAddressList(1, 1000, 2, 2); //5 将刚才设置的sheet引用到你的下拉列表中 DataValidationConstraint constraint = helper.createFormulaListConstraint(hiddenName + "!$A$1:$A$" + (deviceTypeArr.length));
最终效果