Java 使用POI 读取Excel 中的全部图片,非嵌入式图片

示例代码

excel文件格式 : xlsx


    public static Map<String, XSSFPictureData> getPictures(Sheet sheet) throws Exception {
        Map<String, XSSFPictureData> pictures = new HashMap<>();
        // 对于XLSX文件
        if (sheet instanceof XSSFSheet) {
            XSSFDrawing drawing = ((XSSFSheet) sheet).getDrawingPatriarch();
            List<XSSFShape> shapes = drawing.getShapes();
            for (XSSFShape shape : shapes) {
                if (shape instanceof XSSFPicture) {
                    XSSFPicture picture = (XSSFPicture) shape;
                    XSSFClientAnchor anchor = (XSSFClientAnchor) picture.getAnchor();
                    XSSFPictureData pdata = picture.getPictureData();
                    String key = anchor.getRow1() + "-" + anchor.getCol1();
                    pictures.put(key, pdata);
                }
            }
        }
        // 对于XLS文件,逻辑类似,使用HSSF相关类
        return pictures;
    }

    public static void savePicture(XSSFPictureData pictureData, String outputPath) throws Exception {
        String extension = pictureData.suggestFileExtension();
        byte[] data = pictureData.getData();
        FileOutputStream out = new FileOutputStream(outputPath + "." + extension);
        IOUtils.write(data, out);
        out.close();
    }

    public static void main(String[] args) throws Exception {
        File file = new File("C:\\Users\\Administrator\\Documents\\0708.xlsx");
        try (InputStream inputStream = new FileInputStream(file)) {
            Workbook workbook = new XSSFWorkbook(inputStream);
            Sheet sheet = workbook.getSheetAt(0);
            Map<String, XSSFPictureData> pictures = getPictures(sheet);
            for (Map.Entry<String, XSSFPictureData> entry : pictures.entrySet()) {
                savePicture(entry.getValue(), "D:\\" + entry.getKey());
            }
        }
    }
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

一点博客

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

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

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

打赏作者

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

抵扣说明:

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

余额充值