使用类IndexedColors
要自定义单元格颜色,首先需要创建一个新的CellStyle对象,并在其中设置背景颜色。然后,将CellStyle对象应用于单元格。下面是一个示例代码:
- // 导入所需的类
- import org.apache.poi.ss.usermodel.*;
-
- // 创建工作簿和工作表
- Workbook workbook = new XSSFWorkbook();
- Sheet sheet = workbook.createSheet("Sheet1");
-
- // 创建单元格并设置内容
- Row row = sheet.createRow(0);
- Cell cell = row.createCell(0);
- cell.setCellValue("Hello, World!");
-
- // 创建单元格样式并设置背景颜色
- CellStyle style = workbook.createCellStyle();
- style.setFillForegroundColor(IndexedColors.YELLOW.getIndex()); // 设置背景颜色为黄色
- style.setFillPattern(FillPatternType.SOLID_FOREGROUND); // 设置填充图案为实心
-
- // 将样式应用于单元格
- cell.setCellStyle(style);
-
- // 保存Excel文件
- FileOutputStream fileOut = new FileOutputStream("example.xlsx");
- workbook.write(fileOut);
- fileOut.close();
-
- // 关闭工作簿
- workbook.close();
以上示例代码创建了一个新的Excel文件,并在第一个单元格中设置了文本内容为"Hello, World!",并将单元格的背景颜色设置为黄色。
请注意,以上示例仅适用于使用poi库创建的.xlsx格式的Excel文件。如果使用poi库创建的.xls格式的Excel文件,可以使用HSSFCellStyle类和HSSFCellStyle.setFillForegroundColor()方法来设置背景颜色。
可以使用XSSFColor类的setRgb方法来设置RGB颜色。例如,可以使用以下代码设置红色:
使用十六进制值颜色: 可以通过使用Color类的静态方法
Color.decode(String str)
,通过十六进制字符串来获取颜色。其中str表示十六进制字符串。例如,获取十六进制值为"#FF0000"的红色可以使用Color.decode("#FF0000")
。
- XSSFColor redColor = new XSSFColor(new java.awt.Color(255, 0, 0));
-
- XSSFWorkbook workbook = new XSSFWorkbook();
- XSSFCellStyle style = workbook.createCellStyle();
- style.setFillForegroundColor(redColor);
- style.setFillPattern(FillPatternType.SOLID_FOREGROUND);
-
- //将样式应用到单元格:将样式对象应用到具体的单元格上。首先获取到单元格对象,然后使用setCellStyle方法将样式应用于单元格。例如:
-
- XSSFCell cell = row.createCell(0);
- cell.setCellValue("Hello, World!");
- cell.setCellStyle(style);
请注意,上述代码是使用XSSFWorkbook、XSSFCellStyle和XSSFCell类的情况下的示例。如果你使用的是HSSFWorkbook、HSSFCellStyle和HSSFCell类,设置自定义颜色的方式可能会有所不同。