资源描述:
《java程序控制excel导入导出数据库信息》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、1从Excel文件读取数据表JavaExcelAPI既可以从本地文件系统的一个文件(.xls),也可以从输入流中读取Excel数据表。读取Excel数据表的第一步是创建Workbook(术语:工作薄),下面的代码片段举例说明了应该如何操作:(完整代码见ExcelReading.java)importjava.io.*;importjxl.*;…………try{//构建Workbook对象,只读Workbook对象//直接从本地文件创建Workbook//从输入流创建WorkbookInputStreamis=newFileInputS
2、tream(sourcefile);jxl.Workbookrwb=Workbook.getWorkbook(is);}catch(Exceptione){e.printStackTrace();}一旦创建了Workbook,我们就可以通过它来访问ExcelSheet(术语:工作表)。参考下面的代码片段://获取第一张Sheet表Sheetrs=rwb.getSheet(0);我们既可能通过Sheet的名称来访问它,也可以通过下标来访问它。如果通过下标来访问的话,要注意的一点是下标从0开始,就像数组一样。一旦得到了Sheet,我们就
3、可以通过它来访问ExcelCell(术语:单元格)。参考下面的代码片段://获取第一行,第一列的值Cellc00=rs.getCell(0,0);Stringstrc00=c00.getContents();//获取第一行,第二列的值Cellc10=rs.getCell(1,0);Stringstrc10=c10.getContents();//获取第二行,第二列的值Cellc11=rs.getCell(1,1);Stringstrc11=c11.getContents();System.out.println("Cell(0,0)
4、"+"value:"+strc00+";type:"+c00.getType());System.out.println("Cell(1,0)"+"value:"+strc10+";type:"+c10.getType());System.out.println("Cell(1,1)"+"value:"+strc11+";type:"+c11.getType());如果仅仅是取得Cell的值,我们可以方便地通过getContents()方法,它可以将任何类型的Cell值都作为一个字符串返回。示例代码中Cell(0,0)是文本型,Ce
5、ll(1,0)是数字型,Cell(1,1)是日期型,通过getContents(),三种类型的返回值都是字符型。如果有需要知道Cell内容的确切类型,API也提供了一系列的方法。参考下面的代码片段:Stringstrc00=null;doublestrc10=0.00;Datestrc11=null;Cellc00=rs.getCell(0,0);Cellc10=rs.getCell(1,0);Cellc11=rs.getCell(1,1);if(c00.getType()==CellType.LABEL){LabelCelllab
6、elc00=(LabelCell)c00;strc00=labelc00.getString();}if(c10.getType()==CellType.NUMBER){NmberCellnumc10=(NumberCell)c10;strc10=numc10.getValue();}if(c11.getType()==CellType.DATE){DateCelldatec11=(DateCell)c11;strc11=datec11.getDate();}System.out.println("Cell(0,0)"+"value
7、:"+strc00+";type:"+c00.getType());System.out.println("Cell(1,0)"+"value:"+strc10+";type:"+c10.getType());System.out.println("Cell(1,1)"+"value:"+strc11+";type:"+c11.getType());在得到Cell对象后,通过getType()方法可以获得该单元格的类型,然后与API提供的基本类型相匹配,强制转换成相应的类型,最后调用相应的取值方法getXXX(),就可以得到确定类型
8、的值。API提供了以下基本类型,与Excel的数据格式相对应,如下图所示:每种类型的具体意义,请参见JavaExcelAPIDocument。当你完成对Excel电子表格数据的处理后,一定要使用close()方法来关闭先前创建的对象,