Java POI读取excel中数值精度损失问题解决
描述:
excel单元格中,纯数字的单元格,读取后后面会加上.0。
例如:1-->1.0
而使用下面的方法,可能会对小数存在精度损失
cell.setCellType(CellType.STRING);//读取前将单元格设置为文本类型读取
例如:2.2-->2.1999999997
目前的解决办法:
一.将excel单元格改为文本类型
注意,直接修改单元格属性不管用,使用分列的方式,可以实现将数值改为文本类型。
二.java处理
publicclassCommonUtil{
privatestaticNumberFormatnumberFormat=NumberFormat.getNumberInstance();
static{
numberFormat.setGroupingUsed(false);
}
publicstaticStringgetCellValue(Cellcell){
if(null==cell){
return"";
}
Objectvalue;
switch(cell.getCellTypeEnum()){
//省略
caseNUMERIC:
doubled=cell.getNumericCellValue();
value=numberFormat.format(d);//关键在这里!
//省略
}
returnvalue==null?"":value.toString();
}
}
上面的方法可以获取一个正确的数值.
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。
热门推荐
10 八一幼儿祝福语大全简短
11 公司乔迁食堂祝福语简短
12 婚礼结束聚餐祝福语简短
13 儿媳买车妈妈祝福语简短
14 毕业送礼老师祝福语简短
15 同事辞职正常祝福语简短
16 恭贺新婚文案祝福语简短
17 金店立秋祝福语简短英文
18 婆婆高寿祝福语大全简短