IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发测试 -> easyexcel导出动态模板(动态导出下拉框) -> 正文阅读

[开发测试]easyexcel导出动态模板(动态导出下拉框)

使用easyexcel框架下载模板

使用让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$1:$A$N代表 以A列1行开始获取N行下拉数据
            String excelLine = getExcelLine(entry.getKey());
            String refers = "=" + sheetName + "!$" + excelLine + "$1:$" + 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打开则没事。 已解决。

  开发测试 最新文章
pytest系列——allure之生成测试报告(Wind
某大厂软件测试岗一面笔试题+二面问答题面试
iperf 学习笔记
关于Python中使用selenium八大定位方法
【软件测试】为什么提升不了?8年测试总结再
软件测试复习
PHP笔记-Smarty模板引擎的使用
C++Test使用入门
【Java】单元测试
Net core 3.x 获取客户端地址
上一篇文章      下一篇文章      查看所有文章
加:2022-04-24 09:45:10  更:2022-04-24 09:45:23 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/19 4:48:30-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码