jxl运用

1 篇文章 0 订阅

jxl.jar包:http://pan.baidu.com/s/1kVdGh8b

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

 先来看看Excel文件中都有写上面对象   
文件对象 2工作簿对象 单元格对象  
相应的在JXL中就有WorkbookSheet Cell 。通过这三个对象我们就可以实现Excel文件的读取工作。  


我们先想想一下读取步骤,不管是什么样的Excel操作框架必定都要经历
1选取Excel文件,2选择工作簿,3选择Cell4读取信息。
那么现在就可以看看JXL中这四步骤如何体现:  
Workbook workbook = Workbook.getWorkbook(new File("myfile.xls"));  //通过Workbook的静态方法getWorkbook选取Excel文件

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

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

int  columnum  =  sheet.getColumns(); //  得到列数 
int  rownum  =  sheet.getRows(); //  得到行数
Cell c2 = sheet.getCell(columnum , rownum ); //通过Sheet方法的getCell方法选择位置为C2的单元格(两个参数都从0开始)  

String stringc2 = c2.getContents();   //通过CellgetContents方法把单元格中的信息以字符的形式读取出来 
可以看到正是刚才所说的四个步骤。

我们都知道Excel单元格是有格式的,那么这些信息如何取得。
Cell提供了一个getType方法能够返回单元格的类型信息,同时JXL提供了一个CellType类用来预设Excel中的类型信息,而且JXL提供了一些Cell类的子类用来分别用来表示各种类型的单元格,如LabelCellNumberCellDateCell分别表示字符、数值、日期类型的单元格。所以我们可以这样写:  
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电子表格。

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

 response.setContentType("application/vnd.ms-excel");
 response.setHeader("Content-Disposition", "attachment;filename=5.xls");

 OutputStream os = response.getOutputStream();
 WritableWorkbook wb = Workbook.createWorkbook(os);
 WritableSheet sheet = wb.createSheet("detail", 0);
 sheet.addCell(new Label(0, 0, "手机型号"));
 sheet.addCell(new Label(1, 0, "串号一"));
 sheet.addCell(new Label(2, 0, "串号二"));
 sheet.addCell(new Label(3, 0, "入库价格"));
 Iterator<StoMobstock> detailIterator = detailList.iterator();
 int rowNo = 1;
  while (detailIterator.hasNext()) {
                StoMobstock mobstock = detailIterator.next();
                sheet.addCell(new Label(0, rowNo, mobstock.getMobTypeId()));
                sheet.addCell(new Label(1, rowNo, mobstock.getSn1()));
                sheet.addCell(new Label(2, rowNo, mobstock.getSn2()));
                sheet.addCell(new Number(3, rowNo, mobstock.getBuyPrice()
                        .doubleValue(), new WritableCellFormat(
                        new NumberFormat("#,###.00"))));
                rowNo++;
            }
            wb.write();
            wb.close();
            return null;

.......

示例

 import java.io.*;


import jxl.Cell;
import jxl.Sheet;
import jxl.Workbook;
import jxl.read.biff.BiffException;
import jxl.write.Label;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
public class Test {
public static void main(String[] args) throws Exception {
File file = new File("E:\\1.xls");
//write(file);
read(file);
}

//写入excel
public static void write(File file) throws Exception{
int[][] datas={{1,2,3},{3,4,5},{5,6,8}};
OutputStream os = new FileOutputStream(file);
        WritableWorkbook wb = Workbook.createWorkbook(os);
        WritableSheet sheet = wb.createSheet("detail", 0);
        sheet.addCell(new Label(0, 0, "标题一"));
        sheet.addCell(new Label(1, 0, "标题二"));
        sheet.addCell(new Label(2, 0, "标题三"));


       for(int i = 0; i < datas.length; i++)
      for(int j = 0; j < datas[i].length; j++)
      {
           sheet.addCell(new Label(i,j,String.valueOf(datas[i][j])));
           
       }
       wb.write();
       wb.close();
}

//读取excel
public static void read(File file) throws Exception{
//选取文件对象
Workbook book = Workbook.getWorkbook(file);
//获取工作薄
Sheet sheet = book.getSheet(0);
//获取行列数
int rows = sheet.getRows();
int cols = sheet.getColumns();
System.out.println("行数:"+rows +","+"列数:"+cols);
//遍历单元格内容
for(int i = 0; i < rows; i++){
for(int j = 0; j < cols; j++){
Cell cell = sheet.getCell(i, j);
System.out.print(cell.getContents() + " ");
}
System.out.println();
}
book.close();

}
}
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值