iteye_15004 2009-08-20 16:20
浏览 467
已采纳

poi 如何读取 excel中 格式为 XXXX年XX月XX日

在excel 中XXXX年XX月XX日 会被格式化为 XXXX-XX-XX, poi读取的时候会把这段时间当作数字来读就是会进入

case HSSFCell.CELL_TYPE_NUMERIC:


中,但在这里面如何读取格式为XXXX年XX月XX日,poi里会把它当做数字来处理,比如2009年2月3日会显示为39847.0,怎么让日期正常显示?


问题补充:
引用
HSSFDateUtil.isCellDateFormatted(cell)可以判断出单元格的值是否为日期


可能是在excel里设置的问题,我在excel 中输入2009年2月3日在函数栏里显示2009-2-3,程序中读取时HSSFDateUtil.isCellDateFormatted(cell)不能判断出它为日期,继而显示数字类型
问题补充:
date = HSSFDateUtil.getJavaDate(aCell.getNumericCellValue());
可以用这个方法把得到的double类型的数字转换为时间,poi这点做的不好啊......
  • 写回答

3条回答 默认 最新

  • cfy_9310guo 2009-08-20 16:34
    关注

    [code="java"]case Cell.CELL_TYPE_NUMERIC:
    if(DateUtil.isCellDateFormatted(cell)) {
    Date d = cell.getDateCellValue();
    }else{
    double v = cell.getNumericCellValue();
    }
    [/code]

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 MCNP里如何定义多个源?
  • ¥20 双层网络上信息-疾病传播
  • ¥50 paddlepaddle pinn
  • ¥20 idea运行测试代码报错问题
  • ¥15 网络监控:网络故障告警通知
  • ¥15 django项目运行报编码错误
  • ¥15 请问这个是什么意思?
  • ¥15 STM32驱动继电器
  • ¥15 Windows server update services
  • ¥15 关于#c语言#的问题:我现在在做一个墨水屏设计,2.9英寸的小屏怎么换4.2英寸大屏