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

时间:2023-01-01 08:46:28

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

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

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

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

  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. }

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

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

    在POI的第一节入门中,我们提供了两个简单的例子,一个是如何用Apache POI新建一个工作薄,另外一个例子是,如果用Apache POI新建一个工作表.那么在这个章节里面,我将会给大家演示一下,如 ...

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

    有的时候,我们需要Excel中的数据,通过一个图画,可视化的表现出来. 那么这个时候,应该如何做呢?现在就借花献佛,以Apache POI自己提供的一个例子为例,给大家演示一下POI的API 如何画图 ...

  3. &lpar;6&rpar; 如何用Apache POI操作Excel文件-----POI-3&period;10的一个和注解(comment)相关的另外一个bug

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

  4. java使用Apache POI操作excel文件

    官方介绍 HSSF is the POI Project's pure Java implementation of the Excel '97(-2007) file format. XSSF is ...

  5. 使用Apache POI操作Excel文件---在已有的Excel文件中插入一行新的数据

    package org.test; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundEx ...

  6. 项目一&colon;第四天 1、快递员的条件分页查询-noSession&comma;条件查询 2、快递员删除(逻辑删除) 3、基于Apache POI实现批量导入区域数据 a&rpar;Jquery OCUpload上传文件插件使用 b&rpar;Apache POI读取excel文件数据

    1. 快递员的条件分页查询-noSession,条件查询 2. 快递员删除(逻辑删除) 3. 基于Apache POI实现批量导入区域数据 a) Jquery OCUpload上传文件插件使用 b) ...

  7. java使用POI操作excel文件&comma;实现批量导出&comma;和导入

    一.POI的定义 JAVA中操作Excel的有两种比较主流的工具包: JXL 和 POI .jxl 只能操作Excel 95, 97, 2000也即以.xls为后缀的excel.而poi可以操作Exc ...

  8. 利用Apache POI操作Excel

    最近在做接口,有个功能是利用Excel导入汽车发动机所需零件信息到线上系统中.简单回顾一下之前学过的用java操作Excel. 1.maven配置Apache POI pom.xml中配置POIjar ...

  9. c&num;操作Excel模板,替换命名单元格或关键字形成报表

    c#操作Excel模板,替换命名单元格或关键字形成报表 http://blog.sina.com.cn/s/blog_45eaa01a0102vqma.html一 建立Excel 模板文件 templ ...

随机推荐

  1. Java 枚举用法详解

    概念 enum 的全称为 enumeration, 是 JDK 1.5 中引入的新特性. 在Java中,被 enum 关键字修饰的类型就是枚举类型.形式如下: enum Color { RED, GR ...

  2. 《Linux内核分析》第六周 读书笔记

    <Linux内核设计与实现>CHAPTER3阅读梳理 [学习时间:3hours] [学习内容:进程的描述:进程的生命周期(包括创建.终结)] 一.进程(任务)描述 1.进程是处于执行期的程 ...

  3. XML前言

    一.前言 1.XML全称"eXtensible Markup Language"(可扩展的标记语言) 2.DTD全称"Document Type Defintion&qu ...

  4. 用 Webgoat 撬动地球,看安全测试的引路石!

    测试工程师是很多人迈进软件行业的起点.从负责很小的局部到把握整个产品的质量,每个人花费的时间长短不一--从功能到性能.可用性到容错性.从兼容性到扩展性.稳定性到健壮性--方方面面逐渐做广做深. 不过, ...

  5. Android Sqlite数据库执行插入查询更新删除的操作对比

    下面是在Android4.0上,利用Sqlite数据库的insert,query,update,delete函数以及execSql,rawQuery函数执行插入,查询,更新,删除操作花费时间的对比结果 ...

  6. 解决使用vue-cli生成项目后项目地址自动添加&num;号的问题

    vue-router官网https://router.vuejs.org/zh/guide/ vue的路由在默认的hash模式下,url会带有一个#,不美观,而且在微信分享,授权登录等都会有一些坑.所 ...

  7. debian开启cgroup memory子系统

    Debian系统默认是关闭cgroup memory子系统的. 1.修改grub启动参数 # vim /etc/default/grub GRUB_CMDLINE_LINUX="cgroup ...

  8. 【java规则引擎】《Drools7&period;0&period;0&period;Final规则引擎教程》第4章 4&period;2 agenda-group

    转载:https://blog.csdn.net/wo541075754/article/details/75332720 agenda-group 规则的调用与执行是通过StatelessKieSe ...

  9. Django2&period;1集成xadmin管理后台所遇到的错误集锦,解决填坑

    django默认是有一个admin的后台管理模块,但是丑,功能也不齐全,但是大神给我们已经集成好了xadmin后台,我们拿来用即可,但是呢,django已经升级到2.1版本了,xadmin貌似跟不上节 ...

  10. HTML DOM nodeType 属性

    实例 获得 body 元素的节点类型: document.body.nodeType; 结果: 1 定义和用法 nodeType 属性返回以数字值返回指定节点的节点类型. 如果节点是元素节点,则 no ...