background image

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 文件中都有写上面对象

 

文件对象 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(); 
}

最后不要忘记关闭 workbook 以释放资源: