使用jxl.jar操作Excel之使用createSheet(String,int)要注意的地方

在java中使用jxl.jar操作Excel是非常简单方便的,尽管效率并不高。

我近日在使用jxl.jar时发现使用createSheet(String,int)时如果大意的话会很容易出错。传入的int型参数代表sheet号,0是第一页,1是第二页,依次类推,打开Excel表格在底端可以看到,编号最小的页在最左边。

如果在使用createSheet函数的时候没有注意编号问题,两次使用了同一个编号,比如两次创建编号为0的sheet,这时第二次创建的sheet会是第一页,但第一次创建的sheet并未被覆盖,而是向后移成为第二页,后面的页也都后移一页,有些像数组的插入。

另外如果使用了不连续的编号,比如依次创建了编号为0,1,2的sheet,接着创建了编号为4的sheet,这时最后创建的一个sheet的编号不会是4,而是会被设置为顺延的3,如果你执行getSheet(4),会报数组越界的错。

下面用一个例子来详细讲解一下:

	 WritableWorkbook book  =  Workbook.createWorkbook( new  File("D:\\Excel\\test.xls"));
         WritableSheet sheet  =  book.createSheet( "number0" ,  4 );
	   
	 WritableSheet sheet1  =  book.createSheet( "number1" ,  3 );
	   
	 WritableSheet sheet2  =  book.createSheet( "number2" ,  2 );
	   
	 WritableSheet sheet3  =  book.createSheet( "number3" ,  1 );
	   
	 WritableSheet sheet4  =  book.createSheet( "number4" ,  0 );
         book.write();
         book.close();

用以上代码得到的Excel表格中,从编号为0到编号为4的sheet依次为number4,number0,number3,number1,number2。

我们逐条语句来分析。执行第二条后,名为number0的sheet会成为编号为0的sheet,执行第三句时,因为3比现有编号0大,因此被放在number0的后面,成为编号为1的sheet,执行第四句后,number2成为编号为2的sheet,现有sheet序列为number0,number1,number2。第五句,因为编号1不大于现在已有的编号,因此执行插入,number3成为编号为1的sheet,原来编号为1和2的sheet分别成为编号为2和3的sheet,序列变为number0,number3,number1,number2。第六句将number4插在最前面,其余页编号都加1,因此最终得到的序列是number4,number0,number3,number1,number2。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

热血大婶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值