JXL(Java Excel API)是一个用来动态读写Excel文件的开源框架,利用它可以在任何支持Java的操作系统上动态读写Excel文件。JXL的下载地址是:http://www.andykhan.com/jexcelapi/download.html,可以在这里下载到它的最新的版本。
你可以分别通过如下命令
java -jar jxl.jar -xml test.xls
java -jar jxl.jar -cvs test.xls
以xml和cvs格式查看test.xls,这是因为JXL作者实现了一个用来演示的jxl.demo.Demo的类。当然我们使用JXL主要是用它来动态读写Excel文件。
先来看看Excel文件中都有哪些对象
1、文件对象(Workbook)
2、工作簿对象(Sheet)
3、单元格对象。(Cell)
相应的在JXL中就有Workbook,Sheet ,Cell 。通过这三个对象我们就可以实现Excel文件的读取工作。
不管是什么样的Excel操作框架必定都要经历
1、选取Excel文件
2、选择工作簿
3、选择Cell
4、读取信息。
那么现在就可以看看JXL中这四步骤如何体现:
Workbook workbook = Workbook.getWorkbook(new File("myfile.xls"));//通过Workbook的静态方法getWorkbook选取Excel文件
Sheet sheet = workbook.getSheet(0);//通过Workbook的getSheet方法选择第一个工作簿(从0开始)
Cell c2 = sheet.getCell(2,1);//通过Sheet方法的getCell方法选择位置为C2的单元格(两个参数都从0开始)
String stringc2 = c2.getContents();//通过Cell的getContents方法把单元格中的信息以字符的形式读取出来
可以看到正是刚才所说的四个步骤。
我们都知道Excel单元格是有格式的,那么这些信息如何取得。
Cell提供了一个getType方法能够返回单元格的类型信息,同时JXL提供了一个CellType类用来预设Excel中的类型信息,而且JXL提供了一些Cell类的子类用来分别用来表示各种类型的单元格,如LabelCell,NumberCell,DateCell分别表示字符、数值、日期类型的单元格。所以我们可以这样写:
if (c2.getType() == CellType.NUMBER)
{
NumberCell nc = (NumberCell) c2;
numberb2 = nc.getValue();
}
最后不要忘记关闭workbook以释放资源:
workbook.close();
现在总结一下:三个对象,四个步骤,注意格式。就可以轻松的从Excel文件中读取数据。