0
私はApache POIと協力しています。私はExcelからデータを読み取ることができますが、Excelから画像を読み取ることはできません。どのようにイメージをExcelから読み込むか。javaを使用してExcelからイメージを取得
私はApache POIと協力しています。私はExcelからデータを読み取ることができますが、Excelから画像を読み取ることはできません。どのようにイメージをExcelから読み込むか。javaを使用して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
)のように。
@Alex Richter:コードを試しましたが、出力されました –
https://poi.apache.org/spreadsheet/quick-guide.html#Images –
私はそのイメージガイドを読み、それを実行しようとしました。 **これらのエラーが発生しました - > ** List lst = workbook.getAllPictures(); //型不一致:Listからリスト –
に変換できません(Iterator it = lst.iterator(); it.hasNext() );)//メソッドiterator()は、リストListタイプでは未定義です –