Java Excel Poi 字体颜色设置

设置预定义颜色

要设置单元格的字体颜色,可以使用 Apache POI 中的 CellStyleFont 类。下面是一个示例代码,演示如何设置单元格字体颜色:

复制代码
import org.apache.poi.ss.usermodel.*;

public class SetCellFontColorExample {

    public static void main(String[] args) {
        // 创建工作簿和工作表
        Workbook workbook = new XSSFWorkbook();
        Sheet sheet = workbook.createSheet("Sheet1");

        // 创建单元格样式
        CellStyle style = workbook.createCellStyle();

        // 创建字体
        Font font = workbook.createFont();
        font.setColor(IndexedColors.RED.getIndex()); // 设置字体颜色为红色

        // 将字体应用于样式
        style.setFont(font);

        // 创建单元格并设置样式
        Row row = sheet.createRow(0);
        Cell cell = row.createCell(0);
        cell.setCellValue("Hello, World!");
        cell.setCellStyle(style);

        // 保存工作簿
        try {
            FileOutputStream fileOutputStream = new FileOutputStream("CellFontColorExample.xlsx");
            workbook.write(fileOutputStream);
            workbook.close();
            fileOutputStream.close();
            System.out.println("单元格字体颜色设置完成!");
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

这段代码创建了一个带颜色的单元格,字体颜色设置为红色。你可以根据需要将 IndexedColors 中的颜色调整为你想要的其他颜色。最后,代码将单元格写入到名为 "CellFontColorExample.xlsx" 的 Excel 文件中。

设置自定义颜色(RGB 或者 16进制颜色(#FFFFFF))

1.首先,创建一个 XSSFCellStyle 和XSSFFont对象,并为其设置字体样式:

java 复制代码
Workbook workbook = new XSSFWorkbook(); // 创建一个工作簿
Sheet sheet = workbook.createSheet("Sheet1"); // 创建一个工作表

XSSFCellStyle cellStyle = workbook.createCellStyle(); // 创建单元格样式
XSSFFont font = workbook.createFont(); // 创建字体样式

cellStyle.setFont(font); // 将字体样式应用于单元格样式

2.接下来,创建 XSSFColor 对象,并将 RGB 或 16进制 颜色值应用于字体样式:

java 复制代码
//RGB
font.setColor(new XSSFColor(new java.awt.Color(255, 0, 0))); // 设置字体颜色为红色

//16进制颜色
font.setColor(new XSSFColor(new java.awt.Color.decode("#FF0000"))); // 设置字体颜色为红色

3.最后,将样式应用到单元格中:

复制代码
Row row = sheet.createRow(0); // 创建第一行
Cell cell = row.createCell(0); // 创建第一个单元格

cell.setCellStyle(cellStyle); // 将样式应用于单元格

这样就可以设置单元格字体的自定义 颜色了。

请注意,上述代码使用的是 Apache POI 的 XSSFWorkbook 和 XSSFFont 类,适用于处理 .xlsx 格式的文件。如果需要处理 .xls 格式的文件,可以使用 HSSFWorkbook 和 HSSFFont 类。

相关推荐
未若君雅裁34 分钟前
MyBatis 一级缓存、二级缓存与清理机制
java·缓存·mybatis
cen__y1 小时前
Linux12(Git01)
linux·运维·服务器·c语言·开发语言·git
AI人工智能+电脑小能手1 小时前
【大白话说Java面试题 第65题】【JVM篇】第25题:谈谈对 OOM 的认识
java·开发语言·jvm
社交怪人1 小时前
【算平均分】信息学奥赛一本通C语言解法(题号2071)
c语言·开发语言
阿维的博客日记2 小时前
Nacos 为什么能让配置动态生效?(涉及 @RefreshScope 注解)
java·spring
雨辰AI2 小时前
SpringBoot3 + 人大金仓读写分离 + 分库分表 + 集群高可用 全栈实战
java·数据库·mysql·政务
郭涤生2 小时前
不同主机之间网络通信-以太网连接复习
开发语言·rk3588
山居秋暝LS2 小时前
【无标题】RTX00安装paddle OCR,win11不能装最新的,也不能用GPU
开发语言·r语言
卢锡荣2 小时前
单芯通吃,盲插标杆 —— 乐得瑞 LDR6020,Type‑C 全场景互联 “智慧芯”
c语言·开发语言·计算机外设
Xin_ye100862 小时前
C# 零基础到精通教程 - 第七章:面向对象编程(入门)——类与对象
开发语言·c#