SpringBoot中使用 POI

Excel的两种形式

  1. demo.xls
    为Excel2003的格式,其核心结构是复合文档类型的结构,存储数据量较小。在POI中使用HSSF对象操作。
  2. demo.xlsx
    为Excel2007的格式,其核心结构是 XML 类型的结构,采用的是基于 XML 的压缩方式,使其占用的空间更小,操作效率更高 。在POI中使用XSSF或SXSSF对象操作。

引入POI的jar包

java 复制代码
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
    <version>RELEASE</version>
</dependency>

<!--POI-->
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml</artifactId>
    <version>5.2.2</version>
</dependency>

前者用于引入HSSFWorkbook;后者用于引入XSSFWorkbook

创建Excel

java 复制代码
1.创建workbook工作簿
Workbook wb = new XSSFWorkbook();
2.创建表单Sheet
Sheet sheet = wb.createSheet("test");
3.文件流
FileOutputStream fos = new FileOutputStream("E:\\test.xlsx");
4.写入文件
wb.write(fos);
5.关闭
fos.close();

创建单元格

java 复制代码
 public static void main(String[] args) throws IOException {
//        1.创建workbook工作簿
     Workbook wb = new XSSFWorkbook();
//        2.创建表单Sheet
     Sheet sheet = wb.createSheet("test的sheet");
//        3.创建行对象,从0开始
     Row row = sheet.createRow(0);
//        4.创建单元格,从0开始
     Cell cell = row.createCell(0);
//        5.单元格写入数据
     cell.setCellValue("以往有人这样说过:"不要因为一件事的终止而感到悲伤,因为终点就是起点,它将为你开拓一个更广阔的世界。"......123");
//        6.XSSFCellStyle设置单元格样式
     CellStyle cellStyle = wb.createCellStyle();
     cellStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND);
     // 设置背景颜色
     cellStyle.setFillForegroundColor((short)3);
     cell.setCellStyle(cellStyle);

     Sheet sheet2 = wb.getSheet("test的sheet");
     Row row2 = sheet2.getRow(0);
     Cell cell2 = row2.getCell(0);
     String stringCellValue = cell2.getStringCellValue();
     System.out.println(stringCellValue);

//        7.文件流
     FileOutputStream fos = new FileOutputStream("E:\\test.xlsx");
//        8.写入文件
     wb.write(fos);
//        9.关闭
     wb.close();
     fos.close();

}

设置格式(样式) 创建单元格样式对象

java 复制代码
CellStyle cellStyle = wb.createCellStyle();

居中

java 复制代码
cellStyle.setAlignment(HorizontalAlignment.CENTER);

设置边框

java 复制代码
cellStyle.setBorderTop(BorderStyle.THIN);
cellStyle.setBorderRight(BorderStyle.THIN);
cellStyle.setBorderBottom(BorderStyle.THIN);
cellStyle.setBorderLeft(BorderStyle.THIN);

设置字体颜色

java 复制代码
Font font = workbook.createFont();
font.setColor(Font.COLOR_RED);		//红色
cellStyle.setFont(font);

合并单元格

java 复制代码
//firstRow第一行
//lastRow最后一行
//firstCol第一列
//lastCol最后一列
CellRangeAddress cellRangeAddress = new CellRangeAddress(2, 2, 0, 11);
sheet.addMergedRegion(cellRangeAddress);//合并单元格

为合并的单元格+边框

java 复制代码
//边框样式
//合并的单元格
//创建的表单Sheet
RegionUtil.setBorderTop(BorderStyle.THIN, cellRangeAddress, sheet);
RegionUtil.setBorderRight(BorderStyle.THIN, cellRangeAddress, sheet);
RegionUtil.setBorderBottom(BorderStyle.THIN, cellRangeAddress, sheet);
RegionUtil.setBorderLeft(BorderStyle.THIN, cellRangeAddress, sheet);

自动调整列宽

java 复制代码
//列号
sheet.autoSizeColumn(1);
相关推荐
{{uname}}2 小时前
利用WebSocket实现实时通知
网络·spring boot·websocket·网络协议
熊大如如2 小时前
Java 反射
java·开发语言
猿来入此小猿3 小时前
基于SSM实现的健身房系统功能实现十六
java·毕业设计·ssm·毕业源码·免费学习·猿来入此·健身平台
goTsHgo3 小时前
Spring Boot 自动装配原理详解
java·spring boot
卑微的Coder3 小时前
JMeter同步定时器 模拟多用户并发访问场景
java·jmeter·压力测试
pjx9874 小时前
微服务的“导航系统”:使用Spring Cloud Eureka实现服务注册与发现
java·spring cloud·微服务·eureka
多多*4 小时前
算法竞赛相关 Java 二分模版
java·开发语言·数据结构·数据库·sql·算法·oracle
爱喝酸奶的桃酥4 小时前
MYSQL数据库集群高可用和数据监控平台
java·数据库·mysql
唐僧洗头爱飘柔95275 小时前
【SSM-SSM整合】将Spring、SpringMVC、Mybatis三者进行整合;本文阐述了几个核心原理知识点,附带对应的源码以及描述解析
java·spring·mybatis·springmvc·动态代理·ioc容器·视图控制器
骑牛小道士5 小时前
Java基础 集合框架 Collection接口和抽象类AbstractCollection
java