POI介绍
Apache POI是用Java编写的免费开源的跨平台的Java API,
Apache POI提供API给Java程序对Microsoft Office格式档案读和写的功能,
其中使用最多的就是使用POI操作Excel文件。
maven坐标:
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>3.14</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>3.14</version>
</dependency>
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格式档案的功能
入门案例
从Excel文件读取数据
public class POITest {
//使用POI读取Excel中的数据
@Test
public void test1() throws Exception {
//加载指定文件,创建一个Excel(工作簿)
XSSFWorkbook excel = new XSSFWorkbook(new FileInputStream(new File("C:\poitest.xlsx")));
//读取Excel文件中第一个sheet标签项
XSSFSheet sheet = excel.getSheetAt(0);
//遍历sheet标签项,获取每一行数据
for (Row row : sheet) {
//遍历行,获取每个单元对象
for (Cell cell : row) {
System.out.println(cell.getStringCellValue());
}
}
//关闭资源
excel.close();
}
@Test
public void test2() throws Exception {
//加载指定文件,创建一个Excel(工作簿)
XSSFWorkbook excel = new XSSFWorkbook(new FileInputStream(new File("C:\poitest.xlsx")));
//读取Excel文件中第一个sheet标签项
XSSFSheet sheet = excel.getSheetAt(0);
//获取当前工作表最后一行的行号,行号从0开始
int lastRowNum = sheet.getLastRowNum();
for(int i=0;i<=lastRowNum;i++){
//根据行号获取行对象
XSSFRow row = sheet.getRow(i);
//获取当前行的最后一个单元格索引
short lastCellNum = row.getLastCellNum();
for(short j=0;j<lastCellNum;j++){
//根据单元格索引获得单元格对象
XSSFCell cell = row.getCell(j);
System.out.println(cell.getStringCellValue());
}
}
//关闭资源
excel.close();
}
}
XSSFWorkbook:工作簿
XSSFSheet:工作表
Row:行
Cell:单元格
向Excel文件写入数据
public class POITest {
//使用POI向Excel文件写入数据,并且通过输出流将创建的Excel文件保存到本地磁盘
@Test
public void test3() throws Exception{
//在内存中创建一个Excel文件(工作簿)
XSSFWorkbook excel = new XSSFWorkbook();
//创建一个工作表对象
XSSFSheet sheet = excel.createSheet("POI写入数据");
//在工作表中创建行对象
XSSFRow title = sheet.createRow(0);
//在行中创建单元格对象
title.createCell(0).setCellValue("姓名");
title.createCell(1).setCellValue("地址");
title.createCell(2).setCellValue("年龄");
XSSFRow dataRow = sheet.createRow(1);
//在行中创建单元格对象
dataRow.createCell(0).setCellValue("小明");
dataRow.createCell(1).setCellValue("广州");
dataRow.createCell(2).setCellValue("20");
//创建一个输出流,通过输出流将内存中的Excel文件写入本地磁盘
FileOutputStream outputStream = new FileOutputStream("C:\hello1.xlsx");
excel.write(outputStream);
outputStream.flush();
excel.close();
}
}
原文地址:https://blog.csdn.net/weixin_52270382/article/details/132795210
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_11063.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。