如何用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.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. 创建一个单元格(2A单元格)
- Cell cell0 = sheet.createRow(1).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();
- }
- }
转载于:https://www.cnblogs.com/telwanggs/p/5787050.html
如何用Apache POI操作Excel文件-----如何对一个单元格加注解?相关推荐
- 如何用Apache POI操作Excel文件-----如何在已有的Excel文件中插入一行新的数据?
在POI的第一节入门中,我们提供了两个简单的例子,一个是如何用Apache POI新建一个工作薄,另外一个例子是,如果用Apache POI新建一个工作表.那么在这个章节里面,我将会给大家演示一下,如 ...
- (6) 如何用Apache POI操作Excel文件-----POI-3.10的一个和注解(comment)相关的另外一个bug...
如果POI-3.10往一个工作表(sheet)里面插入数据的话,需要注意了,其有一个不太被容易发现的bug. 被插入的工作表(sheet)里面的单元格没有包含任何的注解(comment)的时候,插入一 ...
- 如何用Apache POI操作Excel文件-----如何用Apache POI 画一个离散图
有的时候,我们需要Excel中的数据,通过一个图画,可视化的表现出来. 那么这个时候,应该如何做呢?现在就借花献佛,以Apache POI自己提供的一个例子为例,给大家演示一下POI的API 如何画图 ...
- Apache POI操作Excel文件
Apache POI是用Java编写的免费开源的跨平台的Java API,Apache POI提供API给Java程序对Microsoft Office格式档案读和写的功能,其中使用最多的就是使用PO ...
- 采用APACHE POI操作EXCEL文件--计算式调用另一文件
http://blog.sina.com.cn/s/blog_6151984a0100sczi.html 测试环境: 当前EXCEL文件: workbook.xls 假设一个CELL的计算式如下: ...
- java excel相同的合并_Java使用Apache POI合并Excel连续相同内容的单元格
环境: Apache POI 3.17: HSSFSheet: 目的: 对Excel表格中同一列,如果连续的两个或两个以上单元格的内容相同,则对这些单元格进行合并. 实现代码: /** * 合并指定E ...
- Apache POI操作Excel导出JAVABEAN对象方法
2019独角兽企业重金招聘Python工程师标准>>> Apache POI操作Excel导出方法说明 Apache的POI组件是Java操作Microsoft Office办公套件 ...
- Apache POI操作Excel的坑
本文记录一下用Apache POI操作Excel时可能遇到一些坑. excel版本错误 首先是excel版本问题,由于office excel 03版和07版的区别,在读取文件时如果版本不匹配会报以下 ...
- Java使用POI操作Excel文件
我们可以使用POI操作Excel文件,本文主要介绍:"导入POI的Maven依赖"."创建Poi对象"."Poi读取Excel工作表数目". ...
最新文章
- 零基础入门学python 第二版-《零基础入门学习Python》第二版和第一版的区别在哪里呢?...
- python运行软件-提高Python程序的运行速度
- CTFshow 命令执行 web62
- 中的挂起是什么意思_书房装饰挂什么画好 书法字画给你想要的诗意生活
- Jquery-基础知识点
- 妙用世界之窗浏览器的隐私保护功能
- cartographer坐标系_cartographer个人对框架解读
- cisco 密码重置
- 全新的Kafka controller
- 机器学习重塑供应链管理的10个途径
- Linux下的WPS安装
- hive经典面试题1--根据主播上播、下播时间戳求播出时长
- python主动推送链接至Bing站长平台分分钟让必应收录你的网页-必应SEO窍门
- IT狂人第一至四季/全集The IT Crowd迅雷下载
- 三个问答告诉你aside标签的作用
- Android客户端与PC服务器通过socket进行交互实例
- 电脑破解wifi密码(至少连过1次的才可以)
- 十年一剑,股票自动交易实验(寻找股海宝藏之旅—解锁股市交易更多姿势)
- 部门 2016 总结
- ipad使用的PDF书籍没有目录怎么办?
热门文章
- select poll epoll
- python 3.x 不再支持MySQLdb 模块
- (66)SPI外设驱动发送驱动(五)(第14天)
- (28)FPGA面试题寄生效应
- (48)FPGA面试技能提升篇(数字采样、射频存储、频谱搬移)
- stm32f7网口_STM32F7串口通信问题
- unix系统重启tcp服务器,《TCP/IP详解卷3:TCP事务协议、HTTP、NNTP和UNIX域协议》 —3.5 服务器重启动...
- 软件项目验收汇报ppt_项目验收!万能PPT模板!等你来拿
- 上网课的心得体会1000字_网络学习心得体会 (1000字)
- 兴利调节matlab编程,水利计算之兴利调节计算.ppt