Java POI

Poi介绍

Poi是由apache公司提供的Java编写的免费开源跨平台的Java API,提供让Java程序对Microsoft Office档案读和写的功能。也是目前针对Excel读写比较常用的实现方案。

使用前提,需要导入对应的依赖

<dependency> 
	<groupId>org.apache.poi</groupId> 
	<artifactId>poi</artifactId> 
	<version>3.9</version> 
</dependency> 
<dependency>
	<groupId>org.apache.poi</groupId> 
	<artifactId>poi-ooxml</artifactId> 
	<version>3.9</version>
</dependency>

Poi包结构:

HSSF —— 读写 Microsoft Excel xls(07版本之前的Excel)

XSSF —— 读写 Microsoft Excel OOXML XLSX(07版本之后的Excel)

HWPF —— 读写 Word

HSLF —— 读写 PowerPoint(PPT)

主要使用 XSSF

读取Excel

Poi如何读取操作表格?其实在Poi内部封装了一些对象

XSSFWorkbook:工作簿

XSSFSheet:工作表

Row:行

Cell:单元格在这里插入图片描述

具体操作

在这里插入图片描述
那么我们在测试类中新建poitest包,然后新建一个Product类型,这个类型就是模仿实体类的类型

import lombok.AllArgsConstructor; 
import lombok.Data; 
@Data 
@AllArgsConstructor 
public class Product { private Integer id; private String name; private Double price; private Integer count; }

然后我们再来新建一个测试类型,用户解析表格中的数据,将具体数据保存到Product类型中

/** * 利用Poi读取excel表格数据 */ 
public class readDemo { public static void main(String[] args) { 
	try { 
	List<Product> products = read("E:\idea-family/a.xlsx"); 
	System.out.println(products); 
	}catch (Exception e) { 
		e.printStackTrace(); 
	} 
}
 public static List<Product> read(String path) throws Exception {                            		   
	 List<Product> products = new ArrayList<>(); 
	 // 1. 创建输入流 
	 FileInputStream fip = new FileInputStream(path); 
	 // 2. 再输入流中获取工作簿 
	 XSSFWorkbook workbook = new XSSFWorkbook(fip); 
	 // 3. 在工作簿中获取目标工作表 
	 Sheet sheet = workbook.getSheetAt(0); 
	 // 4. 获取工作表中的行数(有数据的) 
	 int rowNum = sheet.getPhysicalNumberOfRows(); 
	 // 5. 遍历所有的行,但是要注意第一行标题不获取,所以从下标1开始获取
	 for(int i = 1;i<rowNum;i++){  	 
	 // 获取所有行 
	 Row row = sheet.getRow(i); 
	 if(row!=null){ 
	 //用于保存每条数据的集合
	 List<String> list = new ArrayList<>(); 
	 for (Cell cell : row) { 
	 if(cell!=null){ 
	 //把单元各种的所有数据格式设置为String 
	 cell.setCellType(Cell.CELL_TYPE_STRING); 
	 //获取所有单元格数据 
	 String value = cell.getStringCellValue(); 
	 if(value!=null&&!value.equals("")){ 
	 //将每个单元格的数据存储到集合中 
	 list.add(value); 
	 						} 
	 					} 
	 				} 
	 //把获取到的每一条数据封装成一个Product类型 
	 if(list.size()>0){ Product product = new Product(Integer.parseInt(list.get(0)),list.get(1),Double.parseDouble(list.get(2)),Integer.parseInt(list.get(3))); 
	 //将product封装到list集合中 
	 products.add(product); 
	 			} 
	 		} 
		}
	return products; 
	} 
}

最后我们进行测试,数据保存到了实体类集合中在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java POI是一个用于操作Microsoft Office文档的开源Java API框架。它支持读取、写入和编辑各种Office格式的文档,如Word文档、Excel电子表格和PowerPoint演示文稿。 使用Java POI可以方便地生成、修改和处理Office文档。它提供了一组丰富的API,可以创建各种样式的文档,包括设置字体、颜色、表格、图表等。同时,它也支持将数据从数据库中读取,然后将其填充到模板文件中,从而生成自定义的报表、邮件等。 Java POI的主要功能包括: 1. 读取和写入Excel文件:可以将Excel文件读取为Java对象,也可以将Java对象写入到Excel文件中。通过POI,我们可以操作Excel中的单元格、行、列以及样式等信息。 2. 处理Word文档:可以读取、创建和编辑Word文档,可以设置字体、段落样式、页眉页脚、表格等。 3. 操作PowerPoint演示文稿:可以创建和编辑PowerPoint演示文稿,可以设置幻灯片的布局、文本框、图表、图片等。 Java POI具有良好的兼容性和稳定性,可以与各种版本的Microsoft Office套件无缝集成。同时,它还支持多种文件格式,包括xls、xlsx、doc、docx、ppt、pptx等。 总之,Java POI是一个功能强大的工具,可以帮助开发者在Java中处理各种Office文档。无论是生成报表、处理数据还是编辑文档,都可以通过Java POI实现。它为我们提供了丰富的API,使得操作Office文件变得更加简单和高效。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值