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

原创 2015年05月29日 17:06:03

有的时候,我们需要通过操作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://blog.csdn.net/chancein007/article/details/46238217

JFinal专题之POI-Excel导入解决方案

-
  • 1970年01月01日 08:00

POI实战-java开发excel详解(第四章 常用操作-注释)

4.常用操作 4.1注释 4.1.1 单表注释 POI支持Excel单元格加注释功能。创建注释需要通过sheet表去创建类org.apache.poi.hssf.usermodel.HSSFPa...
  • yuzhenling
  • yuzhenling
  • 2015-08-31 13:50:10
  • 3259

java (apache POI 组件) 操作 excel 插入批注

在java的开源世界中,有两套比较有影响的API可供使用,一个是POI,一个是jExcelAPI(即jxl)。jxl功能相对POI比较弱一点。本来使用的是jxl那一套读取和生成报表的工具,发现该框架不...
  • u012959498
  • u012959498
  • 2017-11-01 13:46:23
  • 727

Java使用Apache poi 操作Excel-基本概念与使用

通过POI简化了EXCEL的操作,其中POI提供的WorkBook, spreadsheet,Row,Cell及其实现类来完成对Excel中对应部分(Excel文件,电子表格,行,单元格)的操作(读取...
  • Revivedsun
  • Revivedsun
  • 2017-01-02 21:50:07
  • 1838

POI之自定义注解生成文档-yellowcong

在数据模型对象下,添加一个注解类,说明抽出的字段在excel中所对应的表头,然后通过工具类,通过反射,获取每个字段所对应的标题,同时设定每个字段对应的数据...
  • yelllowcong
  • yelllowcong
  • 2017-07-16 00:21:04
  • 701

POI读取Excel文件的带注释小例子

欢迎点击此处订阅本Blog
  • softwave
  • softwave
  • 2008-09-29 18:56:00
  • 2541

Apache POI 第一讲之创建新工作簿及简单操作

有时候我们在做项目时,有些项目需要生成Microsoft Excel文件格式的报告。有时,甚至希望将Excel文件作为输入数据。这是我们需要用到Apache POI 。例如,一个公司开发的应用程序将财...
  • wenteryan
  • wenteryan
  • 2016-07-03 12:27:26
  • 1170

利用poi简单的创建一个excel

需要引入   poi-3.9-20121203.jar 代码 import java.io.FileOutputStream; import org.apache.poi.hssf.usermodel...
  • xcc_2269861428
  • xcc_2269861428
  • 2017-04-07 22:42:03
  • 800

Apache POI导出Excel

package com.bjpowernode.crm.workbench.activity.web.controller; import java.io.IOException; import j...
  • Aurora_sss
  • Aurora_sss
  • 2017-05-25 20:32:24
  • 171

excel导入导出使用poi自定义注解

最近在做一个数据导入导出的模块 在网上找了一些例子 在这里整理一下 这里就不再贴原作者的地址 (以下代码来自网上非原创 稍作简单修改) 首先引入pom.xml依赖 ...
  • zhugeyangyang1994
  • zhugeyangyang1994
  • 2016-08-03 15:27:10
  • 5057
收藏助手
不良信息举报
您举报文章:(3) 如何用Apache POI操作Excel文件-----如何对一个单元格加注解?
举报原因:
原因补充:

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