Java使用POI读取Excel文件中的所有图片(包含Wps嵌入式图片)

需求

使用POI读取Excel文件中的图片数据。我的需求是导入一份Excel,读取Excel中的图片信息并将其上传至服务器,把图片上传的路径存入数据库,关键是WPS的嵌入式格式图片真的难读,用WPS打开可以看到图片,使用office的Excel打开就是一段代码无法预览图片。参考了很多大佬的博客,我自己也是慢慢摸索后完美实现需求!

实现

读取普通图片信息

直接上代码

import cn.hutool.json.JSONUtil;
import org.apache.poi.EncryptedDocumentException;
import org.apache.poi.hssf.usermodel.*;
import org.apache.poi.ooxml.POIXMLDocumentPart;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.*;
import org.openxmlformats.schemas.drawingml.x2006.spreadsheetDrawing.CTMarker;
import org.apache.commons.lang3.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.*;

public class ExcelImportDemo1 {
   
    public static void main(String[] args) throws IOException {
   
        String path = "D:\\模板测试2.xlsx";// 替换为你自己的文件
        String imageTargetPath = "D:\\download\\test\\";// 替换为你自己的输出路径

        File file = new File(path);
        // 获取图片数据
        Map<String, PictureData> map = getPictureFromExcel(file, 1);
        // 图片保存结果list
        LinkedList<String> pictureList = new LinkedList<>();
        // 遍历图片数据,将图片写入磁盘
        for (Map.Entry<String, PictureData> entry : map.entrySet()) {
   
            String key = entry.getKey();
            PictureData pictureData = entry.getValue();
            String extension = pictureData.suggestFileExtension();
            // 构建图片文件名,使用行列作为文件名
            String[] coordinates = key.split("-");
            // 文件名规则    行号-列号.后缀名 列号不变
            String imageFileName = coordinates[0] + "-" + coordinates[1] + "." + extension;
            pictureList.add(imageFileName);
        }
        System.out.println(JSONUtil.toJsonStr(pictureList));
        // 根据键的第一个数字进行分组
        Map<Character, List<PictureData>> groupedImages = new HashMap<>();
        for (Map.Entry<String, PictureData> entry : map.entrySet()) {
   
            char firstDigit = entry.getKey().charAt(0);
            groupedImages.computeIfAbsent(firstDigit, k -> new ArrayList<>()).add(entry.getValue());
        }
        // 打印分组结果
        for (Map.Entry<Character, List<PictureData>> entry : groupedImages.entrySet()) {
   
            char key = entry.getKey();
            List<PictureData> images = entry.getValue();
            for (PictureData image : images) {
   
                byte[] data = image.getData();
                System.out.println(data);
            }
        }

        // 遍历图片数据,将图片写入磁盘
        for (Map.Entry<String, PictureData> entry : map.entrySet()) {
   
            String key = entry.getKey();
            PictureData pictureData = entry.getValue();
            String extension = pictureData.suggestFileExtension();

            // 构建图片文件名,使用行列作为文件名
            String[] coordinates = key.split("-");
            String imageFileName = coordinates[0] + "-" + coordinates[1] + "." + extension;

            // 将图片数据写入文件
            FileOutputStream out = new FileOutputStream(imageTargetPath + File.separator + imageFileName);
            out.write(pictureData.getData());
            out.close();
        }
    }

    private static String getCellValueAsString(Cell cell) {
   
        String cellValue = "";
        if (cell != null) {
   
            switch (cell.getCellType()) {
   
                case STRING:
                    cellValue = cell.getStringCellValue();
                    break;
                case NUMERIC:
                    cellValue = String.valueOf(cell.getNumericCellValue());
                    break;
                case BOOLEAN:
                    cellValue = String.valueOf(cell.getBooleanCellValue());
                    break;
                // 根据需要处理其他单元格类型
            }
        }
        return cellValue;
    }

    /**
     * 获取excel表中的图片
     *
     * @return
     * @throws IOException
     * @throws InvalidFormatException
     * @throws EncryptedDocumentException
     * @Param fis 文件输入流
     * @Param sheetNum Excel表中的sheet编号
     */
    public static Map<String
Java使用POI库可以实现对Excel文件读取操作。具体的步骤如下: 1. 引用POI库。在Java项目引入POI相关的jar包。 2. 创建文件输入流。使用FileInputStream类创建一个输入流对象,并指定要读取Excel文件路径。 3. 创建工作簿对象。使用HSSFWorkbook类创建一个工作簿对象,将输入流作为参数传入。 4. 获取工作表。使用getSheetAt方法获取指定的工作表,可以通过工作表的索引或名称进行获取。 5. 获取行。使用getRow方法获取指定行的对象,行号作为参数传递给该方法。 6. 获取单元格使用getCell方法获取指定单元格的对象,行号和列号作为参数传递给该方法。 7. 获取单元格的值。使用getStringCellValue方法获取单元格的值,将其赋给一个字符串变量。 8. 输出结果。使用System.out.println方法将获取到的数据打印出来。 需要注意的是,在读取Excel文件时可能会出现FileNotFoundException和IOException异常,需要进行异常处理。同时,在读取完成后,需要关闭输入流。 下面是一个示例代码,用于演示Java使用POI读取Excel文件: ```java import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; import org.apache.poi.hssf.usermodel.HSSFCell; import org.apache.poi.hssf.usermodel.HSSFRow; import org.apache.poi.hssf.usermodel.HSSFSheet; import org.apache.poi.hssf.usermodel.HSSFWorkbook; public class ExcelReader { public static void poiRead() { FileInputStream xlsStream = null; try { // 创建文件输入流 xlsStream = new FileInputStream(new File("C:\\Users\\itour\\Desktop\\poiTest.xls")); // 创建工作簿对象 HSSFWorkbook hssfWorkbook = new HSSFWorkbook(xlsStream); // 获取工作表 HSSFSheet sheetAt = hssfWorkbook.getSheetAt(0); // 获取行 HSSFRow row = sheetAt.getRow(0); // 获取单元格 HSSFCell cell = row.getCell(0); // 获取单元格的值 String cellValue = cell.getStringCellValue(); System.out.println("获取到的数据是:" + cellValue); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } finally { if (xlsStream != null) { try { xlsStream.close(); } catch (IOException e) { e.printStackTrace(); } } } } } ``` 以上代码演示了如何使用POI读取Excel文件第一个工作表的第一个单元格的值。你可以根据自己的需求进行修改和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值