科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道Java操作Excel之理解JXL--读取Excel

Java操作Excel之理解JXL--读取Excel

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

Java操作Excel之理解JXL--读取Excel

作者:sunyfun 来源:赛迪网技术社区 2007年11月30日

关键字: JXL Excel

  • 评论
  • 分享微博
  • 分享邮件
JXL(Java Excel API)是一个用来动态读写Excel文件的开源框架,利用它可以在任何支持Java的操作系统上动态读写Excel文件。JXL的主页是:http://www.andykhan.com/jexcelapi/,可以在这里下载到它的最新的版本。 U%m}v  
你可以分别通过如下命令 L$-cl"  
java -jar jxl.jar -xml test.xls < G>(G+  
java -jar jxl.jar -cvs test.xls ufDt}[gr  
以xml和cvs格式查看test.xls,这是因为JXL作者实现了一个用来演示的jxl.demo.Demo的类。 {*P^5w8x|I  
>rOom`,  
当然我们使用JXL主要是用它来动态读写Excel文件。现在就来看看JXL在对Excel的读和写上都提供了那些支持。 $NGQQnX@S  
先来看看Excel文件中都有写上面对象 w|=N1=,^E  
1 文件对象 2工作簿对象 3 单元格对象。 It,.)fAc  
相应的在JXL中就有Workbook,Sheet ,Cell 。通过这三个对象我们就可以实现Excel文件的读取工作。 @vr[_S  
我们先想想一下读取步骤,不管是什么样的Excel操作框架必定都要经历 0$ z##oQ  
1选取Excel文件,2选择工作簿,3选择Cell,4读取信息。 @)k}`0G  
那么现在就可以看看JXL中这四步骤如何体现: 1}`j'  
//通过Workbook的静态方法getWorkbook选取Excel文件 m[(2jZS{{  
Workbook workbook = Workbook.getWorkbook(new File("myfile.xls")); ;dJ.#?VjHb  
k5ZOI'Ha&S  
//通过Workbook的getSheet方法选择第一个工作簿(从0开始) ?<_^)J08$  
Sheet sheet = workbook.getSheet(0); |-W"VT9x  
|typ :s  
//通过Sheet方法的getCell方法选择位置为C2的单元格(两个参数都从0开始) Qn:'YH[~,  
Cell c2 = sheet.getCell(2,1); }nuEhz M+  
}Y/!]*4  
//通过Cell的getContents方法把单元格中的信息以字符的形式读取出来 "`;N8Qe  
String stringc2 = c2.getContents(); 6[}rJN; }  
U\bcV@Ex  
可以看到正是刚才所说的四个步骤。 rtEp>[Oca  
1+ [#:=\P  
我们都知道Excel单元格是有格式的,那么这些信息如何取得。 x}tp%|2  
Cell提供了一个getType方法能够返回单元格的类型信息,同时JXL提供了一个CellType类用来预设Excel中的类型信息,而且JXL提供了一些Cell类的子类用来分别用来表示各种类型的单元格,如LabelCell,NumberCell,DateCell分别表示字符、数值、日期类型的单元格。所以我们可以这样写: [dWaJPyS  
if (c2.getType() == CellType.NUMBER) z%6f w"  
{ 2gRU*Xql  
NumberCell nc = (NumberCell) c2; -QlbNJ R@  
numberb2 = nc.getValue(); C+bV"?1  
} sz*y7kh  
<fNWy^G r  
最后不要忘记关闭workbook以释放资源: jO)/-l,J  
workbook.close(); R_gsfgHp  
现在总结一下:三个对象,四个步骤,注意格式。就可以轻松的从Excel文件中读取数据.
查看本文来源
    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章