创建一个excel文件
1:基本原则:与读取电子表格相式;第一步是创建一个可写的workbook对象;象这样
import java.io.File;
import java.util.Date;
import jxl.*;
import jxl.write.*;
...
WritableWorkbook workbook = Workbook.createWorkbook(new File("output.xls"));
下一步是为workbook 创建sheets:
WritableSheet sheet = workbook.createSheet("First Sheet", 0); //在开始的位置创建了一个名字为First Sheet的表
现在余下的任务是向sheet里添加元素了。
这是很简单的比如说:要把 3.14159 添加到D5里:
Number number = new Number(3, 4, 3.1459);
sheet.addCell(number);
就这样,你可以添加任意多的数据,但你要知道第一点,在构造单元格时,单元格在工作表中的位置就已经确定了。
一旦创建后,单元格的位置是不能够变更的,尽管单元格的内容是可以改变的。
第二点,单元格的定位是按照下面这样的规律(column, row),而且下标都是从0开始,
例如,A1被存储在(0, 0),B1被存储在(1, 0)。
最后,
不要忘记关闭打开的Excel工作薄对象,以释放占用的内存,参见下面的代码片段:
//写入Exel工作表
wwb.write();
//关闭Excel工作薄对象
wwb.close();
例子:
代码(CreateXLS.java):
//生成Excel的类
import java.io.*;
import jxl.*;
import jxl.write.*;
public class CreateXLS
{
public static void main(String args[])
{
try
{
//打开文件
WritableWorkbook book=
Workbook.createWorkbook(new File("zsa.xls"));
//生成名为“第一页”的工作表,参数0表示这是第一页
WritableSheet sheet=book.createSheet("第一页",0);
//在Label对象的构造子中指名单元格位置是第一列第一行(0,0)
//以及单元格内容为test
Label label=new Label(0,0,"zsa");
//将定义好的单元格添加到工作表中
sheet.addCell(label);
/*生成一个保存数字的单元格
必须使用Number的完整包路径,否则有语法歧义
单元格位置是第二列,第一行,值为1000.000*/
jxl.write.Number number = new jxl.write.Number(1,0,1000.000);
sheet.addCell(number);
//写入数据并关闭文件
book.write();
book.close();
}catch(Exception e)
{
System.out.println(e);
}
}
}
编译执行后,会在当前位置产生一个Excel文件。