java poi 获取excel中的图片(包含wps中嵌入单元格图片) |
您所在的位置:网站首页 › wps把图片嵌入单元格 › java poi 获取excel中的图片(包含wps中嵌入单元格图片) |
项目中有excel导入功能,并且需要导入excel中的图片;模板如图: 已知office中插入的图片为浮动形式;如图: wps中可以插入浮动图片,也可以插入嵌入单元格图片;如图: 并且在wps嵌入单元格形式的图片可以看到使用的是公式;如图: 问题来了,如何获取图片 并且将图片与单元格进行对应 浮动形式图片获取网上一搜一大把 不多说 主要说下wps如何将单元格和获取到的图片对应 开始分析: 已知这个图片公式中的图片ID是 ID_DAF859A2B4904BF7A304D49029CAD99C poi方法可以获取到工作表中所有图片 那么问题来了 如何将图片和图片ID对应起来 poi中没有方法可以找到对应关系 开始找对应关系: 将excel文件改后缀为zip 并进行解压 解压后看到文件xl路径下有个cellimages.xml 打开并格式化后内容如下: 可以看到这个文件里面有图片ID的数据结构 但是又是如何和图片对应起来的呢 上面我们发现如果有图片ID和图片名称的对应关系 那么我们就能确定图片ID和代码中获取的图片对应关系,但是很遗憾 这里没有这个对应关系 接下来继续找 我们发现在解压文件夹下xl\_rels有个cellimages.xml.rels 文件 打开文件并格式化后如下: 然后就可以找到对应关系了
接下来贴代码: 1.使用的依赖 cn.hutool hutool-all 5.8.11 org.apache.poi poi-scratchpad 4.1.2 org.apache.poi poi-ooxml 4.1.2 org.apache.commons commons-lang3 3.12.0 commons-io commons-io 2.11.0 cn.afterturn easypoi-base 4.3.0 org.projectlombok lombok 1.18.28 compile com.alibaba.fastjson2 fastjson2 2.0.342.方法中传入代码中的图片公式 以及上传的文件 返回map类型 嵌入形式图片键为公式 浮动形式图片为起始单元格索引拼接字符串 方法中首先截取字符串 获取图片ID 接下来获取xl/cellimages.xml文件中的rId和图片ID 再接下来获取rId和图片名称对应关系 最后根据图片名称去对应工作表中获取到的图片
已将代码打包 |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |