最近搜索

POI poi 解析excel中的图片

浏览:490
管理员 2022-05-06 13:31


image.png



获取图片数量

	Sheet sheet = workbook.getSheetAt(0);
		
		List pictures = workbook.getAllPictures();
		System.out.println("图片数量:"+pictures.size()); 		


输出是1

image.png

image.png








package com.stone.exam.utils;

import com.stone.exam.bean.ExcelPicPositionEntity;
import net.sf.json.JSONArray;
import net.sf.json.JSONObject;
import org.apache.poi.hssf.usermodel.*;
import org.apache.poi.ooxml.POIXMLDocumentPart;
import org.apache.poi.ss.usermodel.PictureData;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.ss.usermodel.WorkbookFactory;
import org.apache.poi.xssf.usermodel.*;
import org.openxmlformats.schemas.drawingml.x2006.spreadsheetDrawing.CTMarker;
import org.springframework.web.multipart.MultipartFile;

import java.io.*;
import java.util.*;

public class ImportExcelByImg {
	//从03格式excel中获取图片
	private static List<ExcelPicPositionEntity> getSheetPictures03(int sheetNum,
																	 HSSFSheet sheet, HSSFWorkbook workbook) {
		List<ExcelPicPositionEntity> positionEntities = new ArrayList<>();
		List pictures = workbook.getAllPictures();
		if (pictures.size() != 0) {
			for (HSSFShape shape : sheet.getDrawingPatriarch().getChildren()) {
				HSSFClientAnchor anchor = (HSSFClientAnchor) shape.getAnchor();
				if (shape instanceof HSSFPicture) {
					ExcelPicPositionEntity positionEntity = new ExcelPicPositionEntity();
					HSSFPicture pic = (HSSFPicture) shape;
					positionEntity.setSheetNum(sheetNum);
					positionEntity.setColumn((int) anchor.getCol1());
					positionEntity.setRow(anchor.getRow1());
					positionEntity.setPictureData(pic.getPictureData());
					positionEntities.add(positionEntity);
				}
			}
		}
		return positionEntities;
	}
	//07格式excel获取图片。
	private static List<ExcelPicPositionEntity> getSheetPictures07(int sheetNum,
																	 XSSFSheet sheet, XSSFWorkbook workbook) {
		List<ExcelPicPositionEntity> positionEntities = new ArrayList<>();
		for (POIXMLDocumentPart dr : sheet.getRelations()) {
			if (dr instanceof XSSFDrawing) {
				XSSFDrawing drawing = (XSSFDrawing) dr;
				List<XSSFShape> shapes = drawing.getShapes();
				for (XSSFShape shape : shapes) {
					ExcelPicPositionEntity positionEntity = new ExcelPicPositionEntity();
					XSSFPicture pic = (XSSFPicture) shape;
					XSSFClientAnchor anchor = pic.getPreferredSize();
					CTMarker ctMarker = anchor.getFrom();
					positionEntity.setSheetNum(sheetNum);
					positionEntity.setColumn(ctMarker.getCol());
					positionEntity.setRow(ctMarker.getRow());
					positionEntity.setPictureData(pic.getPictureData());
					positionEntities.add(positionEntity);
				}
			}
		}
		return positionEntities;
	}
	//图片及位置获取
	public static List<ExcelPicPositionEntity> getAllData(MultipartFile file) throws Exception {
//		// 创建文件
//		File file = new File(excelPath);
		// 创建流
		InputStream input = new ByteArrayInputStream(file.getBytes());
		// 获取文件后缀名
		String fileExt =  file.getName().substring(file.getName().lastIndexOf(".") + 1);
		// 创建Workbook
		Workbook wb;
		// 创建sheet
		Sheet sheet;
		//根据后缀判断excel 2003 or 2007+
		if (fileExt.equals("xls")) {
			wb = WorkbookFactory.create(input);
		} else {
			wb = new XSSFWorkbook(input);
		}
		//获取excel sheet总数
		int sheetNumbers = wb.getNumberOfSheets();
		List<ExcelPicPositionEntity> positionEntities = new ArrayList<>();
		// 循环sheet
		for (int i = 0; i < sheetNumbers; i++) {
			sheet = wb.getSheetAt(i);
		// 判断用07还是03的方法获取图片
			if (fileExt.equals("xls")) {
				positionEntities.addAll(getSheetPictures03(i, (HSSFSheet) sheet, (HSSFWorkbook) wb));
			} else {
				positionEntities.addAll(getSheetPictures07(i, (XSSFSheet) sheet, (XSSFWorkbook) wb));
			}
		}
		return positionEntities;
	}
}




image.png



image.png

联系站长

站长微信:xiaomao0055

站长QQ:14496453