转载自:http://www.cnblogs.com/lukelook/p/8660798.html

一.POI结构与常用类

1.POI介绍

Apache POI是Apache软件基金会的开源项目,POI提供API给Java程序对Microsoft Office格式档案读和写的功能。 .NET的开发人员则可以利用NPOI (POI for .NET) 来存取 Microsoft Office文档的功能

2.POI结构说明

包名称说明

HSSF提供读写Microsoft Excel XLS格式档案的功能。

XSSF提供读写Microsoft Excel OOXML XLSX格式档案的功能。

HWPF提供读写Microsoft Word DOC格式档案的功能。

HSLF提供读写Microsoft PowerPoint格式档案的功能。

HDGF提供读Microsoft Visio格式档案的功能。

HPBF提供读Microsoft Publisher格式档案的功能。

HSMF提供读Microsoft Outlook格式档案的功能。

3.POI常用类说明

类名                说明

HSSFWorkbook        Excel的文档对象

HSSFSheetExcel的表单

HSSFRowExcel的行

HSSFCellExcel的格子单元

HSSFFont            Excel字体

HSSFDataFormat      格子单元的日期格式

HSSFHeader          Excel文档Sheet的页眉

HSSFFooter          Excel文档Sheet的页脚

HSSFCellStyle       格子单元样式

HSSFDateUtil        日期

HSSFPrintSetup      打印

HSSFErrorConstants  错误信息

二.简单的实例代码

package com.my.utils;

import java.io.FileOutputStream;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;

import org.apache.poi.hssf.util.HSSFColor;

import org.apache.poi.ss.usermodel.Cell;

import org.apache.poi.ss.usermodel.CellStyle;

import org.apache.poi.ss.usermodel.Row;

import org.apache.poi.ss.usermodel.Sheet;

import org.apache.poi.ss.usermodel.Workbook;

public class UsePoiCreateExcle {

public static void main(String[] args) {

// TODO Auto-generated method stub

String path = "D:\\java\\test\\test.xls";

// create workbook

Workbook workbook = new HSSFWorkbook();

// create sheet

Sheet sheet1 = workbook.createSheet("teacher");

Sheet sheet2 = workbook.createSheet("student");

// 设置为当前页面

workbook.setActiveSheet(0);

// 创建行

Row row = sheet1.createRow(0);

// 创建表格

Cell cell1 = row.createCell(0);

Cell cell2 = row.createCell(1);

Cell cell3 = row.createCell(2);

CellStyle style = workbook.createCellStyle();

// 对齐方式

style.setAlignment(CellStyle.ALIGN_CENTER);

// 先设置样式再设置颜色

style.setBorderBottom(CellStyle.BORDER_THICK);

style.setBottomBorderColor(HSSFColor.RED.index);

//先设置填充样式再设置颜色

style.setFillPattern(CellStyle.ALT_BARS);

style.setFillForegroundColor(HSSFColor.GREEN.index);

cell1.setCellValue("序号");

cell1.setCellStyle(style);

cell2.setCellValue("姓名");

cell3.setCellValue("年龄");

System.out.println("=============");

try {

FileOutputStream out = new FileOutputStream(path);

workbook.write(out);

out.close();

} catch (Exception e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

}

三.具体样式详解

1.创建文档摘要信息

workbook.createInformationProperties();//创建文档信息

DocumentSummaryInformation dsi= workbook.getDocumentSummaryInformation();//摘要信息

dsi.setCategory("类别:Excel文件");//类别

dsi.setManager("管理者:李志伟");//管理者

dsi.setCompany("公司:--");//公司

SummaryInformation si = workbook.getSummaryInformation();//摘要信息

si.setSubject("主题:--");//主题

si.setTitle("标题:测试文档");//标题

si.setAuthor("作者:李志伟");//作者

si.setComments("备注:POI测试文档");//备注

2.创建批注

HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)

HSSFPatriarch patr = sheet.createDrawingPatriarch();

HSSFClientAnchor anchor = patr.createAnchor(0, 0, 0, 0, 5, 1, 8, 3);//创建批注位置

HSSFComment comment = patr.createCellComment(anchor);//创建批注

comment.setString(new HSSFRichTextString("这是一个批注段落!"));//设置批注内容

comment.setAuthor("李志伟");//设置批注作者

comment.setVisible(true);//设置批注默认显示

HSSFCell cell = sheet.createRow(2).createCell(1);

cell.setCellValue("测试");

cell.setCellComment(comment);//把批注赋值给单元格

创建批注位置HSSFPatriarch.createAnchor(dx1, dy1, dx2, dy2, col1, row1, col2, row2)方法参数说明:

dx1 第1个单元格中x轴的偏移量

dy1 第1个单元格中y轴的偏移量

dx2 第2个单元格中x轴的偏移量

dy2 第2个单元格中y轴的偏移量

col1 第1个单元格的列号

row1 第1个单元格的行号

col2 第2个单元格的列号

row2 第2个单元格的行号

3.创建页眉和页脚

HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)

HSSFHeader header =sheet.getHeader();//得到页眉

header.setLeft("页眉左边");

header.setRight("页眉右边");

header.setCenter("页眉中间");

HSSFFooter footer =sheet.getFooter();//得到页脚

footer.setLeft("页脚左边");

footer.setRight("页脚右边");

footer.setCenter("页脚中间");

也可以使用Office自带的标签定义,你可以通过HSSFHeader或HSSFFooter访问到它们,都是静态属性,列表如下:

HSSFHeader.tab &A 表名

HSSFHeader.file &F 文件名

HSSFHeader.startBold &B 粗体开始

HSSFHeader.endBold &B 粗体结束

HSSFHeader.startUnderline &U 下划线开始

HSSFHeader.endUnderline &U 下划线结束

HSSFHeader.startDoubleUnderline &E 双下划线开始

HSSFHeader.endDoubleUnderline &E 双下划线结束

HSSFHeader.time &T 时间

HSSFHeader.date &D 日期

HSSFHeader.numPages &N 总页面数

HSSFHeader.page &P 当前页号

4.设置数据格式

HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)

HSSFRow row=sheet.createRow(0);

//设置日期格式--使用Excel内嵌的格式

HSSFCell cell=row.createCell(0);

cell.setCellValue(new Date());

HSSFCellStyle style=workbook.createCellStyle();

style.setDataFormat(HSSFDataFormat.getBuiltinFormat("m/d/yy h:mm"));

cell.setCellStyle(style);

//设置保留2位小数--使用Excel内嵌的格式

cell=row.createCell(1);

cell.setCellValue(12.3456789);

style=workbook.createCellStyle();

style.setDataFormat(HSSFDataFormat.getBuiltinFormat("0.00"));

cell.setCellStyle(style);

//设置货币格式--使用自定义的格式

cell=row.createCell(2);

cell.setCellValue(12345.6789);

style=workbook.createCellStyle();

style.setDataFormat(workbook.createDataFormat().getFormat("¥#,##0"));

cell.setCellStyle(style);

//设置百分比格式--使用自定义的格式

cell=row.createCell(3);

cell.setCellValue(0.123456789);

style=workbook.createCellStyle();

style.setDataFormat(workbook.createDataFormat().getFormat("0.00%"));

cell.setCellStyle(style);

//设置中文大写格式--使用自定义的格式

cell=row.createCell(4);

cell.setCellValue(12345);

style=workbook.createCellStyle();

style.setDataFormat(workbook.createDataFormat().getFormat("[DbNum2][$-804]0"));

cell.setCellStyle(style);

//设置科学计数法格式--使用自定义的格式

cell=row.createCell(5);

cell.setCellValue(12345);

style=workbook.createCellStyle();

style.setDataFormat(workbook.createDataFormat().getFormat("0.00E+00"));

cell.setCellStyle(style);

HSSFDataFormat.getFormat和HSSFDataFormat.getBuiltinFormat的区别:当使用Excel内嵌的(或者说预定义)的格式时,直接用HSSFDataFormat.getBuiltinFormat静态方法即可。当使用自己定义的格式时,必须先调用HSSFWorkbook.createDataFormat(),因为这时在底层会先找有没有匹配的内嵌FormatRecord,如果没有就会新建一个FormatRecord,所以必须先调用这个方法,然后你就可以用获得的HSSFDataFormat实例的getFormat方法了,当然相对而言这种方式比较麻烦,所以内嵌格式还是用HSSFDataFormat.getBuiltinFormat静态方法更加直接一些。

5.合并单元格

HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)

HSSFRow row=sheet.createRow(0);

//合并列

HSSFCell cell=row.createCell(0);

cell.setCellValue("合并列");

CellRangeAddress region=new CellRangeAddress(0, 0, 0, 5);

sheet.addMergedRegion(region);

//合并行

cell=row.createCell(6);

cell.setCellValue("合并行");

region=new CellRangeAddress(0, 5, 6, 6);

sheet.addMergedRegion(region);

CellRangeAddress对象其实就是表示一个区域,其构造方法如下:CellRangeAddress(firstRow, lastRow, firstCol, lastCol),参数的说明:

firstRow 区域中第一个单元格的行号

lastRow 区域中最后一个单元格的行号

firstCol 区域中第一个单元格的列号

lastCol 区域中最后一个单元格的列号

6.单元格对齐

HSSFCell cell=row.createCell(0);

cell.setCellValue("单元格对齐");

HSSFCellStyle style=workbook.createCellStyle();

style.setAlignment(HSSFCellStyle.ALIGN_CENTER);//水平居中

style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);//垂直居中

style.setWrapText(true);//自动换行

style.setIndention((short)5);//缩进

style.setRotation((short)60);//文本旋转,这里的取值是从-90到90,而不是0-180度。

cell.setCellStyle(style);

水平对齐相关参数

如果是左侧对齐就是 HSSFCellStyle.ALIGN_FILL;

如果是居中对齐就是 HSSFCellStyle.ALIGN_CENTER;

如果是右侧对齐就是 HSSFCellStyle.ALIGN_RIGHT;

如果是跨列举中就是 HSSFCellStyle.ALIGN_CENTER_SELECTION;

如果是两端对齐就是 HSSFCellStyle.ALIGN_JUSTIFY;

如果是填充就是 HSSFCellStyle.ALIGN_FILL;

垂直对齐相关参数

如果是靠上就是 HSSFCellStyle.VERTICAL_TOP;

如果是居中就是 HSSFCellStyle.VERTICAL_CENTER;

如果是靠下就是 HSSFCellStyle.VERTICAL_BOTTOM;

如果是两端对齐就是 HSSFCellStyle.VERTICAL_JUSTIFY;

7.使用边框

边框和其他单元格设置一样也是调用CellStyle接口,CellStyle有2种和边框相关的属性,分别是:

边框相关属性

说明

范例

Border+方向

边框类型

BorderLeft, BorderRight等

方向+BorderColor

边框颜色

TopBorderColor,BottomBorderColor等

HSSFCell cell=row.createCell(1);

cell.setCellValue("设置边框");

HSSFCellStyle style=workbook.createCellStyle();

style.setBorderTop(HSSFCellStyle.BORDER_DOTTED);//上边框

style.setBorderBottom(HSSFCellStyle.BORDER_THICK);//下边框

style.setBorderLeft(HSSFCellStyle.BORDER_DOUBLE);//左边框

style.setBorderRight(HSSFCellStyle.BORDER_SLANTED_DASH_DOT);//右边框

style.setTopBorderColor(HSSFColor.RED.index);//上边框颜色

style.setBottomBorderColor(HSSFColor.BLUE.index);//下边框颜色

style.setLeftBorderColor(HSSFColor.GREEN.index);//左边框颜色

style.setRightBorderColor(HSSFColor.PINK.index);//右边框颜色

cell.setCellStyle(style);

其中边框类型分为以下几种:

边框范例图

对应的静态值

HSSFCellStyle.BORDER_DOTTED

HSSFCellStyle.BORDER_HAIR

HSSFCellStyle.BORDER_DASH_DOT_DOT

HSSFCellStyle.BORDER_DASH_DOT

HSSFCellStyle.BORDER_DASHED

HSSFCellStyle.BORDER_THIN

HSSFCellStyle.BORDER_MEDIUM_DASH_DOT_DOT

HSSFCellStyle.BORDER_SLANTED_DASH_DOT

HSSFCellStyle.BORDER_MEDIUM_DASH_DOT

HSSFCellStyle.BORDER_MEDIUM_DASHED

HSSFCellStyle.BORDER_MEDIUM

HSSFCellStyle.BORDER_THICK

HSSFCellStyle.BORDER_DOUBLE

8.设置字体

HSSFCell cell = row.createCell(1);

cell.setCellValue("设置字体");

HSSFCellStyle style = workbook.createCellStyle();

HSSFFont font = workbook.createFont();

font.setFontName("华文行楷");//设置字体名称

font.setFontHeightInPoints((short)28);//设置字号

font.setColor(HSSFColor.RED.index);//设置字体颜色

font.setUnderline(FontFormatting.U_SINGLE);//设置下划线

font.setTypeOffset(FontFormatting.SS_SUPER);//设置上标下标

font.setStrikeout(true);//设置删除线

style.setFont(font);

cell.setCellStyle(style);

下划线选项值:

单下划线 FontFormatting.U_SINGLE

双下划线 FontFormatting.U_DOUBLE

会计用单下划线 FontFormatting.U_SINGLE_ACCOUNTING

会计用双下划线 FontFormatting.U_DOUBLE_ACCOUNTING

无下划线 FontFormatting.U_NONE

上标下标选项值:

上标 FontFormatting.SS_SUPER

下标 FontFormatting.SS_SUB

普通,默认值 FontFormatting.SS_NONE

9.背景和纹理

SSFCellStyle style = workbook.createCellStyle();

style.setFillForegroundColor(HSSFColor.GREEN.index);//设置图案颜色

style.setFillBackgroundColor(HSSFColor.RED.index);//设置图案背景色

style.setFillPattern(HSSFCellStyle.SQUARES);//设置图案样式

cell.setCellStyle(style);

10.设置宽度和高度

HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)

HSSFRow row = sheet.createRow(1);

HSSFCell cell = row.createCell(1);

cell.setCellValue("123456789012345678901234567890");

sheet.setColumnWidth(1, 31 * 256);//设置第一列的宽度是31个字符宽度

row.setHeightInPoints(50);//设置行的高度是50个点

这里你会发现一个有趣的现象,setColumnWidth的第二个参数要乘以256,这是怎么回事呢?其实,这个参数的单位是1/256个字符宽度,也就是说,这里是把B列的宽度设置为了31个字符。

设置行高使用HSSFRow对象的setHeight和setHeightInPoints方法,这两个方法的区别在于setHeightInPoints的单位是点,而setHeight的单位是1/20个点,所以setHeight的值永远是setHeightInPoints的20倍。

你也可以使用HSSFSheet.setDefaultColumnWidth、HSSFSheet.setDefaultRowHeight和HSSFSheet.setDefaultRowHeightInPoints方法设置默认的列宽或行高。

11.判断单元格是否为日期

//判断单元格是否为日期类型,使用DateUtil.isCellDateFormatted(cell)方法,例如:

HSSFCell cell = row.createCell(1);

cell.setCellValue(new Date());//设置日期数据

System.out.println(DateUtil.isCellDateFormatted(cell));//输出:false

HSSFCellStyle style =workbook.createCellStyle();

style.setDataFormat(HSSFDataFormat.getBuiltinFormat("m/d/yy h:mm"));

cell.setCellStyle(style);//设置日期样式

System.out.println(DateUtil.isCellDateFormatted(cell));//输出:true

12.设置默认工作表

HSSFWorkbook workbook = new HSSFWorkbook();// 创建Excel文件(Workbook)

workbook.createSheet("Test0");// 创建工作表(Sheet)

workbook.createSheet("Test1");// 创建工作表(Sheet)

workbook.createSheet("Test2");// 创建工作表(Sheet)

workbook.createSheet("Test3");// 创建工作表(Sheet)

workbook.setActiveSheet(2);//设置默认工作表

13.重命名

HSSFWorkbook workbook = new HSSFWorkbook();// 创建Excel文件(Workbook)

workbook.createSheet("Test0");// 创建工作表(Sheet)

workbook.createSheet("Test1");// 创建工作表(Sheet)

workbook.createSheet("Test2");// 创建工作表(Sheet)

workbook.createSheet("Test3");// 创建工作表(Sheet)

workbook.setSheetName(2, "1234");//重命名工作表

14.调整表单显示比例

HSSFWorkbook workbook = new HSSFWorkbook();// 创建Excel文件(Workbook)

HSSFSheet sheet1= workbook.createSheet("Test0");// 创建工作表(Sheet)

HSSFSheet sheet2=workbook.createSheet("Test1");// 创建工作表(Sheet)

HSSFSheet sheet3=workbook.createSheet("Test2");// 创建工作表(Sheet)

sheet1.setZoom(1,2);//50%显示比例

sheet2.setZoom(2,1);//200%显示比例

sheet3.setZoom(1,10);//10%显示比例

15.显示/隐藏网格线

HSSFWorkbook workbook = new HSSFWorkbook();// 创建Excel文件(Workbook)

HSSFSheet sheet1= workbook.createSheet("Test0");// 创建工作表(Sheet)

HSSFSheet sheet2=workbook.createSheet("Test1");// 创建工作表(Sheet)

sheet1.setDisplayGridlines(false);//隐藏Excel网格线,默认值为true

sheet2.setGridsPrinted(true);//打印时显示网格线,默认值为false

16.遍历Sheet

String filePath = "d:\\users\\lizw\\桌面\\POI\\sample.xls";

FileInputStream stream = new FileInputStream(filePath);

HSSFWorkbook workbook = new HSSFWorkbook(stream);//读取现有的Excel

HSSFSheet sheet= workbook.getSheet("Test0");//得到指定名称的Sheet

for (Row row : sheet)

{

for (Cell cell : row)

{

System.out.print(cell + "\t");

}

System.out.println();

}

其他详见:http://www.cnblogs.com/LiZhiW/p/4313789.html

apache poi使用例_4.Apache POI使用详解相关推荐

  1. java ant解压缩_java ant包中的org.apache.tools.zip实现压缩和解压缩实例详解

    java ant包中的org.apache.tools.zip实现压缩和解压缩实例详解 发布于 2020-4-7| 复制链接 摘记: java ant包中的org.apache.tools.zip实现 ...

  2. Pytest全局用例共用之conftest.py详解

    一.'conftest特点: 1.可以跨.py文件调用,有多个.py文件调用时,可让conftest.py只调用了一次fixture,或调用多次fixture 2.conftest.py与运行的用例要 ...

  3. java connection 单例_Java设计模式之单例模式详解

    Java设计模式之单例模式详解 什么是设计模式 设计模式是在大量的实践中总结和理论之后优选的代码结构,编程风格,以及解决问题的思考方式.使用设计模式是为了可重用代码.让代码更容易被他人理解.保证代码可 ...

  4. Apache Flink 管理大型状态之增量 Checkpoint 详解

    邱从贤(山智),Apache Flink Contributor,中南大学硕士,2018 年加入阿里巴巴计算平台事业部,专注于 Flink 核心引擎开发,主要从事 Flink  State&C ...

  5. IDEA里运行代码时出现Caused by: java.lang.ClassNotFoundException: org.apache.log4j.Logger的解决办法(图文详解)...

    问题详情 运行出现log4j的问题 "C:\Program Files\Java\jdk1.8.0_66\bin\java" -Didea.launcher.port=7533 & ...

  6. Apache以及PHP的默认编码问题解决(详解)

    如果你在网上搜索 "apache配置",搜到的页面大多都会建议你在httpd.conf中加上这么一句:AddDefaultCharset GB2312.对于新手而且是只用GB231 ...

  7. Apache官网下载ant软件包及安装详解

    1.进入ant官网:https://ant.apache.org.点击下图的1.2两个步骤 2.可以看到下图有ant最新版本的软件包下载,其中有个here按钮,这是进入历史版本的入口. 3.如果下载最 ...

  8. Apache rewrite URL静态化配置与参数详解

    RewriteEngine On|Off RewriteEngine 可用On 或者 Off 打开或关闭rewrite功能. rewrite configurations 不会继承,所以你得给每个你想 ...

  9. FreeBSD8.1最新apache+PHP+mysql+samba+svn的安装步骤详解

    1.更新ports安装包     使用portsnap来更新步骤(可以修改/etc/portsnap.conf的配置文件SERVERNAME=portsnap.cn.FreeBSD.org,以提高你的 ...

最新文章

  1. 【c语言】求n个整数的和
  2. vue开发使用vue-particles如何兼容IE11?
  3. 在ORACLE中对存储过程加密
  4. c# winform实现输出数据到Console控制台窗台
  5. [asp.net] 利用WebClient上传图片到远程服务
  6. 你的代码(软件)安全吗?【信息图】
  7. 一个数的约数(个数。约数和)
  8. 高性能的分布式内存对象缓存系统Memcached
  9. 【直线检测】【matlab】基于Hough变换的直线检测
  10. 《概率论与数理统计》之常见概率分布
  11. python基础:基础语法
  12. Oracle导出表结构(含表名、字段名、数据类型、是否为空、字段说明)至Excel(简单详细)sql语句的形式
  13. 支付宝API使用流程
  14. 【AD小知识】PCB布线理论及实际操作
  15. CCNA理论学习笔记整理(一)
  16. linux注册域名命令,Linux基础命令---显示域名ypdomainname
  17. mysql优化数据库对象
  18. 民航飞机因何频繁遭遇乱流?
  19. 科技英语计算机单元答案,科技英语课后练习答案.doc
  20. springboot+vue餐厅点餐系统在线点餐系统(含源码+数据库)

热门文章

  1. 湖南师大工学院计算机,张连明-湖南师范大学信息科学与工程学院
  2. java对角线遍历_Leetcode 498:对角线遍历Diagonal Traverse(python3、java)
  3. sql oraoledb.oracle,无法创建链接服务器XXXXX的 OLE DB 访问接口OraOLEDB.Oracle的实例。 (Microsoft SQL Server,错误7302)...
  4. 本机tomcat的server.xml被还原的问题及解决办法
  5. Linux命令工具 top详解
  6. 网站暴库原理与方法剖析
  7. 算法竞赛入门经典训练指南
  8. 杭电 1272 并查集判断环
  9. Ext Scheduler(日程表) 2.0——升级到4.0
  10. Jupyter中显示数据data时只显示省略号不显示完整数据