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表中是数值型的
我不清楚怎样进行类型转换,向大家请教!!!谢谢 展开
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表中是数值型的
我不清楚怎样进行类型转换,向大家请教!!!谢谢 展开
2个回答
展开全部
if (cell.getCellType() == HSSFCell.CELL_TYPE_NUMERIC){
String form = cell.getCellStyle().getDataFormatString();
DecimalFormat format = new DecimalFormat(form);
format.format(cell.getNumericCellValue());
}
String form = cell.getCellStyle().getDataFormatString();
DecimalFormat format = new DecimalFormat(form);
format.format(cell.getNumericCellValue());
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
光点科技
2023-08-15 广告
2023-08-15 广告
通常情况下,我们会按照结构模型把系统产生的数据分为三种类型:结构化数据、半结构化数据和非结构化数据。结构化数据,即行数据,是存储在数据库里,可以用二维表结构来逻辑表达实现的数据。最常见的就是数字数据和文本数据,它们可以某种标准格式存在于文件...
点击进入详情页
本回答由光点科技提供
展开全部
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);
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);
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |