Excel的两种形式
- demo.xls
为Excel2003的格式,其核心结构是复合文档类型的结构,存储数据量较小。在POI中使用HSSF对象操作。 - 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);