ApachePOI和数值单元格类型-Excel报告问题的解决方案
创始人
2024-09-06 09:00:37
0

在使用Apache POI库读取Excel文件时,可能会遇到有连续数字的单元格被解析为日期单元格的问题。例如,当单元格内的数字为"10-1",Apache POI可能会将其解释为10月1日。这可能会导致应用程序逻辑错误,因为实际上单元格中包含了完全不同的信息。 为解决此问题,需要明确告诉POI有关数字单元格类型的信息。例如,设置单元格格式为文本(org.apache.poi.ss.usermodel.BuiltinFormats.TEXT),或者使用将默认格式设为文本的Workbook对象。下面是一个示例代码,它获取名为“test.xlsx”的Excel文件,将所有数字单元格的格式设为文本,并遍历所有单元格以获取它们的值。

import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;

import org.apache.poi.ss.usermodel.BuiltinFormats;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.ss.usermodel.WorkbookFactory;

public class ReadExcelFile {

    public static void main(String[] args) throws IOException {

        FileInputStream inputStream = new FileInputStream(new File("test.xlsx"));

        Workbook workbook = WorkbookFactory.create(inputStream);

        // set default cell format to text
        workbook.getCreationHelper().createCellStyle().setDataFormat(BuiltinFormats.TEXT);

        Sheet sheet = workbook.getSheetAt(0);

        for (Row row : sheet) {
            for (Cell cell : row) {

                String value = "";
                switch (cell.getCellType()) {
                case STRING:
                    value = cell.getStringCellValue();
                    break;
                case NUMERIC:
                    value = String.valueOf(cell.getNumericCellValue());
                    break;
                case BOOLEAN:
                    value = String.valueOf(cell.getBooleanCellValue());
                    break;
                default:
                    break;
                }

                System.out.print(value + "\t");
            }
            System.out.println();
        }

        workbook.close();
        inputStream.close();
    }
}

相关内容

热门资讯

透视插件!wepoker可以设... 透视插件!wepoker可以设置盖牌-关于开挂透视辅助教程(有挂教学)透视插件!wepoker可以设...
最新技巧“浙江游戏大厅修改器”... 最新技巧“浙江游戏大厅修改器”原先有开挂辅助挂(确实有挂);1、这是跨平台的浙江游戏大厅修改器黑科技...
透视挂透视!hhpoker可以... 透视挂透视!hhpoker可以开挂-揭露开挂透视辅助攻略(有挂攻略)1、hhpoker可以开挂系统规...
玩家必看分享“小程序微乐游戏辅... 玩家必看分享“小程序微乐游戏辅助器”其实有开挂辅助器(详细教程);1、让任何用户在无需AI插件第三方...
透视工具!wepoker国外版... 透视工具!wepoker国外版透视-教你开挂透视辅助工具(了解有挂)1、全新机制【wepoker国外...
专业讨论“欢乐游戏城破解版内置... 专业讨论“欢乐游戏城破解版内置修改器”本来有开挂辅助脚本(了解有挂);详细欢乐游戏城破解版内置修改器...
一分钟教你“宝宝游戏辅助”好像... 您好:宝宝游戏辅助这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌特别...
透视最新!hhpoker透视挂... 透视最新!hhpoker透视挂实战视频-解谜开挂透视辅助攻略(有挂技术)1、超多福利:超高返利,海量...
9分钟了解“四川家园游戏辅助器... 9分钟了解“四川家园游戏辅助器平台交易”果然有开挂辅助下载(有挂规律);亲真的是有正版授权,小编(透...
透视科技!wepoker智能辅... 透视科技!wepoker智能辅助插件-教你开挂透视辅助插件(有挂方针)1、进入到wepoker智能辅...