poi3.14版本解析Excel中的图片,以及下载的导出图片到Excel中

解析Excel中的图片


public class importExcelByImg {

    public static void main(String[] args) {
        try {
            String filePath = "C:\\Users\\86182\\Desktop\\12312.xlsx";
            FileInputStream file = new FileInputStream(filePath);
            //建议使用WorkbookFactory.create方法创建Workbook对象,兼容性更好
            Workbook workbook = WorkbookFactory.create(file);
            File outputDir = new File("E:/images");
            if (!outputDir.exists()) {
                outputDir.mkdirs();
            }
            for (PictureData pictureData : workbook.getAllPictures()) {
                String uuid = UUID.randomUUID().toString();
                String fileExtension;
                if (pictureData instanceof HSSFPictureData) {
                    // 处理 HSSF 图片数据(Excel 2003及更早版本)
//                    HSSFPictureData hssfPictureData = (HSSFPictureData) pictureData;
//                    byte[] pictureBytes = hssfPictureData.getData();
                    // 处理图片数据,例如保存到文件或进行其他操作
                    HSSFPictureData hssfPictureData = (HSSFPictureData) pictureData;
                    fileExtension = hssfPictureData.suggestFileExtension();
                    savePictureDataToFile(outputDir, uuid, fileExtension, hssfPictureData.getData());
                } else if (pictureData instanceof XSSFPictureData) {
                    // 处理 XSSF 图片数据(Excel 2007及更新版本)
//                    XSSFPictureData xssfPictureData = (XSSFPictureData) pictureData;
//                    byte[] pictureBytes = xssfPictureData.getData();
                    // 处理图片数据,例如保存到文件或进行其他操作
                    XSSFPictureData xssfPictureData = (XSSFPictureData) pictureData;
                    fileExtension = xssfPictureData.suggestFileExtension();
                    savePictureDataToFile(outputDir, uuid, fileExtension, xssfPictureData.getData());
                }
            }
            workbook.close();
            file.close();
        } catch (IOException | InvalidFormatException e) {
            e.printStackTrace();
        }
    }

  /**
     * 自己根据系统修改
     * @param outputDir 保存图片的目录
     * @param fileName 保存图片的文件名
     * @param fileExtension 保存图片的扩展名
     * @param pictureData 图片数据
     */
    private static void savePictureDataToFile(File outputDir, String fileName, String fileExtension, byte[] pictureData) {
        try (FileOutputStream fileOutputStream = new FileOutputStream(new File(outputDir, fileName + "." + fileExtension))) {
            fileOutputStream.write(pictureData);
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

导出图片到Excel中

 File file = new File(Constants.filePath + imgprefix + imgsuffix);
//画图的顶级管理器,一个sheet只能获取一个(一定要注意这点)
//这里是模板文件所以用XSSFDrawing
XSSFDrawing patriarch = (XSSFDrawing) sheet.createDrawingPatriarch();
BufferedImage bufferImg = null;
ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream();
bufferImg = ImageIO.read(file);
String type = imgsuffix.substring(imgsuffix.lastIndexOf(".") + 1);
ImageIO.write(bufferImg, type, byteArrayOut);
  //anchor主要用于设置图片的属性
                /**
                 * dx1 第一个单元格中x轴的偏移量
                 * dy1 第一个单元格中y轴的偏移量
                 * dx2 第二个单元格中x轴的偏移量
                 * dy2 第二个单元格中y轴的偏移量
                 * col1 第一个单元格的列号
                 * row1 第一个单元格的行号
                 * col2 第二个单元格的列号
                 * row2 第二个单元格的行号
                 */
XSSFClientAnchor anchor = new XSSFClientAnchor(0, 0, 0, 0, (short) 8, 3, (short) 10, 9);
patriarch.createPicture(anchor, workbook.addPicture(byteArrayOut.toByteArray(), "jpg".equals(type) ? XSSFWorkbook.PICTURE_TYPE_JPEG : XSSFWorkbook.PICTURE_TYPE_PNG));
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

FirstTalent

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值