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