java - 使用java从e​​xcel中获取图像

标签 java excel apache-poi

我正在使用Apache POI。我可以从Excel中读取数据,但无法从Excel中读取图像。如何从Excel读取图像。

最佳答案

与其费解,不如让我们看一个完整的例子。

import org.apache.poi.ss.usermodel.WorkbookFactory;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.ss.usermodel.PictureData;

import java.io.InputStream;
import java.io.FileInputStream;
import java.io.FileOutputStream;

import java.util.List;
import java.util.Iterator;

class ReadExcelImages {

 public static void main(String[] args) throws Exception{

  InputStream inp = new FileInputStream("test.xls");
  //InputStream inp = new FileInputStream("test.xlsx");

  Workbook workbook = WorkbookFactory.create(inp);

  List lst = workbook.getAllPictures();
  int i = 1;
  for (Iterator it = lst.iterator(); it.hasNext(); ) {
   PictureData pict = (PictureData)it.next();
   String ext = pict.suggestFileExtension();
   byte[] data = pict.getData();
   if (ext.equals("png")){
    FileOutputStream out = new FileOutputStream("pict" + i++ + ".png");
    out.write(data);
    out.close();
   } else if (ext.equals("jpeg")) {
    FileOutputStream out = new FileOutputStream("pict" + i++ + ".jpeg");
    out.write(data);
    out.close();
   }
  }
 }
}

适用于 HSSF (*.xls) 以及 XSSF (*.xlsx) )。

关于java - 使用java从e​​xcel中获取图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41086729/

相关文章:

excel - 间接填充自定义功能区上的下拉菜单

excel - 如何将单元格范围作为表格从 Excel 复制到 PowerPoint - VBA

vba - 将背景图像添加到特定单元格

java - 线程 "main"java.lang.NoSuchFieldError : Factory question 中出现异常

grails - 如何使用 apache POI 逐行遍历 .docx 文件

java - 在android中反序列化JSON字符串

java - 如何使用证书发出 REST Get 请求?

java - Apache POI - Docx 输出问题

java - 根据条件将字符串转换为字符串

java - 添加存储为链表的两个多项式