(4) 如何用Apache POI操作Excel文件-----发现了POI-3.12一个回归bug

原创 2015年05月29日 17:16:32

好不容易盼望POI-3.12的最终版本能出来,这个月终于出来,于是先堵为快,从这个的地址(https://poi.apache.org/download.html#POI-3.12)下载最新的POI-3.12版本。

然后,跑了一个程序,对一个Excel的第一个单元格(A1)加上注解(comments),不幸的是,其抛出了下面的错误,

Exception in thread "main" java.lang.IllegalArgumentException: Multiple cell comments in one cell are not allowed, cell: A1
at org.apache.poi.xssf.usermodel.XSSFDrawing.createCellComment(XSSFDrawing.java:318)
at org.apache.poi.xssf.usermodel.XSSFDrawing.createCellComment(XSSFDrawing.java:52)
at com.tibco.poi.xssf.CellComments.main(CellComments.java:49)


然后有用同样的代码,在POI-3.10的版本上测试了一下,没有发现任何问题,所以,可知这是一个回归问题。下面是重现这个问题的代码(用的是我上篇文章的代码,只不过把第33行的代码做了一下小小修改,http://blog.csdn.net/chancein007/article/details/46238217,把注解(comment)加在了A1单元格 )。那么遇到这样的回归问题,该如何处理呢?这个时候,我们可以给Apache POI的Bugzilla系统新建一个bug,这样他们看到后,也许在下一个版本就帮我们解决了。具体如何开Bugzilla的bug,请看下一个章节。

import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import java.io.IOException;
import java.io.FileOutputStream;

/**
 * Demonstrates how to work with excel cell comments.
 * <p>
 * Excel comment is a kind of a text shape,
 * so inserting a comment is very similar to placing a text box in a worksheet
 * </p>
 *
 * @author Yegor Kozlov
 */
public class CellComments {
    public static void main(String[] args) throws IOException {
    	//1.创建一个工作簿对象
    	XSSFWorkbook wb = new XSSFWorkbook();

    	//2.得到一个POI的工具类
        CreationHelper factory = wb.getCreationHelper();

        //3. 创建一个工作表
        XSSFSheet sheet = wb.createSheet();
        
        //4.得到一个换图的对象
        Drawing drawing = sheet.createDrawingPatriarch();
        //5. ClientAnchor是附属在WorkSheet上的一个对象,  其固定在一个单元格的左上角和右下角.
        ClientAnchor anchor = factory.createClientAnchor();
        
        //6. 创建一个单元格(A1单元格)
        Cell cell0 = sheet.createRow(0).createCell(0);
        //6.1. 对这个单元格设置值
        cell0.setCellValue("Test");
        //6.2. 对这个单元格加上注解
        Comment comment0 = drawing.createCellComment(anchor);
        RichTextString str0 = factory.createRichTextString("Hello, World!");
        comment0.setString(str0);
        comment0.setAuthor("Apache POI");
        cell0.setCellComment(comment0);
        
        //7. 创建一个单元格(4F单元格)
        Cell cell1 = sheet.createRow(3).createCell(5);
        //7.1. 对这个单元格设置值
        cell1.setCellValue("F4");
        //7.2. 对这个单元格加上注解
        Comment comment1 = drawing.createCellComment(anchor);
        RichTextString str1 = factory.createRichTextString("Hello, World!");
        comment1.setString(str1);
        comment1.setAuthor("Apache POI");
        cell1.setCellComment(comment1);

        //8. 创建一个单元格(4F单元格)
        Cell cell2 = sheet.createRow(2).createCell(2);
        cell2.setCellValue("C3");

        Comment comment2 = drawing.createCellComment(anchor);
        RichTextString str2 = factory.createRichTextString("XSSF can set cell comments");
        //9。为注解设置字体
        Font font = wb.createFont();
        font.setFontName("Arial");
        font.setFontHeightInPoints((short)14);
        font.setBoldweight(Font.BOLDWEIGHT_BOLD);
        font.setColor(IndexedColors.RED.getIndex());
        str2.applyFont(font);

        comment2.setString(str2);
        comment2.setAuthor("Apache POI");
        comment2.setColumn(2);
        comment2.setRow(2);
        //10. 保存成Excel文件
        String fname = "comments.xlsx";
        FileOutputStream out = new FileOutputStream(fname);
        wb.write(out);
        out.close();

    }
}




版权声明:本文为博主原创文章,未经博主允许不得转载。

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

POI--HSSFCell类

用POI创建单元格,使用「HSSFCell」类 该类包含三个构造方法。  protected HSSFCell(Workbook book, Sheet sheet, int row, CellV...

下拉搜索 bootstrap combox 搜索建议插件

Bootstrap Search Suggest  Demo|示例 这是一个基于 bootstrap 按钮式下拉菜单组件的搜索建议插件,必须使用于按钮式下拉菜单组件上。 功能说明...

POI 注解方式 导入导出 excel , 只依赖于 POI包

对 excel 导入导出, 使用注解的方式, 方便转换成对象,或者 由对象输出到 输出流 的excel; 只用在 model 里面加入少量注解, 就可以方便的进行导入导出操作了!...

(8) 如何用Apache POI操作Excel文件-----POI-3.10.1 的一个黑白颜色颠倒的bug以及解决方案

在用POI-3.10的版本设置Excel单元格的字体的颜色或者单元格背景色的时候,对于XSSF方式,如果设置的颜色为黑色,则实际在Excel中渲染出来的却是白色;反之,如果设置的颜色为白色,则实际在E...

(6) 如何用Apache POI操作Excel文件-----POI-3.10的一个和注解(comment)相关的另外一个bug

如果POI-3.10往一个工作表(sheet)里面插入数据的话,需要注意了,其有一个不太被容易发现的bug。 被插入的工作表(sheet)里面的单元格没有包含任何的注解(comment)的时候,插入一...

Apache poi 操作 excel 文件压缩包

  • 2017年07月14日 02:46
  • 9.76MB
  • 下载

(1) 如何用Apache POI操作Excel文件-----入门

Apache POI项目的目标就是可以用Java API来创建和维护各种Office文件(MS Word,MS PowerPoint和MS Excel). 本系列文章主要是针对Excel文件的操作。对...

(9) 如何用Apache POI操作Excel文件-----应用条件样式(ConditionalFormatting)

有的时候,我们可能想根据一些条件,把Excel工作表中的一些数据,根据某个特定的条件,修改一下满足条件的单元格的样式. 其中比较操作符对象ComparisonOperator支持除了BWTWEEN和N...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:(4) 如何用Apache POI操作Excel文件-----发现了POI-3.12一个回归bug
举报原因:
原因补充:

(最多只允许输入30个字)