Excel文件按模板导出

Excel文件按模板导出

系统上的数据需要下载或保存时,就需要实现数据化可视化报表的功能,同时,我们需要按照一定的文件模板导出数据。

pom文件引入依赖

数据可视化报表,肯定离不开poi的依赖,这里我们引入easypoi和poi-ooxml

        <!-- easypoi的支持 -->
        <dependency>
            <groupId>cn.afterturn</groupId>
            <artifactId>easypoi-spring-boot-starter</artifactId>
            <version>4.3.0</version>
        </dependency>

        <!-- excel工具 -->
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>4.1.2</version>
        </dependency>

Controller层

    @GetMapping("/export")
    public void export(TdlzLzhtBgVo tdlzLzhtBgVo, HttpServletResponse response) throws Exception {
        // 获取模板文件位置
        TemplateExportParams templatePath = new TemplateExportParams("template/tdlzLzxybaxxExcel.xlsx",true);
        Map<String, Object> map = new HashMap<>();
        List<TdlzLzxybaxxDto> list = tdlzLzxybaxxService.selectLzxybaxx(tdlzLzhtBgVo);
        map.put("data", list); // 导出的数据集合
        ExcelUtil.exportExcel(templatePath, map, "耕地流转(承包)协议备案信息", response);
    }

ExcelUtil文件导出工具类

    /**
     * 根据模板生成excel后导出
     * @param templatePath  模板路径
     * @param map 数据集合
     * @param fileName 文件名
     * @param response
     * @throws IOException
     */
    public static void exportExcel(TemplateExportParams templatePath, Map<String, Object> map, String fileName, HttpServletResponse response) throws IOException {
        Workbook workbook = ExcelExportUtil.exportExcel(templatePath, map);
        downLoadExcel(fileName, response, workbook);
    }

    /**
     * excel下载
     *
     * @param fileName 下载时的文件名称
     * @param response
     * @param workbook excel数据
     */
    private static void downLoadExcel(String fileName, HttpServletResponse response, Workbook workbook) throws IOException {
        try {
            response.setCharacterEncoding("UTF-8");
            response.setHeader("content-Type", "application/vnd.ms-excel");
            response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode(fileName + ".xlsx", "UTF-8"));
            workbook.write(response.getOutputStream());
        } catch (Exception e) {
            throw new IOException(e.getMessage());
        }
    }

模板文件内容

文件导出的模板文件,需要按照规定的格式填入占位符号

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要实现固定模板格式的Excel导出,你可以使用以下步骤: 1. 定义Excel模板,包含表头和数据区域。 2. 使用JavaScript或Vue组件创建一个表格,包含要导出的数据。 3. 使用JavaScript库如SheetJS或ExcelJS将表格数据转换为Excel文件。 4. 将转换后的Excel文件模板文件合并,保留表头和数据格式。 5. 提供下载链接或使用浏览器的文件保存对话框下载Excel文件。 下面是一个示例Vue组件,可以实现固定模板格式的Excel导出: ``` <template> <div> <button @click="exportExcel">导出Excel</button> </div> </template> <script> import XLSX from 'xlsx'; export default { data() { return { columns: [ { header: '姓名', key: 'name' }, { header: '年龄', key: 'age' }, { header: '性别', key: 'gender' }, ], data: [ { name: '张三', age: 25, gender: '男' }, { name: '李四', age: 30, gender: '女' }, { name: '王五', age: 28, gender: '男' }, ], templateFile: 'template.xlsx', }; }, methods: { exportExcel() { const workbook = XLSX.readFile(this.templateFile); const worksheet = workbook.Sheets['Sheet1']; const data = XLSX.utils.sheet_to_json(worksheet, { header: 1, defval: '' }); const headerRow = data[0]; const dataRows = this.data.map(item => this.columns.map(col => item[col.key])); XLSX.utils.sheet_add_aoa(worksheet, dataRows, { origin: 1 }); const blob = new Blob([XLSX.write(workbook, { type: 'binary' })], { type: 'application/vnd.ms-excel' }); const url = URL.createObjectURL(blob); const a = document.createElement('a'); a.href = url; a.download = 'data.xlsx'; a.click(); }, }, }; </script> ``` 这个组件使用了SheetJS库来处理Excel文件,template.xlsx是预先定义好的Excel模板文件,columns和data是要导出的表头和数据。在exportExcel方法中,首先读取模板文件,然后将数据添加到工作表中,最后生成Excel文件并提供下载链接。注意,这里使用了Blob对象和URL.createObjectURL方法来创建下载链接,可以避免将整个文件内容加载到内存中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

徐三木Mu

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值