<dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>3.9</version> </dependency> java代码创建多行表头
时间: 2023-06-17 09:06:09 浏览: 100
可以使用Apache POI库来创建多行表头。以下是一个示例代码:
```
import org.apache.poi.ss.usermodel.*;
import java.io.FileOutputStream;
import java.io.IOException;
public class ExcelTableHeader {
public static void main(String[] args) throws IOException {
// 创建工作簿
Workbook workbook = WorkbookFactory.create(true);
// 创建工作表
Sheet sheet = workbook.createSheet("Sheet1");
// 创建样式
CellStyle cellStyle = workbook.createCellStyle();
cellStyle.setAlignment(HorizontalAlignment.CENTER);
cellStyle.setVerticalAlignment(VerticalAlignment.CENTER);
cellStyle.setFillForegroundColor(IndexedColors.GREY_25_PERCENT.getIndex());
cellStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND);
cellStyle.setBorderBottom(BorderStyle.THIN);
cellStyle.setBorderTop(BorderStyle.THIN);
cellStyle.setBorderLeft(BorderStyle.THIN);
cellStyle.setBorderRight(BorderStyle.THIN);
// 创建表头
Row row1 = sheet.createRow(0);
Cell cell11 = row1.createCell(0);
cell11.setCellValue("Header 1");
cell11.setCellStyle(cellStyle);
Cell cell12 = row1.createCell(1);
cell12.setCellValue("Header 2");
cell12.setCellStyle(cellStyle);
Cell cell13 = row1.createCell(2);
cell13.setCellValue("Header 3");
cell13.setCellStyle(cellStyle);
Row row2 = sheet.createRow(1);
Cell cell21 = row2.createCell(0);
cell21.setCellValue("Sub Header 1");
cell21.setCellStyle(cellStyle);
Cell cell22 = row2.createCell(1);
cell22.setCellValue("Sub Header 2");
cell22.setCellStyle(cellStyle);
Cell cell23 = row2.createCell(2);
cell23.setCellValue("Sub Header 3");
cell23.setCellStyle(cellStyle);
// 自适应列宽
for (int i = 0; i < 3; i++) {
sheet.autoSizeColumn(i);
}
// 写入文件
FileOutputStream outputStream = new FileOutputStream("table_header.xlsx");
workbook.write(outputStream);
workbook.close();
}
}
```
在上面的示例中,我们创建了一个包含两行表头的工作表,使用居中对齐、灰色填充和细线边框样式。
你可以根据需要更改样式和表头行数。
阅读全文