jxl操作excel(一)

jxl操作excel

jxl是一个韩国人写的java操作excel的工具, 在开源世界中,有两套比较有影响的API可 供使用,一个是POI,一个是jExcelAPI。其中功能相对POI比较弱一点。但jExcelAPI对中文支持非常好,API是纯Java的, 并不 依赖Windows系统,即使运行在Linux下,它同样能够正确的处理Excel文件。 另外需要说明的是,这套API对图形和图表的支持很有限,而且仅仅识别PNG格式。

使用如下:

搭建环境

 将下载后的文件解包,得到jxl.jar,放入classpath,安装就完成了。

 基本操作

 一、创建文件

 拟生成一个名为test.xls”的Excel文件,其中第一个工作表被命名为
 第一页,大致效果如下:

 package   test;

 //  生成Excel的类  
  import   java.io.File;

 import   jxl.Workbook;
 import   jxl.write.Label;
 import   jxl.write.WritableSheet;
 import   jxl.write.WritableWorkbook;

 public     class   CreateExcel   {
      public     static     void   main(String args[])   {
          try     {
              //   打开文件  
              WritableWorkbook book   =   Workbook.createWorkbook(  new   File(  "  test.xls  "  ));
              //   生成名为第一页的工作表,参数0表示这是第一页  
              WritableSheet sheet   =   book.createSheet(  "  第一页  "  ,   0  );
              //   Label对象的构造子中指名单元格位置是第一列第一行(0,0)
              //   以及单元格内容为test  
              Label label   =     new   Label(  0  ,   0  ,   "  test  "  );

              //   将定义好的单元格添加到工作表中  
              sheet.addCell(label);

              /*  
             生成一个保存数字的单元格 必须使用Number的完整包路径,否则有语法歧义 单元格位置是第二列,第一行,值为789.123
               */  
            jxl.write.Number number   =     new   jxl.write.Number(  1  ,   0  ,   555.12541  );
            sheet.addCell(number);

              //   写入数据并关闭文件  
              book.write();
            book.close();

        }      catch   (Exception e)   {
            System.out.println(e);
        }  
    }  
}
 

 

   编译执行后,会产生一个Excel文件。

 三、读取文件

 以刚才我们创建的Excel文件为例,做一个简单的读取操作,程序代码如下:

 package   test;

 //  读取Excel的类  
  import   java.io.File;

 import   jxl.Cell;
 import   jxl.Sheet;
 import   jxl.Workbook;

 public     class   ReadExcel   {
      public     static     void   main(String args[])   {
          try     {
            Workbook book   =   Workbook.getWorkbook(  new   File(  "  test.xls  "  ));
              //   获得第一个工作表对象  
              Sheet sheet   =   book.getSheet(  0  );
              //   得到第一列第一行的单元格  
              Cell cell1   =   sheet.getCell(  0  ,   0  );
            String result   =   cell1.getContents();
            System.out.println(result);
            book.close();
        }      catch   (Exception e)   {
            System.out.println(e);
        }  
    }  
}
 


  程序执行结果:test

 四、修改文件
 利用jExcelAPI可以修改已有的Excel文件,修改Excel文件的时候,除了打开文件的方式不同之外,
 其他操作和创建Excel是一样的。下面的例子是在我们已经生成的Excel文件中添加一个工作表:

 package   test;

 import   java.io.File;

 import   jxl.Workbook;
 import   jxl.write.Label;
 import   jxl.write.WritableSheet;
 import   jxl.write.WritableWorkbook;

 public     class   UpdateExcel   {
      public     static     void   main(String args[])   {
          try     {
              //   Excel获得文件  
              Workbook wb   =   Workbook.getWorkbook(  new   File(  "  test.xls  "  ));
              //   打开一个文件的副本,并且指定数据写回到原文件  
              WritableWorkbook book   =   Workbook.createWorkbook(  new   File(  "  test.xls  "  ),
                    wb);
              //   添加一个工作表  
              WritableSheet sheet   =   book.createSheet(  "  第二页  "  ,   1  );
            sheet.addCell(  new   Label(  0  ,   0  ,   "  第二页的测试数据  "  ));
            book.write();
            book.close();
        }      catch   (Exception e)   {
            System.out.println(e);
        }  
    }  
}
 


其他操作

 一、 数据格式化

 Excel中不涉及复杂的数据类型,能够比较好的处理字串、数字和日期已经能够满足一般的应用。

 1、 字串格式化

 字符串的格式化涉及到的是字体、粗细、字号等元素,这些功能主要由WritableFont
 WritableCellFormat类来负责。假设我们在生成一个含有字串的单元格时,使用如下语句,
 为方便叙述,我们为每一行命令加了编号:

 WritableFont font1  =  
   new   WritableFont(WritableFont.TIMES,  16  ,WritableFont.BOLD); 

 WritableCellFormat format1  =  new   WritableCellFormat(font1); 

 Label label  =  new   Label(  0  ,  0  ,data   4   test,format1) 

  其中指定了字串格式:字体为TIMES,字号16,加粗显示。WritableFont有非常丰富的
 构造子,供不同情况下使用,jExcelAPIjava-doc中有详细列表,这里不再列出。

 处代码使用了WritableCellFormat类,这个类非常重要,通过它可以指定单元格的各种
 属性,后面的单元格格式化中会有更多描述。

 处使用了Label类的构造子,指定了字串被赋予那种格式。

 WritableCellFormat类中,还有一个很重要的方法是指定数据的对齐方式,比如针对我们
 上面的实例,可以指定:

    //  把水平对齐方式指定为居中  
   format1.setAlignment(jxl.format.Alignment.CENTRE);

   //  把垂直对齐方式指定为居中  
   format1.setVerticalAlignment(jxl.format.VerticalAlignment.CENTRE);

你可能感兴趣的:(windows,linux,工作,Excel,单元测试)