利用POI获取Excel中图片和图片位置(支持excel2003or2007多sheet)

转自:http://blog.csdn.net/delongcpp/article/details/8833995

第三方JAR包(apache下载POI即可):

  • poi-3.9-20121203.jar
  • dom4j-1.6.1.jar
  • poi-ooxml-3.9-20121203.jar
  • poi-ooxml-schemas-3.9-20121203.jar
  • poi-scratchpad-3.9-20121203.jar
  • stax-api-1.0.1.jar
  • xmlbeans-2.3.0.jar

测试代码:

  1. package com;
  2. import java.io.File;
  3. import java.io.FileInputStream;
  4. import java.io.FileOutputStream;
  5. import java.io.IOException;
  6. import java.io.InputStream;
  7. import java.util.ArrayList;
  8. import java.util.HashMap;
  9. import java.util.List;
  10. import java.util.Map;
  11. import org.apache.poi.POIXMLDocumentPart;
  12. import org.apache.poi.hssf.usermodel.HSSFClientAnchor;
  13. import org.apache.poi.hssf.usermodel.HSSFPicture;
  14. import org.apache.poi.hssf.usermodel.HSSFPictureData;
  15. import org.apache.poi.hssf.usermodel.HSSFShape;
  16. import org.apache.poi.hssf.usermodel.HSSFSheet;
  17. import org.apache.poi.hssf.usermodel.HSSFWorkbook;
  18. import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
  19. import org.apache.poi.ss.usermodel.PictureData;
  20. import org.apache.poi.ss.usermodel.Sheet;
  21. import org.apache.poi.ss.usermodel.Workbook;
  22. import org.apache.poi.ss.usermodel.WorkbookFactory;
  23. import org.apache.poi.xssf.usermodel.XSSFClientAnchor;
  24. import org.apache.poi.xssf.usermodel.XSSFDrawing;
  25. import org.apache.poi.xssf.usermodel.XSSFPicture;
  26. import org.apache.poi.xssf.usermodel.XSSFShape;
  27. import org.apache.poi.xssf.usermodel.XSSFSheet;
  28. import org.apache.poi.xssf.usermodel.XSSFWorkbook;
  29. import org.openxmlformats.schemas.drawingml.x2006.spreadsheetDrawing.CTMarker;
  30. /**
  31. * @since 2013-04-22
  32. * @author Gerrard
  33. * 获取excel中 图片,并得到图片位置,支持03 07 多sheet
  34. */
  35. public class GetImgFromExcel {
  36. /**
  37. * @param args
  38. * @throws IOException
  39. * @throws InvalidFormatException
  40. */
  41. public static void main(String[] args) throws InvalidFormatException, IOException {
  42. // 创建文件
  43. File file = new File("model/test.xls");
  44. // 创建流
  45. InputStream input = new FileInputStream(file);
  46. // 获取文件后缀名
  47. String fileExt =  file.getName().substring(file.getName().lastIndexOf(".") + 1);
  48. // 创建Workbook
  49. Workbook wb = null;
  50. // 创建sheet
  51. Sheet sheet = null;
  52. //根据后缀判断excel 2003 or 2007+
  53. if (fileExt.equals("xls")) {
  54. wb = (HSSFWorkbook) WorkbookFactory.create(input);
  55. } else {
  56. wb = new XSSFWorkbook(input);
  57. }
  58. //获取excel sheet总数
  59. int sheetNumbers = wb.getNumberOfSheets();
  60. // sheet list
  61. List<Map<String, PictureData>> sheetList = new ArrayList<Map<String, PictureData>>();
  62. // 循环sheet
  63. for (int i = 0; i < sheetNumbers; i++) {
  64. sheet = wb.getSheetAt(i);
  65. // map等待存储excel图片
  66. Map<String, PictureData> sheetIndexPicMap;
  67. // 判断用07还是03的方法获取图片
  68. if (fileExt.equals("xls")) {
  69. sheetIndexPicMap = getSheetPictrues03(i, (HSSFSheet) sheet, (HSSFWorkbook) wb);
  70. } else {
  71. sheetIndexPicMap = getSheetPictrues07(i, (XSSFSheet) sheet, (XSSFWorkbook) wb);
  72. }
  73. // 将当前sheet图片map存入list
  74. sheetList.add(sheetIndexPicMap);
  75. }
  76. printImg(sheetList);
  77. }
  78. /**
  79. * 获取Excel2003图片
  80. * @param sheetNum 当前sheet编号
  81. * @param sheet 当前sheet对象
  82. * @param workbook 工作簿对象
  83. * @return Map key:图片单元格索引(0_1_1)String,value:图片流PictureData
  84. * @throws IOException
  85. */
  86. public static Map<String, PictureData> getSheetPictrues03(int sheetNum,
  87. HSSFSheet sheet, HSSFWorkbook workbook) {
  88. Map<String, PictureData> sheetIndexPicMap = new HashMap<String, PictureData>();
  89. List<HSSFPictureData> pictures = workbook.getAllPictures();
  90. if (pictures.size() != 0) {
  91. for (HSSFShape shape : sheet.getDrawingPatriarch().getChildren()) {
  92. HSSFClientAnchor anchor = (HSSFClientAnchor) shape.getAnchor();
  93. if (shape instanceof HSSFPicture) {
  94. HSSFPicture pic = (HSSFPicture) shape;
  95. int pictureIndex = pic.getPictureIndex() - 1;
  96. HSSFPictureData picData = pictures.get(pictureIndex);
  97. String picIndex = String.valueOf(sheetNum) + "_"
  98. + String.valueOf(anchor.getRow1()) + "_"
  99. + String.valueOf(anchor.getCol1());
  100. sheetIndexPicMap.put(picIndex, picData);
  101. }
  102. }
  103. return sheetIndexPicMap;
  104. } else {
  105. return null;
  106. }
  107. }
  108. /**
  109. * 获取Excel2007图片
  110. * @param sheetNum 当前sheet编号
  111. * @param sheet 当前sheet对象
  112. * @param workbook 工作簿对象
  113. * @return Map key:图片单元格索引(0_1_1)String,value:图片流PictureData
  114. */
  115. public static Map<String, PictureData> getSheetPictrues07(int sheetNum,
  116. XSSFSheet sheet, XSSFWorkbook workbook) {
  117. Map<String, PictureData> sheetIndexPicMap = new HashMap<String, PictureData>();
  118. for (POIXMLDocumentPart dr : sheet.getRelations()) {
  119. if (dr instanceof XSSFDrawing) {
  120. XSSFDrawing drawing = (XSSFDrawing) dr;
  121. List<XSSFShape> shapes = drawing.getShapes();
  122. for (XSSFShape shape : shapes) {
  123. XSSFPicture pic = (XSSFPicture) shape;
  124. XSSFClientAnchor anchor = pic.getPreferredSize();
  125. CTMarker ctMarker = anchor.getFrom();
  126. String picIndex = String.valueOf(sheetNum) + "_"
  127. + ctMarker.getRow() + "_" + ctMarker.getCol();
  128. sheetIndexPicMap.put(picIndex, pic.getPictureData());
  129. }
  130. }
  131. }
  132. return sheetIndexPicMap;
  133. }
  134. public static void printImg(List<Map<String, PictureData>> sheetList) throws IOException {
  135. for (Map<String, PictureData> map : sheetList) {
  136. Object key[] = map.keySet().toArray();
  137. for (int i = 0; i < map.size(); i++) {
  138. // 获取图片流
  139. PictureData pic = map.get(key[i]);
  140. // 获取图片索引
  141. String picName = key[i].toString();
  142. // 获取图片格式
  143. String ext = pic.suggestFileExtension();
  144. byte[] data = pic.getData();
  145. FileOutputStream out = new FileOutputStream("D:\\pic" + picName + "." + ext);
  146. out.write(data);
  147. out.close();
  148. }
  149. }
  150. }
  151. }

利用POI获取Excel中图片和图片位置的更多相关文章

  1. 利用POI抽取word中的图片并保存在文件中

    利用POI抽取word中的图片并保存在文件中 poi.apache.org/hwpf/quick-guide.html 1.抽取word doc中的图片 package parse; import j ...

  2. JAVA使用POI获取Excel的列数与行数

    Apache POI 是用Java编写的免费开源的跨平台的 Java API,Apache POI提供API给Java程式对Microsoft Office格式档案读和写的功能. 下面这篇文章给大家介 ...

  3. C# 获取Excel中的合并单元格

    C# 获取Excel中的合并单元格 我们在制作表格时,有时经常需要合并及取消合并一些单元格.在取消合并单元格时需要逐个查找及取消,比较麻烦.这里分享一个简单的方法来识别Excel中的合并单元格,识别这 ...

  4. 十九、利用OGNL获取ValueStack中:根栈和contextMap中的数据

    利用OGNL获取ValueStack中:根栈和contextMap中的数据 原则:OGNL表达式如果以#开头,访问的contextMap中的数据 如果不以#开头,是访问的根栈中的对象的属性(List集 ...

  5. Yii中使用PHPexcel获取excel中数据

    1.view中代码如下: <form name="frmBatchSettle" id="" action="" method=&qu ...

  6. POI处理Excel中的日期数据类型

    在POI处理Excel中的日期类型的单元格时,如果仅仅是判断它是否为日期类型的话,最终会以NUMERIC类型来处理. 正确的处理方法是先判断单元格 的类型是否则NUMERIC类型, 然后再判断单元格是 ...

  7. 基于BootStrap的initupload()实现Excel上传和获取excel中的数据

    简单说明:后边要做exl解析(还没做呢),所以先有一个excel的的上传以及获取excel中的数据,展示出来. 代码: //html代码 <div class="btn-group&q ...

  8. 利用PHP获取访客IP、地区位置、浏览器及来源页面等信息

    这篇文章主要介绍了利用PHP获取访客IP.地区位置.浏览器及来源页面等信息的相关资料,文中给出了详细的示例代码供大家参考学习,对大家具有一定的参考借鉴价值,需要的朋友们下面来一起看看吧. 前言 本文中 ...

  9. c# 应用NPOI 获取Excel中的图片,保存至本地的算法

    要求:读取excel中的图片,保存到指定路径 思路:  利用NPOI中 GetAllPictures()方法获取图片信息 步骤: 1.新建一个Windows窗体应用程序 2.桌面新建一个excel,贴 ...

随机推荐

  1. express mongoose 新手上路 问题记录

    1.npm start启动报错,提示端口占用 app.js中添加了app.listen(3000),删掉即可 2.跳转到html页面 //ejs改为html app.engine('.html', r ...

  2. C#中的委托到底是什么概念??

    委托,简单理解是这样的.比如您要管您的孩子,把孩子送进了幼儿园.OK.此时您就把您的孩子委托给了幼儿园.当幼儿园放学,将孩子交还给您的手中.则是委托的回调.当然我这里的例子是说异步委托调用.您也可以同 ...

  3. myeclipse里如何添加mysql数据库

    首先声明,这只是我本人的一些经验,不代表任何集体和个人的利益,请勿没事就当喷子来喷我.我希望对一些对这方面学习的朋友有帮助,当然,我自己也是菜鸟级别啦!!!!!!!!!!!! 首先是电脑必要安装了my ...

  4. Office下载地址

    文件名cn_office_professional_plus_2016_x86_x64_dvd_6969182.isoSHA1277926A41B472EE38CA0B36ED8F2696356DCC ...

  5. Windows 多用户远程访问 Ubuntu 14.04桌面

    使用X2Go实现多用户远程访问 Ubuntu 14.04桌面:VNC也可以,但是每次连接VNC就回新创建一个Seession,想要在下次远程登录的时候返回上次活动,需要记住开启的线程,这种繁琐的操作不 ...

  6. ****The Toy of Flandre Scarlet

    The Toy of Flandre Scarlet Time Limit:2000MS     Memory Limit:65536KB     64bit IO Format:%lld & ...

  7. IIS SSL取消证书合法性验证

    cscript adsutil.vbs set w3svc/certcheckmode 1win 2003 IIS 6 以下执行以上代码,去除证书的合法性验证 cscript adsutil.vbs ...

  8. JavaFX基础学习之OkHttp/Gson

    导入jar包,使用OkHttp/Okio/Gson请求解析 package application; import java.io.IOException; import java.net.URL; ...

  9. ogg 初始化

    192.168.27.33test11ghdb11gtrandata: 同步delete,update 使用config 文件:同步表使用进程根据SCN号和RBA和主键同步##目的:数据定时同步,从源 ...

  10. DB2中coalesce函数的应用

    在ETL项目中经常会碰到这样的一种情况: 目标表中的某列来源于不同的源数据表A,B,C.如果在A中没有有效的数据则从B中取,如果B中没有则从C中取,如果C中也没有则设置为空值. 遇到这样的情况可能,有 ...