2016-12-11 6 views
0

私はApache POIと協力しています。私はExcelからデータを読み取ることができますが、Excelから画像を読み取ることはできません。どのようにイメージをExcelから読み込むか。javaを使用してExcelからイメージを取得

+1

https://poi.apache.org/spreadsheet/quick-guide.html#Images –

+0

私はそのイメージガイドを読み、それを実行しようとしました。 **これらのエラーが発生しました - > ** List lst = workbook.getAllPictures(); //型不一致:List からリスト –

+0

に変換できません(Iterator it = lst.iterator(); it.hasNext() );)//メソッドiterator()は、リストListタイプでは未定義です –

答えて

2

まわりを困惑するのではなく、完全な例があります。

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)のように。

+0

@Alex Richter:コードを試しましたが、出力されました –

関連する問題