jackyrong

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

   经常要将EXCEL和数据库打交道的话,建议推荐使用一个好的开源工具JXL,下面小结如何将其EXCEL数据导入到数据库,
以及如何把数据库的数据导出到EXCEL.

1) EXCEL的表格导入数据库
   假设有一个EXCEL,有两个SHEET,记得第一个sheet序号是0,第2个sheet的序号是1.
import jxl.Cell;
import jxl.Sheet;
import jxl.Workbook;
import jxl.read.biff.BiffException;

主要方法为:

   InputStream fs = null;
   Workbook rbw = null;
    try{

       try {      
           fs=new FileInputStream(file);   
           rbw=Workbook.getWorkbook(fs);
           System.out.println("加载本地excel文件成功!");   
           } catch (FileNotFoundException e){
             e.printStackTrace();
           } catch (BiffException e){
             e.printStackTrace();
           } catch (IOException e){
             e.printStackTrace();
           }
       
    
      Sheet book=null;
      Sheet bookSingle=null;
      try{
      book=rbw.getSheet(0);//第一个sheet
         }catch (Exception e){
      e.printStackTrace();   
      }
         System.out.println("取得excel文件sheet成功!"); 

         rsRows=book.getRows();//获取第一个sheet表的总行数
            for(int i=1;i<rsRows;i++){   
           //获取excel文件中数据  
           //第i行第0列
          Cell cell0 = book.getCell(0, i);
          String usercode=cell0.getContents();
                   
          //第i行第1列
          Cell cell1 = book.getCell(1, i);
          String org_name=cell1.getContents();
         }
   注意这里的book.getCell(0,i),是从第I行第0列这样写的,就是反过来

2) 数据库到EXCEL
    File file=new File("xxx.xls");
 WritableWorkbook book = Workbook.createWorkbook(new File(fileName));

    // 生成名为“SheetOne”的工作表,参数0表示这是第一个sheet
    WritableSheet sheet = book.createSheet("SheetOne", 0);

   // 在Label对象的构造子中指名单元格位置是第一列第一行(0,0),以及单元格内容
        Label chs_name_LbTitle=new Label(0, 0, "中文名称");

     ............................................
         sheet.addCell(chs_name_LbTitle);

 Label ent_name_cCell=new Label(0, 1, 要写入的实际数据);
sheet.addCell(ent_name_cCell);
 book.write();
    book.close();

posted on 2009-10-10 16:50  jackyrong的世界  阅读(437)  评论(0编辑  收藏  举报