不同格式和要求情况下,excel文件上传问题

excel文件上传时,总会遇到各种格式的excel文件,对于不同格式,到底应该如何处理呢?

=== 情况一:===

只上传一个sheet,假设第一个,首行不需要传入

此时第二行是标题行,需要从第三行开始读

java 复制代码
public void uploadExcel(InputStream inputStream) throws Exception {
        Workbook workbook = new XSSFWorkbook(inputStream);
        Sheet sheet = workbook.getSheetAt(0);
 
        List<YourDataObject> dataList = new ArrayList<>();
        for (Row row : sheet) {
            // 假设第二行是标题行,从第二行开始读取
            if (row.getRowNum() == 0 ||row.getRowNum() == 1 ) {
                continue; 
            }
            YourDataObject data = new YourDataObject();
            // 假设每行第一个单元格是String类型,第二个是Double
            data.setName(row.getCell(0).getStringCellValue());
            data.setValue(row.getCell(1).getNumericCellValue());
            dataList.add(data);
        }
        workbook.close();
    }

如果运行时出现"Cannot get a STRING value from a NUMERIC cell"问题,可采取以下方式:

1.number类型转化为String类型的过程中造成了Cannot get a STRING value from a NUMERIC cell这样的问题,

因此需要在读取excel单元格数据转化之前设置单元格类型为String

java 复制代码
//获取单元格
XSSFCell cell = row.getCell(0);
//设置单元格类型
cell.setCellType(CellType.STRING);
//获取单元格数据
String cellValue = cell.getStringCellValue();

2.DataFormatter通过这个方法可以获取任何格式的cell数据

java 复制代码
DataFormatter formatter=new DataFormatter();
   formatter.formatCellValue(sheet.getRow(i).getCell(13));

3.自己动手写一个函数集中处理转换,使用时调用即可。

java 复制代码
private static List<String> convertRowValuesToString(Row row) {
        List<String> cellValues = new ArrayList<>();
        for (Cell cell : row) {
            switch (cell.getCellType()) {
                case STRING:
                    cellValues.add(cell.getStringCellValue());
                    break;
                case NUMERIC:
                    cellValues.add(String.valueOf(cell.getNumericCellValue()));
                    break;
                // Add more cases if needed, e.g., BOOLEAN, FORMULA, etc.
                default:
                    cellValues.add(""); // or handle other types as needed
            }
        }
        return cellValues;
    }
java 复制代码
public static void main(String[] args) throws IOException {
        File file = new File("path/to/your/excel/file.xlsx");
        FileInputStream fis = new FileInputStream(file);
        Workbook workbook = new XSSFWorkbook(fis);
        Sheet sheet = workbook.getSheetAt(0);

        for (Row row : sheet) {
            List<String> cellValues = convertRowValuesToString(row);
            System.out.println(cellValues);
        }

        workbook.close();
        fis.close();
    }

=== 情况二:===

...

(其他情况抽时间持续更新中)

参考链接:

链接:https://www.jianshu.com/p/a8b6f4056daa

相关推荐
ohoy10 小时前
RedisTemplate 使用之Zset
java·开发语言·redis
张较瘦_10 小时前
SpringBoot3 | MyBatis-Plus 搞定宠物管理:从0到1实现增删改查
mybatis·宠物
独断万古他化10 小时前
【Spring 核心: IoC&DI】从原理到注解使用、注入方式全攻略
java·后端·spring·java-ee
毕设源码_郑学姐10 小时前
计算机毕业设计springboot基于HTML5的酒店预订管理系统 基于Spring Boot框架的HTML5酒店预订管理平台设计与实现 HTML5与Spring Boot技术驱动的酒店预订管理系统开
spring boot·后端·课程设计
梵得儿SHI10 小时前
(第四篇)Spring AI 核心技术攻坚:多轮对话与记忆机制,打造有上下文的 AI
java·人工智能·spring·springai生态·上下文丢失问题·三类记忆·智能客服实战案
希忘auto10 小时前
SpringBoot之统一数据返回格式
java·spring
不吃香菜学java10 小时前
spring-依赖注入
java·spring boot·后端·spring·ssm
ja哇10 小时前
Spring AOP 详细讲解
java·后端·spring
南部余额10 小时前
Spring Boot 整合 MinIO:封装常用工具类简化文件上传、启动项目初始化桶
java·spring boot·后端·文件上传·工具类·minio·minioutils
海南java第二人10 小时前
Spring Bean生命周期深度剖析:从创建到销毁的完整旅程
java·后端·spring