java从excel中读取图片,生成文件输出流写入本地磁盘

package com.junfun.pms.controller.excelImport;

import org.apache.poi.ss.usermodel.PictureData;
import org.apache.poi.xssf.usermodel.*;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.List;
import java.util.UUID;

public class ExcelImageReader {

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

        String excelFilePath = "D:/tu/tupianbiaoge.xlsx";
        String imagePath = "D:/tu";

        try {
            FileInputStream fis = new FileInputStream(new File(excelFilePath));
            XSSFWorkbook workbook = new XSSFWorkbook(fis);
            XSSFSheet sheet = workbook.getSheetAt(0);
            XSSFDrawing drawings = sheet.getDrawingPatriarch();

            List<XSSFShape> shapes = drawings.getShapes();
            int i=0;
            for (XSSFShape shape : shapes) {
                if (shape instanceof XSSFPicture) {
                    ++i;
                    if (i ==4){
                        continue;
                    }

                    XSSFPicture picture = (XSSFPicture) shape;
                    PictureData pictureData = picture.getPictureData();
                    byte[] data = pictureData.getData();

                    // 获取图片的锚点
                    XSSFClientAnchor anchor = (XSSFClientAnchor) picture.getAnchor();
                    int rowIndex = anchor.getRow1() + 1; // 行索引从0开始,所以加1
                    int colIndex = anchor.getCol1() + 1; // 列索引从0开始,所以加1

                    // 生成带有中文行列信息的文件名
                    String imageFileName = "图片_第" + rowIndex + "行_第" + colIndex + "列_" + UUID.randomUUID().toString() + ".jpg";

//                    String imageFileName = UUID.randomUUID().toString() + ".jpg"; // Generate unique file name
                    FileOutputStream fos =
                            new FileOutputStream(new File(imagePath + File.separator + imageFileName));
                    fos.write(data);
                    fos.flush();
                    fos.close();


                }
            }

        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值