import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import java.io.FileOutputStream;
import java.io.IOException;
public class POIExample {
public static void main(String[] args) {
// 创建一个新的工作簿
Workbook workbook = new XSSFWorkbook();
// 创建一个工作表
Sheet sheet = workbook.createSheet("Java Books");
// 数据数组
Object[][] bookData = {
{"Head First Java", "Kathy Sierra", 79},
{"Effective Java", "Joshua Bloch", 36},
{"Clean Code", "Robert C. Martin", 42}
};
// 创建字体样式
Font headerFont = workbook.createFont();
headerFont.setBold(true);
headerFont.setFontHeightInPoints((short) 14);
headerFont.setColor(IndexedColors.RED.getIndex());
// 创建单元格样式
CellStyle headerCellStyle = workbook.createCellStyle();
headerCellStyle.setFont(headerFont);
// 创建标题行
Row headerRow = sheet.createRow(0);
for (int i = 0; i < headers.length; i++) {
Cell cell = headerRow.createCell(i);
cell.setCellValue(headers[i]);
cell.setCellStyle(headerCellStyle);
}
// 填充数据
int rowNum = 1;
for (Object[] aBook : bookData) {
Row row = sheet.createRow(rowNum++);
int colNum = 0;
for (Object field : aBook) {
Cell cell = row.createCell(colNum++);
if (field instanceof String) {
cell.setCellValue((String) field);
} else if (field instanceof Integer) {
cell.setCellValue((Integer) field);
}
}
}
// 自动调整列宽
for (int i = 0; i < headers.length; i++) {
sheet.autoSizeColumn(i);
}
// 写入文件并关闭资源
try (FileOutputStream fileOut = new FileOutputStream("books.xlsx")) {
workbook.write(fileOut);
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
workbook.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
private static final String[] headers = {"Title", "Author", "Price"};
}
XSSFWorkbook 创建一个新的 Excel 工作簿,并创建一个名为 "Java Books" 的工作表。bookData,其中包含书籍的标题、作者和价格。bookData 数组,将每一本书的信息填入表格中。autoSizeColumn 方法自动调整每列的宽度以适应内容。books.xlsx 的文件中,并确保正确关闭资源。这段代码展示了如何使用 Apache POI 库创建一个简单的 Excel 文件。
上一篇:java map 遍历
下一篇:java mqtt
Laravel PHP 深圳智简公司。版权所有©2023-2043 LaravelPHP 粤ICP备2021048745号-3
Laravel 中文站