Apache POI是Apache软件基金会的开放源码函式库,POIAPI给Java程序对Microsoft Office格式档案读和写的功能。

官方文档

[https://poi.apache.org/]

相关类

类名 对应文件类型
HSSF 读写Microsoft Excel XLS
XSSF 读写Microsoft Excel OOXML XLSX
HWPF 读写Microsoft Word DOC97
XWPF 读写Microsoft Word DOC2003
XSLF 读写Microsoft PowerPoint
XDGF 读Microsoft Visio
XPBF 读Microsoft Publisher
XSMF 读Microsoft Outlook

XLSX相关类及方法

常用类

类名 对应关系
XSSFWorkbook 工作薄(可以理解为.xlsx的文件)
XSSFSheet Excel表(就是创建Excel文件时默认创建的Sheet1那种表格)
XSSFRow 表格中的一行数据
XSSFCell 表格一行中的一个单元格
XSSFCellStyle 单元格样式
XSSFFont 字体
XSSFHeader Sheet的页眉
XSSFFooter Sheet的页脚
DocumentSummaryInformation 文件摘要信息
CellRangeAddress 单元格范围地址,通常合并单元格时使用

常用方法

构造方法

方法名 说明
XSSFWorkbook()
XSSFWorkbook(InputStream is) (is为要读的文件的输入流)
XSSFWorkbook(File file) 按文件对象读取
XSSFWorkbook(String path) 按文件路径读取

XSSFWorkbook常用方法

方法名 返回类型 说明
getNumberOfSheets() int 获取工作薄中表的个数
getSheet(String name) XSSFSheet 按表名获取表
getSheetAt(int index) XSSFSheet 按表序号获取表
getSheetIndex(String name) int 获取指定表名的表序号
getSheetIndex(Sheet sheet) int 按表获取它的序号
removeSheetAt(int index) void 删除指定序号的表
write(OutputStream var1) void 将内存中的Excel写入到文件
createCellStyle() XSSFCellStyle 创建一个单元格格式

XSSFSheet常用方法

方法名 返回类型 说明
createRow(int rownum) HSSFRow 在指定行创建一个新行
getRow(int index) HSSFRow 获取一行数据
getFirstRowNum() int 获取从上到下第一行有数据的行所在行号
getLastRowNum() int 获取从下到上第一行有数据的行所在行号
addMergedRegion(CellRangeAddress region) int 合并单元格
autoSizeColumn(int column) void 自动调整指定列的宽度
setColumnWidth(int columnIndex, int width) void 设置某一列的宽度,width=字符个数 * 256,例如20个字符的宽度就是20 * 256

XSSFRow常用方法

方法名 返回类型 说明
createCell(int column) XSSFCell 创建一个单元格
createCell(int columnIndex, CellType type) XSSFCell 创建指定单元格格式的单元格
getCell(int cellnum) XSSFCell 获取指定行中指定索引的单元格
setHeight(short height) void 设置行高

XSSFCell常用方法

方法名 返回类型 说明
setCellValue(String value) void 设置单元格内容
setCellValue(double value) void 同上
setCellValue(Date value) void 同上
setCellValue(LocalDateTime value) void 同上
setCellValue(Calendar value) void 同上
toString() String 将单元格中的内容转换为String返回
setCellFormula(String formula) void 设置单元格计算公式
setCellStyle(CellStyle style) void 设置单元格格式

XSSFFont常用方法

方法名 返回类型 说明
setColor(short color) void 设置字体颜色
setBold(boolean bold) void 设置是否粗体
setItalic(boolean italic) void 设置倾斜
setUnderline(byte underline) void 设置下划线

XSSFCellStyle常用方法

方法名 返回类型 说明
setFont(Font font) void 为单元格设置字体样式
setAlignment(HorizontalAlignment align) void 设置水平对齐方式
setVerticalAlignment(VerticalAlignment align) void 设置垂直对齐方式
setFillForegroundColor(short bg) void 设置前景色
setFillBackgroundColor(short bg) void 设置背景颜色

示例

导包

将下载下来的包中所有的docs文件夹同目录下的所有jar包、lib文件夹、ooxml-lib文件夹导入到工程中

读入

样例表

用户编号 用户名 密码 姓名 性别 年龄
1 zs 123 张三 18
2 ls ls 李四 18
3 rsb rsb rsb 16
5 rbj rbj rbj 15
7 ssq ssq ssq 14
8 iow iow iow 7
9 auf auf auf 9
10 atv atv atv 12
11 soc soc soc 5
12 wqo wqo wqo 12
import org.apache.poi.xssf.usermodel.*;

import java.io.IOException;
import java.io.InputStream; public class Main {
public static void main(String[] args) throws IOException {
InputStream is = Thread.currentThread().getContextClassLoader().getResourceAsStream("test.xlsx");
XSSFWorkbook workbook = new XSSFWorkbook(is); //获取索引为0的sheet表格
XSSFSheet sheet = workbook.getSheetAt(0);
//获取表格中有内容的首行行号
int first = sheet.getFirstRowNum();
//获取表格中有内容的尾行行号
int last = sheet.getLastRowNum(); //从首行开始获取,首行为表头
XSSFRow row = sheet.getRow(0);
XSSFCell cell = row.getCell(0);
System.out.print(cell.toString() + "\t");
cell = row.getCell(1);
System.out.print(cell.toString() + "\t");
cell = row.getCell(2);
System.out.print(cell.toString() + "\t");
cell = row.getCell(3);
System.out.print(cell.toString() + "\t");
cell = row.getCell(4);
System.out.print(cell.toString() + "\t");
cell = row.getCell(5);
System.out.println(cell.toString() + "\t");
for (int i = first + 1|i <= last|++i) {
row = sheet.getRow(i);
cell = row.getCell(0);
int uid = Integer.valueOf(cell.toString().replace(".0", ""));
cell = row.getCell(1);
String uname = cell.toString();
cell = row.getCell(2);
String upass = cell.toString();
cell = row.getCell(3);
String truename = cell.toString();
cell = row.getCell(4);
String sex = cell.toString();
cell = row.getCell(5);
int age = Integer.valueOf(cell.toString().replace(".0", ""));
System.out.println(new User(uid, uname, upass, truename, sex, age));
}
}
}
用户编号	用户名	密码	姓名	性别	年龄
1 zs 123.0 张三 男 18
2 ls ls 李四 男 18
3 rsb rsb rsb 男 16
5 rbj rbj rbj 男 15
7 ssq ssq ssq 女 14
8 iow iow iow 男 7
9 auf auf auf 男 9
10 atv atv atv 男 12
11 soc soc soc 女 5
12 wqo wqo wqo 男 12

写出

import org.apache.poi.ss.usermodel.HorizontalAlignment;
import org.apache.poi.ss.usermodel.VerticalAlignment;
import org.apache.poi.ss.util.CellRangeAddress;
import org.apache.poi.xssf.usermodel.*; import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.Random; public class Write {
public static void main(String[] args) throws IOException {
//新建一个工作薄
XSSFWorkbook workbook = new XSSFWorkbook();
//在工作薄中新建一个名为写入的sheet表
XSSFSheet sheet = workbook.createSheet("写入");
//创建一行作为表头
XSSFRow row = sheet.createRow(0);
//向表头写入内容
XSSFCell cell = row.createCell(0);
cell.setCellValue("用户编号");
cell = row.createCell(1);
cell.setCellValue("用户名");
cell = row.createCell(2);
cell.setCellValue("密码");
cell = row.createCell(3);
cell.setCellValue("姓名");
cell = row.createCell(4);
cell.setCellValue("性别");
cell = row.createCell(5);
cell.setCellValue("年龄"); //写入其他内容同理 //测试合并单元格
row = sheet.createRow(1);
cell = row.createCell(0);
cell.setCellValue(1);
cell = row.createCell(1);
cell.setCellValue(2);
cell = row.createCell(2);
cell.setCellValue(3); sheet.addMergedRegion(new CellRangeAddress(1,1,0,3));
cell = row.getCell(0);
//让工作薄创建一个单元格格式
XSSFCellStyle style = workbook.createCellStyle();
//设置水平对齐方式
style.setAlignment(HorizontalAlignment.CENTER);
//设置垂直对齐方式
style.setVerticalAlignment(VerticalAlignment.CENTER);
cell.setCellStyle(style); workbook.write(new FileOutputStream("write.xlsx"));
}
}

最新文章

  1. Windows内核遍历驱动模块源码分析
  2. 使用Flexible实现手淘H5页面的终端适配
  3. Oracle 正则表达式函数-REGEXP_SUBSTR 使用例子
  4. 准备NOIP2017 编辑距离问题 模板
  5. DB2和Oracle区别
  6. oracle从游标批量提取数据
  7. Linux进程关闭和后台运行解析
  8. HDU 1533 最小费用最大流(模板)
  9. 【转】Kylin实践之使用Hive视图
  10. 第二篇T语言实例开发(版本5.3),福彩3D摇号器
  11. 自定义能够for each的类,C#,Java,C++,C++/cli的实现方法
  12. 使用Web Deploy进行远程部署
  13. Office2010安装错误
  14. IIS7 ASP.NET 未被授权访问所请求的资源
  15. linux中内核的一个不错的参数somaxconn
  16. 快速搭建Android 开发环境-使用ADT Bundle
  17. hacker入门篇——相关书籍
  18. day5_python学习笔记_chapter7_字典
  19. jquery实现ajax提交form表单的方法总结
  20. OpenCV探索之路(十一):轮廓查找和多边形包围轮廓

热门文章

  1. 【折半枚举+二分】POJ 3977 Subset
  2. phpexcel导出数据 出现Formula Error的解决方案
  3. PHP SPL标准库-接口
  4. windows搭建SVN服务MD版
  5. FrameworkElementFactory中的SetBinding与SetValue
  6. Java 等待/通知机制
  7. 使用Navicat远程连接阿里云ECS服务器上的MySQL数据库
  8. 看完本文若不能让你学通“Python”,我将永远退出IT界
  9. frida框架hook常用字符串模板总结
  10. 理解DES算法