热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

POI读取excel图片并定位图片需要提前注意的事项

场景介绍因为一直在使用阿里的EasyExcel也挺方便的,而且性能也是非常不错,但是有些场景还是不支持,比如说读取excel中的指定行指

场景介绍

因为一直在使用阿里的EasyExcel也挺方便的,而且性能也是非常不错,但是有些场景还是不支持,比如说读取excel中的指定行指定列的图片信息。

毕竟Apache的POI还是比较强大,对于一些图片的处理不管是word和PDF还有他们之间的相互转换都有相应的API支持。


tips:小技巧

我这里主要是想分享一下在处理excel图片的过程中所遇到的一些小问题。


  1. excel中的图片和文字等并不是统一处理的,而是分开的。
  2. 普通的文字内容能通过行列号直接能准确的定位到,图片则“不能”,为啥会主动加上引号,因为图片的位置跟他在的单元格有绝对的关系,是有边界的。下文会验证这点。
  3. 假如现在的需求是处理每一行的excel内容,并要求把图片也入库,则需要分开处理图片和别的列的内容。

实验环境

POI指定版本如下:

org.apache.poipoi-ooxml3.17

JDK版本:1.8

所用的excel文件如下图:

现在接下来就是通过POI读取到两张图片资源,并打印相应的行号和列号。

public static void main(String[] args) {// 文件路径可以根据自己需求来 我的是放在本地根路径下了File file = new File("static/image/导入图片.xlsx");XSSFWorkbook wb = null;try {wb = new XSSFWorkbook(file);} catch (IOException | InvalidFormatException e) {e.printStackTrace();}XSSFSheet sheet = wb.getSheetAt(0);List

list = sheet.getRelations();for (POIXMLDocumentPart part : list) {if (part instanceof XSSFDrawing) {XSSFDrawing drawing = (XSSFDrawing) part;List shapes = drawing.getShapes();for (XSSFShape shape : shapes) {XSSFPicture picture = (XSSFPicture) shape;PictureData pic = picture.getPictureData();XSSFClientAnchor anchor = picture.getPreferredSize();CTMarker marker = anchor.getFrom();// 获取图片格式String ext = pic.suggestFileExtension();log.info("行号[{}],单元格[{}],图片格式[{}]", marker.getRow(), marker.getCol(), ext);}}}}

以上代码也很简单,直接就能跑起来,如果按照上面excel的图片文件位置,读取出来的图片坐标也符合预期,结果如下:

但是如果把图片放置的单元格稍微拖动一下,改成这样的:不仔细看或者运营人员稍微处理不当,两个单元格出现相互覆盖的情况,读取入库可能就出现错位了。

实验结果也正是如此:

类似的如果是图片横向的覆盖左边的单元格,图片的坐标也是就近原则。效果如下:

实验结果如下:


总结:

最后我总结下:如果需求中有了类似的场景需要用到excel处理图片,并且还需要入库,数据库最好是存储图片资源的路径,次之可以把图片转成Base64也可行。

我比较推荐第一种,可以单独开一个线程来异步处理类似这样的导入导出任务,慢一点也无所谓,或者定时任务也行。

在保证图片没有错位的前提下,读取到图片后,提前先把图片上传到指定的服务器(有CDN更好)返回图片所在的行号和列号和图片资源URL,然后在读取每一行excel根据行号判断该行对应的图片资源是哪一列,把资源路径设置好,这里可以稍微处理下,如果该图片是在前端后期直接在页面上渲染,可对该资源URL加上标签。比如:

String.format("''

 


推荐阅读
  • Go GUIlxn/walk 学习3.菜单栏和工具栏的具体实现
    本文介绍了使用Go语言的GUI库lxn/walk实现菜单栏和工具栏的具体方法,包括消息窗口的产生、文件放置动作响应和提示框的应用。部分代码来自上一篇博客和lxn/walk官方示例。文章提供了学习GUI开发的实际案例和代码示例。 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • 解决.net项目中未注册“microsoft.ACE.oledb.12.0”提供程序的方法
    在开发.net项目中,通过microsoft.ACE.oledb读取excel文件信息时,报错“未在本地计算机上注册“microsoft.ACE.oledb.12.0”提供程序”。本文提供了解决这个问题的方法,包括错误描述和代码示例。通过注册提供程序和修改连接字符串,可以成功读取excel文件信息。 ... [详细]
  • EPPlus绘制刻度线的方法及示例代码
    本文介绍了使用EPPlus绘制刻度线的方法,并提供了示例代码。通过ExcelPackage类和List对象,可以实现在Excel中绘制刻度线的功能。具体的方法和示例代码在文章中进行了详细的介绍和演示。 ... [详细]
  • Java如何导入和导出Excel文件的方法和步骤详解
    本文详细介绍了在SpringBoot中使用Java导入和导出Excel文件的方法和步骤,包括添加操作Excel的依赖、自定义注解等。文章还提供了示例代码,并将代码上传至GitHub供访问。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 本文介绍了使用kotlin实现动画效果的方法,包括上下移动、放大缩小、旋转等功能。通过代码示例演示了如何使用ObjectAnimator和AnimatorSet来实现动画效果,并提供了实现抖动效果的代码。同时还介绍了如何使用translationY和translationX来实现上下和左右移动的效果。最后还提供了一个anim_small.xml文件的代码示例,可以用来实现放大缩小的效果。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • 阿,里,云,物,联网,net,core,客户端,czgl,aliiotclient, ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • 利用Visual Basic开发SAP接口程序初探的方法与原理
    本文介绍了利用Visual Basic开发SAP接口程序的方法与原理,以及SAP R/3系统的特点和二次开发平台ABAP的使用。通过程序接口自动读取SAP R/3的数据表或视图,在外部进行处理和利用水晶报表等工具生成符合中国人习惯的报表样式。具体介绍了RFC调用的原理和模型,并强调本文主要不讨论SAP R/3函数的开发,而是针对使用SAP的公司的非ABAP开发人员提供了初步的接口程序开发指导。 ... [详细]
  • 本文讨论了Kotlin中扩展函数的一些惯用用法以及其合理性。作者认为在某些情况下,定义扩展函数没有意义,但官方的编码约定支持这种方式。文章还介绍了在类之外定义扩展函数的具体用法,并讨论了避免使用扩展函数的边缘情况。作者提出了对于扩展函数的合理性的质疑,并给出了自己的反驳。最后,文章强调了在编写Kotlin代码时可以自由地使用扩展函数的重要性。 ... [详细]
author-avatar
手机用户2502904705
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有