Java如何操作Word, Excel,

发布时间:2019-09-01 09:51:22编辑:auto阅读(1650)

    3. 拷贝、更新Excel工作薄

      接下来简要介绍一下如何更新一个已经存在的工作薄,主要是下面二步操作,第一步是构造只读的Excel工作薄,第二步是利用已经创建的Excel工作薄创建新的可写入的Excel工作薄,参考下面的代码片段:(完整代码见ExcelModifying.java)

    //创建只读的Excel工作薄的对象

    jxl.Workbook rw = jxl.Workbook.getWorkbook(new File(sourcefile));

     

    //创建可写入的Excel工作薄对象

    jxl.write.WritableWorkbook wwb = Workbook.createWorkbook(new File(targetfile), rw);

     

    //读取第一张工作表

    jxl.write.WritableSheet ws = wwb.getSheet(0);

     

    //获得第一个单元格对象

    jxl.write.WritableCell wc = ws.getWritableCell(0, 0);

     

    //判断单元格的类型, 做出相应的转化

    if(wc.getType() == CellType.LABEL)

    {

    Label l = (Label)wc;

      l.setString("The value has been modified.");

    }

     

    //写入Excel对象

    wwb.write();

     

    //关闭可写入的Excel对象

    wwb.close();

     

    //关闭只读的Excel对象

    rw.close();

      之所以使用这种方式构建Excel对象,完全是因为效率的原因,因为上面的示例才是API的主要应用。为了提高性能,在读取工作表时,与数据相关的一些输 出信息,所有的格式信息,如:字体、颜色等等,是不被处理的,因为我们的目的是获得行数据的值,既使没有了修饰,也不会对行数据的值产生什么影响。唯一的 不利之处就是,在内存中会同时保存两个同样的工作表,这样当工作表体积比较大时,会占用相当大的内存,但现在好像内存的大小并不是什么关键因素了。

      一旦获得了可写入的工作表对象,我们就可以对单元格对象进行更新的操作了,在这里我们不必调用API提供的add()方法,因为单元格已经于工作表当中,所以我们只需要调用相应的setXXX()方法,就可以完成更新的操作了。

      尽单元格原有的格式化修饰是不能去掉的,我们还是可以将新的单元格修饰加上去,以使单元格的内容以不同的形式表现。

      新生成的工作表对象是可写入的,我们除了更新原有的单元格外,还可以添加新的单元格到工作表中,这与示例2的操作是完全一样的。

      最后,不要忘记调用write()方法,将更新的内容写入到文件中,然后关闭工作薄对象,这里有两个工作薄对象要关闭,一个是只读的,另外一个是可写入的。

关键字

上一篇: python 算法

下一篇: Windows 罕见技巧全集3