不同格式和要求情况下,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

相关推荐
掌心向暖RPA自动化16 小时前
如何获取网页某个元素在屏幕可见部分的中心坐标影刀RPA懒加载坐标定位技巧
java·javascript·自动化·rpa·影刀rpa
日取其半万世不竭16 小时前
Minecraft Java版社区服务器搭建教程(Linux,适合新手)
java·linux·服务器
TeamDev17 小时前
JxBrowser 9.0.0 版本发布啦!
java·前端·混合应用·jxbrowser·浏览器控件·跨平台渲染·原声输入
AI人工智能+电脑小能手17 小时前
【大白话说Java面试题】【Java基础篇】第24题:Java面向对象有哪些特征
java·开发语言·后端·面试
AI人工智能+电脑小能手18 小时前
【大白话说Java面试题】【Java基础篇】第25题:JDK1.8的新特性有哪些
java·开发语言·后端·面试
likerhood18 小时前
SLF4J: Failed to load class “StaticLoggerBinder“ 解决
java·log4j·maven
早日退休!!!18 小时前
大模型推理瓶颈七层分析模型
java·服务器·数据库
叶小鸡19 小时前
Java 篇-项目实战-天机学堂(从0到1)-day9
java·开发语言
@#¥&~是乱码鱼啦19 小时前
Spring分层架构:Controller、Service、Mapper数据链路,IOC的真实工作意义
java·spring·架构
xieliyu.19 小时前
Java手搓数据结构:从零模拟实现无头双向非循环链表
java·数据结构·链表