解决 EasyExcel 填充图片占满单元格问题

本篇主要记录解决使用EasyExcel 填充图片的两个问题:

  1. 如何根据标识填充

2.如果完全占满要显示的单元格

java 复制代码
import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.ExcelWriter;
import com.alibaba.excel.metadata.data.ImageData;
import com.alibaba.excel.metadata.data.WriteCellData;
import com.alibaba.excel.write.metadata.WriteSheet;
import com.nx.plugin.basic.common.exception.SystemException;
import com.nx.plugin.basic.common.utils.FileUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.test.context.SpringBootTest;

import java.io.File;
import java.nio.file.Files;
import java.nio.file.Paths;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;


@SpringBootTest
public class DailyTest {

    static Logger log = LoggerFactory.getLogger(DailyTest.class);



    public static void main(String[] args) {
        Map formDataMap = new HashMap();
        //待填充的图片路径
        String picUrl = "D:\\Data\\xxx ...... xxx\\99795411766660016.png";
        //生成的目标文件路径
        String targetFileNameUrl = "C:\\Users\\xxx ...... xxx\\Desktop\\生成的目标文件.xlsx";
        //模板文件路径
        String templateFileNameUrl = "D:\\Data\\xxx ...... xxx\\模板文件路径.xlsx";

        WriteCellData<Void> writeCellData = new WriteCellData<>();

        try {
            // 可以放入多个图片
            List<ImageData> imageDataList = new ArrayList<>();

            ImageData imageData = new ImageData();
            // 设置图片
            byte[] data = Files.readAllBytes(Paths.get(picUrl));

            imageData.setImage(data);
            // 类似给定了四个点位     根据给定的首行,末行,首列,末列 来锁定图片的位置
            imageData.setRelativeFirstRowIndex(0);  //合并单元格的第一行索引
            imageData.setRelativeLastRowIndex(2);   //合并单元格的第一列索引
            imageData.setRelativeFirstColumnIndex(0);   //合并单元格的最后一行索引
            imageData.setRelativeLastColumnIndex(11);   //合并单元格的最后一列索引
            //这四个属性就是在上面的范围的前提下 图片的边距
            imageData.setTop(5);
            imageData.setBottom(5);
            imageData.setLeft(5);
            imageData.setRight(5);

            imageDataList.add(imageData);
            writeCellData.setImageDataList(imageDataList);
        } catch (Exception e) {
            //获取图片出现异常
            e.printStackTrace();
        }
        
        //单元格填充图片
        formDataMap.put("codePic", writeCellData);

        File targetFile = new File(targetFileNameUrl);
        FileUtils.createFile(targetFileNameUrl);
        File templateFile = new File(templateFileNameUrl);
        if (!templateFile.exists()) {
            //todo 模板文件为空
        }
        try (ExcelWriter excelWriter = EasyExcel.write(targetFile).withTemplate(templateFileNameUrl).build()) {
            WriteSheet writeSheet = EasyExcel.writerSheet().build();
            //普通表单字段填充
            excelWriter.fill(formDataMap, writeSheet);
        }
    }
}

模板:

图片填充后的效果:

相关推荐
闪电悠米6 分钟前
黑马点评短信登录01_session_sms_login
java·spring boot·redis·git·spring·面试
Advancer-8 分钟前
黑马点评plus --异步秒杀重构升级
java·spring boot·重构·intellij-idea
Dicky-_-zhang11 分钟前
服务网格实战:Istio与Linkerd对比选型与落地实践
java·jvm
云烟成雨TD13 分钟前
Spring AI Alibaba 1.x 系列【56】SAA Admin 平台功能介绍
java·人工智能·spring
Gauss松鼠会13 分钟前
GaussDB(DWS) 资源监控Topsql
java·网络·数据库·算法·oracle·性能优化·gaussdb
夏日听雨眠14 分钟前
数据结构(快速排序)
java·数据结构·算法
字节高级特工17 分钟前
C++11(一) 革新:右值引用与移动语义
java·开发语言·c++·人工智能·后端
郝学胜-神的一滴19 分钟前
系统设计 012:从用户系统出发,吃透缓存、数据库与高并发设计
java·数据库·python·缓存·php·软件构建
人道领域22 分钟前
【LeetCode刷题日记】654.最大二叉树:递归算法详解
java·算法·leetcode
青云计划22 分钟前
Synchronized 锁升级:从偏向锁到重量级锁的性能进化之路
java·后端