java读取excel 不知道excel里面具体内容是时间还是数字或者是字符串 如何正确读取呢

java读取excel 不知道excel里面具体内容是时间还是数字或者是字符串 如何正确读取呢,第1张

java读取excel时间格式出现数字的处理方法:

Excel存储日期、时间均以数值类型进行存储,读取时POI先判断是是否是数值类型,再进行判断转化

1、数值格式(CELL_TYPE_NUMERIC):

1纯数值格式:getNumericCellValue() 直接获取数据

2日期格式:处理yyyy-MM-dd, d/m/yyyy h:mm, HH:mm 等不含文字的日期格式

1)判断是否是日期格式:HSSFDateUtilisCellDateFormatted(cell)

2)判断是日期或者时间

cellgetCellStyle()getDataFormat() == HSSFDataFormatgetBuiltinFormat("h:mm")

OR: cellgetCellStyle()getDataFormat() == HSSFDataFormatgetBuiltinFormat("yyyy-MM-dd")

3自定义日期格式:处理yyyy年m月d日,h时mm分,yyyy年m月等含文字的日期格式

判断cellgetCellStyle()getDataFormat()值,解析数值格式

yyyy年m月d日----->31

m月d日---->58

h时mm分--->32

举例说明:

private String parseExcel(Cell cell) {

String result = new String();

switch (cellgetCellType()) {

case HSSFCellCELL_TYPE_NUMERIC:// 数字类型

if (HSSFDateUtilisCellDateFormatted(cell)) {// 处理日期格式、时间格式

SimpleDateFormat sdf = null;

if (cellgetCellStyle()getDataFormat() == HSSFDataFormat

getBuiltinFormat("h:mm")) {

sdf = new SimpleDateFormat("HH:mm");

} else {// 日期

sdf = new SimpleDateFormat("yyyy-MM-dd");

}

Date date = cellgetDateCellValue();

result = sdfformat(date);

} else if (cellgetCellStyle()getDataFormat() == 58) {

// 处理自定义日期格式:m月d日(通过判断单元格的格式id解决,id的值是58)

SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");

double value = cellgetNumericCellValue();

Date date = orgapachepoissusermodelDateUtil

getJavaDate(value);

result = sdfformat(date);

} else {

double value = cellgetNumericCellValue();

CellStyle style = cellgetCellStyle();

DecimalFormat format = new DecimalFormat();

String temp = stylegetDataFormatString();

// 单元格设置成常规

if (tempequals("General")) {

formatapplyPattern("#");

}

result = formatformat(value);

}

break;

case HSSFCellCELL_TYPE_STRING:// String类型

result = cellgetRichStringCellValue()toString();

break;

case HSSFCellCELL_TYPE_BLANK:

result = "";

default:

result = "";

break;

}

return result;

}

注意事项:同样写入到Excel的时间格式为------> yyyy/m/d h:mm:ss ,且单元格宽度不够的的情况的下:

显示方式1:

显示方式2:

原因分析:“显示方式1”的写入格式是String类型,cellsetCellValue(date),其中date为String类型;

                  “显示方式2”的写入格式为Date类型,cellsetCellValue(date),其中date为Date类型;

解决办法:

1如果想要时间格式不被压缩成成“###”,可以将我们获取到的时间转换成String类型,

SimpleDateFormat formatter= new SimpleDateFormat("yyyy/M/d H:mm:ss");

Date date= new Date(SystemcurrentTimeMillis());

String time= formatterformat(date);

2如果想要单元格格式为时间,且在单元格宽度不够的情况下显示成“###” ,

CreationHelper createHelper=workbookgetCreationHelper();

CellStyle style= workbookcreateCellStyle();

DataFormat format= workbookcreateDataFormat();

stylesetDataFormat(createHelpercreateDataFormat()getFormat("yyyy/M/d H:mm:ss"));

cellsetCellValue(new Date());

cellsetCellStyle(style);

即可!

备注:将时间字符串timeString转换成Date格式方法:

Date date=null;

SimpleDateFormat formatter=new SimpleDateFormat("yyyy/M/d H:mm:ss");

date=formatterparse(timeString);

以上。

                    

首先

1你要明白poi是java 的第三方类库,用于导出excel,word 等等

2 datepicker 是一个用于html页面的的js日期控件

datepicker 的api

>

以上就是关于java读取excel 不知道excel里面具体内容是时间还是数字或者是字符串 如何正确读取呢全部的内容,包括:java读取excel 不知道excel里面具体内容是时间还是数字或者是字符串 如何正确读取呢、POI采坑系列:POI 导入导出Excel时,需要注意的时间格式####、poi 支持日期控件吗 就是datepicker 怎么调用设置单元格d出日期选择器等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/web/9604461.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-30
下一篇 2023-04-30

发表评论

登录后才能评论

评论列表(0条)

保存