获取excel中的图片(包含wps中嵌入单元格图片)

项目中有excel导入功能,并且需要导入excel中的图片;模板如图:

获取excel中的图片(包含wps中嵌入单元格图片)_第1张图片

已知office中插入的图片为浮动形式;如图:

获取excel中的图片(包含wps中嵌入单元格图片)_第2张图片

wps中可以插入浮动图片,也可以插入嵌入单元格图片;如图:

获取excel中的图片(包含wps中嵌入单元格图片)_第3张图片

并且在wps嵌入单元格形式的图片可以看到使用的是公式;如图:

获取excel中的图片(包含wps中嵌入单元格图片)_第4张图片

 问题来了,如何获取图片  并且将图片与单元格进行对应

浮动形式图片获取网上一搜一大把 不多说

主要说下wps如何将单元格和获取到的图片对应

开始分析:

获取excel中的图片(包含wps中嵌入单元格图片)_第5张图片

已知这个图片公式中的图片ID是 ID_DAF859A2B4904BF7A304D49029CAD99C

poi方法可以获取到工作表中所有图片  那么问题来了 如何将图片和图片ID对应起来

poi中没有方法可以找到对应关系 

获取excel中的图片(包含wps中嵌入单元格图片)_第6张图片

 开始找对应关系:

将excel文件改后缀为zip  并进行解压

获取excel中的图片(包含wps中嵌入单元格图片)_第7张图片

解压后看到文件xl路径下有个cellimages.xml

获取excel中的图片(包含wps中嵌入单元格图片)_第8张图片

 打开并格式化后内容如下:

获取excel中的图片(包含wps中嵌入单元格图片)_第9张图片

 可以看到这个文件里面有图片ID的数据结构 但是又是如何和图片对应起来的呢

上面我们发现如果有图片ID和图片名称的对应关系 那么我们就能确定图片ID和代码中获取的图片对应关系,但是很遗憾 这里没有这个对应关系          接下来继续找

获取excel中的图片(包含wps中嵌入单元格图片)_第10张图片

 我们发现在解压文件夹下xl\_rels有个cellimages.xml.rels 文件

获取excel中的图片(包含wps中嵌入单元格图片)_第11张图片

打开文件并格式化后如下:

获取excel中的图片(包含wps中嵌入单元格图片)_第12张图片

然后就可以找到对应关系了

获取excel中的图片(包含wps中嵌入单元格图片)_第13张图片 有了对应关系就可以开始撸代码了

接下来贴代码:

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.34
        

2.方法中传入代码中的图片公式 以及上传的文件 返回map类型

嵌入形式图片键为公式 浮动形式图片为起始单元格索引拼接字符串

获取excel中的图片(包含wps中嵌入单元格图片)_第14张图片

方法中首先截取字符串 获取图片ID

获取excel中的图片(包含wps中嵌入单元格图片)_第15张图片

 接下来获取xl/cellimages.xml文件中的rId和图片ID 

获取excel中的图片(包含wps中嵌入单元格图片)_第16张图片

再接下来获取rId和图片名称对应关系

获取excel中的图片(包含wps中嵌入单元格图片)_第17张图片

最后根据图片名称去对应工作表中获取到的图片

获取excel中的图片(包含wps中嵌入单元格图片)_第18张图片 就可以根据这个map去进行操作了

获取excel中的图片(包含wps中嵌入单元格图片)_第19张图片

已将代码打包 

获取excel中的图片(包含wps中嵌入单元格图片)_第20张图片

你可能感兴趣的:(excel,wps)