Poi判断单元格的数据类型问题

写了一个关于Excel数据写入数据库的程序,下面是把读Excel文件的相关代码:publicList<SAV_TMP>readSAV_TMP(FilexlsFile){L... 写了一个关于Excel数据写入数据库的程序,下面是把读Excel文件的相关代码:public List<SAV_TMP> readSAV_TMP(File xlsFile){
List<SAV_TMP> list=new ArrayList<SAV_TMP>();
try{
FileInputStream fln=new FileInputStream(xlsFile);//创建一个文件流
HSSFWorkbook readWorkBook=new HSSFWorkbook(fln);//获取工作簿
HSSFSheet readSheet=readWorkBook.getSheet("Sheet1");//获取第一张工作表,Sheet1表名
HSSFRow readRow=readSheet.getRow(0);//数据起始行
HSSFCell readCell=readRow.getCell((short)0);//单元格
System.out.println("第一个单元格是:"+readCell.getStringCellValue());
int count=readSheet.getPhysicalNumberOfRows();//获得工作表中一共有多少条数据
for(int i=2;i<count;i++){//Excel中的第三行起是要读入的数据
HSSFRow readRow1=readSheet.getRow(i);
String acno=readCell.getStringCellValue();
String rctl=readCell.getStringCellValue();
String cunm=readCell.getStringCellValue();
double acbl=readCell.getNumericCellValue();
double rjye=readCell.getNumericCellValue();

现在报出异常:java.lang.NumberFormatException: You cannot get a numeric value from a String based cell
应该就是这两句的问题
double acbl=readCell.getNumericCellValue();
double rjye=readCell.getNumericCellValue();
我的数据库中acbl和rjye就是Double类型的,Excel表中是数值型的

我不清楚怎样进行类型转换,向大家请教!!!谢谢
展开
 我来答
liwei113114
2010-07-29
知道答主
回答量:28
采纳率:0%
帮助的人:18.9万
展开全部
if (cell.getCellType() == HSSFCell.CELL_TYPE_NUMERIC){
String form = cell.getCellStyle().getDataFormatString();
DecimalFormat format = new DecimalFormat(form);
format.format(cell.getNumericCellValue());
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
光点科技
2023-08-15 广告
通常情况下,我们会按照结构模型把系统产生的数据分为三种类型:结构化数据、半结构化数据和非结构化数据。结构化数据,即行数据,是存储在数据库里,可以用二维表结构来逻辑表达实现的数据。最常见的就是数字数据和文本数据,它们可以某种标准格式存在于文件... 点击进入详情页
本回答由光点科技提供
tomiscat2009
推荐于2016-06-23 · TA获得超过2434个赞
知道小有建树答主
回答量:380
采纳率:0%
帮助的人:539万
展开全部
ACNO
1234567890
2343456566
4565678878

1、这种情况下,POI在读取ACNO时,认为他是数值,CUNM也一样,所以这两列应该用getNumericCellValue()读取

2、在用getNumericCellValue()读取数值后,返回的值是用科学计数法表示的:double acno=1.23456789E9,因而必须用NumberFormat类格式化一下:format(acno)="1234567890",这才是正确的ACNO,CUNM同

3、代码:
NumberFormat nf = NumberFormat.getInstance();
nf.setGroupingUsed(false);//true时的格式:1,234,567,890
double acno=readCell0.getNumericCellValue();
String acnoStr=nf.format(acno);
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式