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 用三极管设计一个单管共射放大电路
  • ¥20 fluent无法启动
  • ¥15 孟德尔随机化r语言运行问题
  • ¥15 pyinstaller编译的时候出现No module named 'imp'
  • ¥15 nirs_kit中打码怎么看(打码文件是csv格式)
  • ¥15 怎么把多于硬盘空间放到根目录下
  • ¥15 Matlab问题解答有两个问题
  • ¥15 LCD12864中文显示
  • ¥15 在使用CH341SER.EXE时不小心把所有驱动文件删除了怎么解决
  • ¥15 gsoap生成onvif框架