为什么用poi读取excel 的数字全是double

 我来答
shihoumacili
高粉答主

推荐于2019-03-02 · 每个回答都超有意思的
知道大有可为答主
回答量:1.1万
采纳率:87%
帮助的人:492万
展开全部

这是正常的。

  1. 通过POI取出的数值默认都是double,即使excel单元格中存的是1,取出来的值也是1.0,这就造成了一些问题,

  2. 如果数据库字段是int,那么就会wrong data type,所以需要对数值类型处理。


代码如下:


Cell cell = null;// 单元格  

Object inputValue = null;// 单元格值  

if(!isEmpty(cell) && cell.getCellType() == Cell.CELL_TYPE_NUMERIC) {  

    long longVal = Math.round(cell.getNumericCellValue());  

    if(Double.parseDouble(longVal + ".0") == doubleVal)  

        inputValue = longVal;  

    else  

        inputValue = doubleVal;  

}  

       这么处理后,单元格中的小数没有变化,如果是整数,也会取到整数。

pyp_it_xp
2010-10-22 · TA获得超过1348个赞
知道小有建树答主
回答量:522
采纳率:75%
帮助的人:172万
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式