EasyExcel填充模板及图片

官方文档:https://www.yuque.com/easyexcel/doc/fill

其实参考官网文档已经可以正常使用了,这里主要是记录如何在模板中填充图片

请求参数

注意:sheetNo 能帮助我们定位数据是哪个sheet

{
  "fileId": 804,
  "data": [
    {
      "sheetNo": 0,
      "content": "简单说明",
      "test_image": 907,
      "test2_image": 908
    },
    {
      "sheetNo": 1,
      "name": "名称"
    }
  ]
}

解析页面表单

   /**
     * 解析页面表单,根据Map填充
     *
     * @param map
     * @return
     */
    @Override
    public AjaxResult parse(Map<String, Object> map) {

        // 1. 获取前端的传值  -> cn.hutool.json
        Map<String, Object> jsonMap = JSONUtil.parseObj(map);
        // 1.1 获得 fileId 数据
        // 这里理论上直接传 fileId 即可,即可找到模板对应的文件
        Integer fileId = (Integer) jsonMap.get(FORM_FILE_ID);

        // 2. 根据 fileId 查库
        MyFile myFile = fileService.selectFileById(Long.valueOf(fileId));
        // 2.1 检查一波
        if (ObjectUtil.isNull(myFile)) {
            return AjaxResult.error();
        }

        // 3. 获取模板文件位置
        String templateFilePath = myFile.getPath();
        // 3.1 检查一波
        if (!FileUtils.checkAllowDownload(templateFilePath)) {
            return AjaxResult.error("资源文件非法,不允许下载。");
        }

        // 4. 获取 data 数据 -> cn.hutool.json
        JSONArray dataArray = (JSONArray) jsonMap.get(FORM_DATA);

        // 5. 返回新文件路径信息
        Map<String, String> newFilePathMap = getNewFilePath(myFile.getSuffix());

        // 6. 生成文件
        genFileByTemplate(newFilePathMap.get(FILE_NEW_FILE_DOWNLOAD_PATH),
                getTemplatePath(templateFilePath).get(FILE_TEMPLATE_DOWNLOAD_PATH),
                dataArray);

        // 7. 写库返回数据
        AjaxResult ajaxResult = insertFile(myFile, newFilePathMap.get(FILE_NEW_FILE_PATH));

        // 8. 保存测试数据
        this.insertTemplate(Long.valueOf(fileId), (Long) ajaxResult.get("id"), JSONUtil.parseObj(map).toString());

        return ajaxResult;
    }

生成文件方法

   /**
     * 生成文件
     *
     * @param newFileDownloadPath  新文件路径
     * @param templateDownloadPath 模板文件路径
     * @param dataArray            数据数组
     */
    private void genFileByTemplate(String newFileDownloadPath, String templateDownloadPath, JSONArray dataArray) {
        // 先检查一波
        this.checkPathExists(newFileDownloadPath);

			  // 参考官网即可
        ExcelWriter excelWriter = EasyExcel.write(newFileDownloadPath).withTemplate(templateDownloadPath).build();

        // 遍历map
        for (Object obj : dataArray) {
            Map<String, Object> param = new JSONObject(obj).toBean(Map.class);
            // 获取sheetNo
            Integer sheetNo = (Integer) param.get(SHEET_NO);
            log.debug("sheetNo: " + sheetNo);

            // 特殊处理方法
            tickHandleByParam(param);
            imageHandleByParam(param);

            // 多sheet填充
            // sheetNo 的作用在这里!!
            WriteSheet writeSheet = EasyExcel.writerSheet(sheetNo).build();

            try {
                excelWriter.fill(param, writeSheet);
            } catch (Exception e) {
                e.printStackTrace();
                // 文件已经生成,但是空的,删除它
                this.deleteFile(newFileDownloadPath);
                throw new MyException("请检查sheetNo是否配置正确");
            }
        }
        excelWriter.finish();
    }

处理图片方法

   /**
     * 图片处理
     *
     * @param param
     */
    private void imageHandleByParam(Map<String, Object> param) {
        for (Map.Entry<String, Object> entry : param.entrySet()) {
            try {
                String mapKey = entry.getKey();
                if (mapKey.contains(CONTAIN_IMAGE_KEY)) {
                    // 文件id
                    Integer fileId = (Integer) entry.getValue();

                    MyFile myFile = fileService.selectFileById(Long.valueOf(fileId));
                    if (ObjectUtil.isNull(myFile)) {
                        continue;
                    }
                    // 本地资源路径
                    String localPath = Config.getProfile();
                    // 数据库资源地址
                    String downloadPath = localPath + StringUtils.substringAfter(myFile.getPath(), Constants.RESOURCE_PREFIX);

                    // 填充图片
                    ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream();
                    BufferedImage bufferImg = ImageIO.read(new File(downloadPath));
                    // 图片后缀格式
                    String suffix = file.getSuffix();
                    ImageIO.write(bufferImg, suffix, byteArrayOut);

                    bufferImg.flush();
                    // 注意:这里需要put回原来的key里
                    param.put(mapKey, byteArrayOut.toByteArray());
                }
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }

效果

模板图

效果图

  • 3
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 14
    评论
对于填充模板,可以使用EasyExcel这个库来进行操作。下面是一个简单的示例代码,演示如何使用EasyExcel填充模板: ```java // 导入相关的包 import com.alibaba.excel.EasyExcel; import com.alibaba.excel.context.AnalysisContext; import com.alibaba.excel.event.AnalysisEventListener; import com.alibaba.excel.metadata.Sheet; import com.alibaba.excel.metadata.Table; import java.util.ArrayList; import java.util.List; public class FillTemplateExample { public static void main(String[] args) { // 加载模板文件 String templateFileName = "template.xlsx"; // 准备填充数据 List<DataModel> data = prepareData(); // 使用EasyExcel进行填充 EasyExcel.write("output.xlsx") .withTemplate(templateFileName) .sheet() .doFill(data); } private static List<DataModel> prepareData() { // 准备填充数据 List<DataModel> data = new ArrayList<>(); data.add(new DataModel("张三", 20, "男")); data.add(new DataModel("李四", 25, "女")); data.add(new DataModel("王五", 30, "男")); return data; } // 填充数据模型类 public static class DataModel { private String name; private int age; private String gender; // 构造函数、getter和setter方法省略 public DataModel(String name, int age, String gender) { this.name = name; this.age = age; this.gender = gender; } } } ``` 以上代码中,首先加载模板文件`template.xlsx`,然后准备填充数据`data`,最后使用EasyExcel的`doFill()`方法进行填充,并将填充结果写入到`output.xlsx`文件中。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值