当前位置: 首页 > news >正文

获取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.使用的依赖

 <dependency><groupId>cn.hutool</groupId><artifactId>hutool-all</artifactId><version>5.8.11</version></dependency><dependency><groupId>org.apache.poi</groupId><artifactId>poi-scratchpad</artifactId><version>4.1.2</version></dependency><dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml</artifactId><version>4.1.2</version></dependency><dependency><groupId>org.apache.commons</groupId><artifactId>commons-lang3</artifactId><version>3.12.0</version></dependency><dependency><groupId>commons-io</groupId><artifactId>commons-io</artifactId><version>2.11.0</version></dependency><dependency><groupId>cn.afterturn</groupId><artifactId>easypoi-base</artifactId><version>4.3.0</version></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.28</version><scope>compile</scope></dependency><dependency><groupId>com.alibaba.fastjson2</groupId><artifactId>fastjson2</artifactId><version>2.0.34</version></dependency>

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

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

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

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

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

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

 就可以根据这个map去进行操作了

已将代码打包 

http://www.lryc.cn/news/131958.html

相关文章:

  • Git命令详解
  • 【STM32RT-Thread零基础入门】 4. 线程介绍(理论)
  • css学习3(三种样式表与样式控制优先级)
  • 【JS深层解析】内存
  • 第二章:25+ Python 数据操作教程(第十四节NUMPY 教程与练习)
  • Pycharm与Anaconda Python的开发环境搭建
  • 2.创建小程序
  • XenDesktop5.6如何连接数据库
  • OAuth2.0一 Spring Security OAuth2.0
  • 【linux】kernel编译时相关报错
  • C语言 功能型API --------------------strcat()
  • 企业展示小程序搭建指南
  • 大模型技术实践(一)|ChatGLM2-6B基于UCloud UK8S的创新应用
  • Flink状态和状态管理
  • 【3Ds Max】布料命令的简单使用
  • 用 VB.net,VBA 两种方式 读取单元格内的 换行数据,并出力到 CSV文件
  • kafka线上问题优化
  • FifthOne:用于矢量搜索的计算机视觉接口
  • 认识Axios
  • 系统架构设计专业技能 · 信息安全技术
  • kafka晋升之路-理论+场景
  • (牛客网)链表相加(二)
  • Vs code 使用中的小问题
  • vue2和vue3
  • 火山引擎ByteHouse:一套方案,让OLAP引擎在精准投放场景更高效
  • 【论文阅读】SHADEWATCHER:使用系统审计记录的推荐引导网络威胁分析(SP-2022)
  • Mac 使用 rar 命令行工具解压和压缩文件
  • 7.maven
  • MySQL 主从复制遇到 1590 报错
  • games101-windows环境配置(CMake+vcpkg+VS2019)