如何用Apache POI操作Excel文件-----如何对一个单元格加注解?

有的时候,我们需要通过操作Apache POI,在生成Cell数据的同时,能对其生成的Cell,加上注解(comments),类似于下面的。

那么对于这种情况,我们的代码应该如何写呢? 借花献佛,我就用Apache POI官方提供的例子,然后加上一些注解,给大家看一下。本例子的测试代码是基于POI-3.12的。

执行完后,将会生成上图所示的Excel工作表单(sheet)

[java] view plain copy

  1. import org.apache.poi.ss.usermodel.*;
  2. import org.apache.poi.xssf.usermodel.XSSFSheet;
  3. import org.apache.poi.xssf.usermodel.XSSFWorkbook;
  4. import java.io.IOException;
  5. import java.io.FileOutputStream;
  6. /**
  7. * Demonstrates how to work with excel cell comments.
  8. * <p>
  9. * Excel comment is a kind of a text shape,
  10. * so inserting a comment is very similar to placing a text box in a worksheet
  11. * </p>
  12. *
  13. * @author Yegor Kozlov
  14. */
  15. public class CellComments {
  16. public static void main(String[] args) throws IOException {
  17. //1.创建一个工作簿对象
  18. XSSFWorkbook wb = new XSSFWorkbook();
  19. //2.得到一个POI的工具类
  20. CreationHelper factory = wb.getCreationHelper();
  21. //3. 创建一个工作表
  22. XSSFSheet sheet = wb.createSheet();
  23. //4.得到一个换图的对象
  24. Drawing drawing = sheet.createDrawingPatriarch();
  25. //5. ClientAnchor是附属在WorkSheet上的一个对象,  其固定在一个单元格的左上角和右下角.
  26. ClientAnchor anchor = factory.createClientAnchor();
  27. //6. 创建一个单元格(2A单元格)
  28. Cell cell0 = sheet.createRow(1).createCell(0);
  29. //6.1. 对这个单元格设置值
  30. cell0.setCellValue("Test");
  31. //6.2. 对这个单元格加上注解
  32. Comment comment0 = drawing.createCellComment(anchor);
  33. RichTextString str0 = factory.createRichTextString("Hello, World!");
  34. comment0.setString(str0);
  35. comment0.setAuthor("Apache POI");
  36. cell0.setCellComment(comment0);
  37. //7. 创建一个单元格(4F单元格)
  38. Cell cell1 = sheet.createRow(3).createCell(5);
  39. //7.1. 对这个单元格设置值
  40. cell1.setCellValue("F4");
  41. //7.2. 对这个单元格加上注解
  42. Comment comment1 = drawing.createCellComment(anchor);
  43. RichTextString str1 = factory.createRichTextString("Hello, World!");
  44. comment1.setString(str1);
  45. comment1.setAuthor("Apache POI");
  46. cell1.setCellComment(comment1);
  47. //8. 创建一个单元格(4F单元格)
  48. Cell cell2 = sheet.createRow(2).createCell(2);
  49. cell2.setCellValue("C3");
  50. Comment comment2 = drawing.createCellComment(anchor);
  51. RichTextString str2 = factory.createRichTextString("XSSF can set cell comments");
  52. //9。为注解设置字体
  53. Font font = wb.createFont();
  54. font.setFontName("Arial");
  55. font.setFontHeightInPoints((short)14);
  56. font.setBoldweight(Font.BOLDWEIGHT_BOLD);
  57. font.setColor(IndexedColors.RED.getIndex());
  58. str2.applyFont(font);
  59. comment2.setString(str2);
  60. comment2.setAuthor("Apache POI");
  61. comment2.setColumn(2);
  62. comment2.setRow(2);
  63. //10. 保存成Excel文件
  64. String fname = "comments.xlsx";
  65. FileOutputStream out = new FileOutputStream(fname);
  66. wb.write(out);
  67. out.close();
  68. }
  69. }
时间: 2024-10-06 06:08:22

如何用Apache POI操作Excel文件-----如何对一个单元格加注解?的相关文章

(3) 如何用Apache POI操作Excel文件-----如何对一个单元格加注解?

有的时候,我们需要通过操作Apache POI,在生成Cell数据的同时,能对其生成的Cell,加上注解(comments),类似于下面的. 那么对于这种情况,我们的代码应该如何写呢? 借花献佛,我就用Apache POI官方提供的例子,然后加上一些注解,给大家看一下.本例子的测试代码是基于POI-3.12的. 执行完后,将会生成上图所示的Excel工作表单(sheet) import org.apache.poi.ss.usermodel.*; import org.apache.poi.xs

(5) 如何用Apache POI操作Excel文件-----发现Apache的POI的Bug后,如何给Apache的POI报Bug?

在我上篇文章中,(4) 如何用Apache POI操作Excel文件-----发现了POI-3.12一个回归,通过测试POI-3.12的版本,我发现了一个bug,那么发现bug后,该如何处理.我们有2种处理方式,首先我们到Apache POI的bug库里面搜索,看别人有没有创建类似的bug,如果有创建的,这个是最好的结果,我们只需要关注这个bug什么时候被修复.如果没有搜索不到,这个时候我们就需要给Apache POI报bug了.那么,如何给Apache报Bug? 第一步: 打开https://

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

好不容易盼望POI-3.12的最终版本能出来,这个月终于出来,于是先堵为快,从这个的地址(https://poi.apache.org/download.html#POI-3.12)下载最新的POI-3.12版本. 然后,跑了一个程序,对一个Excel的第一个单元格(A0)加上注解(comments),不幸的是,其抛出了下面的错误, Exception in thread "main" java.lang.IllegalArgumentException: Multiple cell

(2) 如何用Apache POI操作Excel文件-----如何在已有的Excel文件中插入一行新的数据?

在POI的第一节入门中,我们提供了两个简单的例子,一个是如何用Apache POI新建一个工作薄,另外一个例子是,如果用Apache POI新建一个工作表.那么在这个章节里面,我将会给大家演示一下,如何用Apache POI在已有的Excel文件中插入一行新的数据.具体代码,请看下面的例子. import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.

如何用Apache POI操作Excel文件-----如何在已有的Excel文件中插入一行新的数据?

在POI的第一节入门中,我们提供了两个简单的例子,一个是如何用Apache POI新建一个工作薄,另外一个例子是,如果用Apache POI新建一个工作表.那么在这个章节里面,我将会给大家演示一下,如何用Apache POI在已有的Excel文件中插入一行新的数据.具体代码,请看下面的例子. [java] view plain copy import java.io.File; import java.io.FileInputStream; import java.io.FileNotFound

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

Apache POI项目的目标就是可以用Java API来创建和维护各种Office文件(MS Word,MS PowerPoint和MS Excel). 本系列文章主要是针对Excel文件的操作.对于Excel的操作,Apache POI提供两种模型:HSSF和XSSF. 其区别,请参考下面的图1.截止到2015年5月28日,当前的最新版本是3.12. 具体信息,我们可以访问其官方网站:http://poi.apache.org/ 1.下面是用Apache POI创建一个工作薄的基本的代码 i

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

如果POI-3.10往一个工作表(sheet)里面插入数据的话,需要注意了,其有一个不太被容易发现的bug. 被插入的工作表(sheet)里面的单元格没有包含任何的注解(comment)的时候,插入一行数据,不会有任何问题.但是如果被插入的工作表(sheet)里面的单元格只要包含任何的注解(comment)的时候,这个时候插入一行数据的时候,就会破坏这个文件.当程序执行完后,如果打开被插入数据的Excel文件,我们将会发现,其会弹出下面的对话框. 程序代码如下, package com.tibc

(7) 如何用Apache POI操作Excel文件-----如何用Apache POI 画一个离散图

有的时候,我们需要Excel中的数据,通过一个图画,可视化的表现出来. 那么这个时候,应该如何做呢?现在就借花献佛,以Apache POI自己提供的一个例子为例,给大家演示一下POI的API 如何画图的.下面是一个最终的效果图.然后分别给大家解释每段代码的作用和意义. 代码如下, import java.io.FileOutputStream; import org.apache.poi.ss.usermodel.*; import org.apache.poi.ss.util.*; impor

如何用Apache POI操作Excel文件-----如何用Apache POI 画一个离散图

有的时候,我们需要Excel中的数据,通过一个图画,可视化的表现出来. 那么这个时候,应该如何做呢?现在就借花献佛,以Apache POI自己提供的一个例子为例,给大家演示一下POI的API 如何画图的.下面是一个最终的效果图.然后分别给大家解释每段代码的作用和意义. 代码如下, [java] view plain copy import java.io.FileOutputStream; import org.apache.poi.ss.usermodel.*; import org.apac