POI Excel实现内容替换

目录

1 Maven依赖

2 实现代码

3 调试代码

4 模板内容

5 调试结果

 注:


1 Maven依赖

        <!-- easyExcel  Excel文档处理工具     -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>easyexcel</artifactId>
            <version>2.2.8</version>
        </dependency>
        <!-- hutool工具包       -->
        <dependency>
            <groupId>cn.hutool</groupId>
            <artifactId>hutool-all</artifactId>
            <version>5.5.7</version>
        </dependency>

2 实现代码

    /**
     * 替换Excel模板文件内容
     *
     * @param replaceMap 文档数据
     */
    public static void replaceSheet(Map<String, Object> replaceMap, Workbook workbook, Sheet sheet, Integer endRowIndex) {
        try {
            Iterator rows = sheet.rowIterator();
            while (rows.hasNext()) {
                Row row = (Row) rows.next();
                if (row == null) {
                    continue;
                }
                int num = row.getLastCellNum();
                if (endRowIndex != null && row.getRowNum() > endRowIndex) {
                    break;
                }
                for (int i = 0; i < num; i++) {
                    Cell cell = row.getCell(i);
                    if (cell == null || cell.getCellTypeEnum() == NUMERIC || cell.getStringCellValue() == null) {
                        continue;
                    }
                    String value = cell.getStringCellValue();
                    if (StrUtil.isNotEmpty(value) && value.indexOf("${") != -1) {
                        cell.setCellValue(replaceValue(value, replaceMap));
                    }
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    /**
     * 替换内容 ${}
     *
     * @param value
     * @param replaceMap
     * @return
     */
    public static String replaceValue(String value, Map<String, Object> replaceMap) {
        String str = value.substring(value.indexOf("${") + 2, value.indexOf('}'));
        if (StrUtil.isEmpty(str)) {
            return value;
        }
        value = value.replace("${" + str + "}", (String) replaceMap.get(str));
        return value;
    }

3 调试代码


    @Test
    public void testReplace() {
        try {
            //读文件
            ClassPathResource classPathResource = new ClassPathResource("/doc/excel/replaceTemplate.xlsx");
            XSSFWorkbook workbook = new XSSFWorkbook(classPathResource.getFile());
            Sheet sheet = workbook.getSheetAt(0);
            File file = new File("D:/easyexcel/testReplace.xlsx");
            FileUtil.createNewFile(file);
            Map<String, Object> replaceMap = new HashMap<>();
            replaceMap.put("test1", "测试1");
            replaceMap.put("test2", "测试2");
            //替换内容
            POIExcelUtil.replaceSheet(replaceMap, workbook, sheet, null);
            workbook.write(new FileOutputStream(file));
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

4 模板内容

5 调试结果

 注:

(1)以${}符号表示需要替换的内容。

(2)源码请查看Gitee。

xudongbase: 主要是项目中可以用到的共通方法https://gitee.com/xudong_master/xudongbase

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值