【分享-POI工具,Excel字段取值容错小工具】

在使用POI导出Excel数据的时候这样

java 复制代码
         FileInputStream inputStream = new FileInputStream(file);
        Workbook workbook = WorkbookFactory.create(inputStream);
        Sheet sheet = workbook.getSheetAt(0);
        for (Row row : sheet) {
			row.getCell(1).getStringCellValue();
			......
		}

row.getCell(1).getStringCellValue(); 这里是很容易报错的. 因为excel里的列格式即使设置为文本

当cell内的值是一个纯数字的时候, POI取到的还会是一个double类型的值. getStringCellValue(这个方法就会抛出类型不匹配的错误.)

为了解决这个常见问题. 写了这个工具类

java 复制代码
public class ExcelUtil {
    public static String getCellValueString(Cell cell){
        if (cell != null) {
            switch (cell.getCellType()) {
                case STRING:
                    // 如果单元格内容是字符串类型
                    return cell.getStringCellValue();
                case NUMERIC:
                    // 如果单元格内容是数字类型
                    double numericValue = cell.getNumericCellValue();
                    return String.valueOf(numericValue); // 转为字符串后设置
                case BOOLEAN:
                    // 如果单元格内容是布尔值类型
                    boolean booleanValue = cell.getBooleanCellValue();
                    return String.valueOf(booleanValue); // 转为字符串后设置
                case FORMULA:
                    // 如果单元格是公式
                    String formulaValue = cell.getCellFormula();
                    return formulaValue; // 设置公式字符串
                default:
                    // 其他类型的处理(如空单元格)
                    return ""; // 设置为空字符串
            }
        } else {
            // 如果单元格为空
            return ""; // 设置为空字符串
        }

    }

    public static double getCellValueNumber(Cell cell){
        if (cell == null) {
            return -4; // 如果单元格为空,返回-1
        }
        switch (cell.getCellType()) {
            case STRING:
                try {
                    // 尝试将字符串转换为数字
                    return Double.parseDouble(cell.getStringCellValue());
                } catch (NumberFormatException e) {
                    // 如果字符串不能转换为数字,返回-1
                    return -1;
                }

            case NUMERIC:
                // 如果是数字类型,直接返回数字
                return cell.getNumericCellValue();

            case BOOLEAN:
                // 如果是布尔类型,true转换为1,false转换为0
                return cell.getBooleanCellValue() ? 1 : 0;

            case FORMULA:
                // 如果是公式类型,返回-1
                return -2;

            default:
                // 对于其他类型,返回-1
                return -3;
        }
    }
}

然后我们必须要从cell中取String类型就这样使用

java 复制代码
ExcelUtil.getCellValueString(row.getCell(2));

取double类型就这样使用

java 复制代码
ExcelUtil.getCellValueNumber(row.getCell(3));

避免excel总是自动转换或者用户输入错误造成的导入数据错误.

相关推荐
我是一颗柠檬6 分钟前
【Java项目技术亮点】EXPLAIN深度分析与慢查询治理
android·java·开发语言
万亿少女的梦1689 分钟前
基于Spring Boot的社区管理系统设计与实现
java·spring boot·mysql·vue·系统设计
大气的小蜜蜂19 分钟前
领域层的服务
java·前端·数据库
agent89721 分钟前
Spring Boot 接口超时治理:从连接池、线程池到熔断限流的完整排查思路
java·spring boot·后端
Devin~Y27 分钟前
抖音级短视频推荐与直播带货平台面试实战:从 Java 微服务到 RAG 智能客服全链路解析
java·spring boot·redis·spring cloud·kafka·agent·rag
帅次37 分钟前
Android 高级工程师面试:Java 多线程与并发 近1年高频追问 22 题
android·java·面试
要开心吖ZSH40 分钟前
Java事务与MySQL事务的关系及MVCC通俗解析
java·开发语言·mysql·mvcc
放弃 治疗42 分钟前
Windows 11系统 最新 Launch4j 安装与使用教程:从 JAR 到 EXE 的完整打包指南
java·jar
火星校尉1 小时前
一场数据基建与消费场景的跨界实验
java·前端·数据库·python·php
寻道码路1 小时前
LangChain4j Java AI 应用开发实战(二十六):多模型集成策略 —— OpenAI、DeepSeek、阿里百炼混合使用
java·开发语言·人工智能·ai