您的当前位置:首页正文

jxl对excel文件内容导入导出

2020-01-08 来源:榕意旅游网


1. 当然我们使用JXL主要是用它来动态读写Excel文件。现在就来看看JXL在对Excel的读和写上都提供了那些支持。

2. 先来看看Excel文件中都有写上面对象

3. 1 文件对象 2工作簿对象 3 单元格对象。

4. 相应的在JXL中就有Workbook,Sheet ,Cell 。通过这三个对象我们就可以实现Excel文件的读取工作。

5. 我们先想想一下读取步骤,不管是什么样的Excel操作框架必定都要经历

6. 1选取Excel文件,2选择工作簿,3选择Cell,4读取信息。

7. 那么现在就可以看看JXL中这四步骤如何体现:

8. Workbook workbook = Workbook.getWorkbook(new

File(\"myfile.xls\")); //通过Workbook的静态方法getWorkbook选取Excel文件

int sheetsnumber = workbook.getNumberOfSheets();//获取工作薄个数

Sheet sheet = workbook.getSheet(0); //通过Workbook的getSheet方法选择第一个工作簿(从0开始)

int columnum = sheet.getColumns(); // 得到列数

int rownum = sheet.getRows(); // 得到行数

Cell c2 = sheet.getCell(columnum , rownum ); //通过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();

2.与读取Excel工作表相似,首先要使用Workbook类的工厂方法创建一个可写入的工作薄(Workbook)对象,这里要注意的是,只能通过API提供的工厂方法来创建Workbook,而不能使用WritableWorkbook的构造函数,因为类WritableWorkbook的构造函数为protected类型。

API提供了两种方式来处理可写入的输出流,一种是直接生成本地文件,如果文件名不带全路径的话,缺省的文件会定位在当前目录,如果文件名带有全路径的话,则生成的Excel文件则会定位在相应的目录;另外一种是将Excel对象直接写入到输出流,例如:用户通过浏览器来访问Web服务器,如果HTTP头设置正确的话,浏览器自动调用客户端的Excel应用程序,来显示动态生成的Excel电子表格。

接下来就是要创建工作表,创建工作表的方法与创建工作薄的方法几乎一样,同样是通过工厂模式方法获得相应的对象,该方法需要两个参数,一个是工作表的名称,另一个是工作表在工作薄中的位置,参考下面的代码片段:

<%@ page language=\"java\" pageEncoding=\"GBK\"%>

response.setContentType(\"application/download\");

response.setHeader(\"Content-Disposition\s\");

ServletOutputStream sos = response.getOutputStream();

WritableWorkbook wwb=null;

wwb = Workbook.createWorkbook(sos);

WritableSheet ws = wwb.createSheet(\"sheet1\

Label lab = new Label(0, 0, \"序号\");

ws.addCell(lab);

lab = new Label(1, 0, \"用户名\");

ws.addCell(lab);

lab = new Label(2, 0, \"性别\");

ws.addCell(lab);

………..

wwb.write();

wwb.close();

sos.flush();

sos.close();

总结一下:三个对象,四个步骤,注意格式。就可以轻松的从Excel文件中读写数据.

因篇幅问题不能全部显示,请点此查看更多更全内容