Java Excel Poi字体颜色自定义设置代码

 更新时间:2024年01月30日 08:56:53   作者:软件星  
最近项目使用POI按模板导出Excel,需要设置单元格的字体为红色,下面这篇文章主要给大家介绍了关于Java Excel Poi字体颜色自定义设置的相关资料,需要的朋友可以参考下

设置预定义颜色

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

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对象,并为其设置字体样式:

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

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

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

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

//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 类。

附:POI导出excel如何设置字体,颜色和自适应

1.设置字体,颜色

//设置style
CellStyle cstyle = workbook.createCellStyle();
HSSFFont font = workbook.createFont();

font .setFontHeightInPoints((short) 10);//字体大小
font .setColor(Font.COLOR_BLUE);//字体颜色
font.setFontName("宋体");//字体
cstyle .setFont(font);

......
cell.setCellStyle(cstyle);//将style设置进单元格cell中
......

2.自适应

  • 设置行高
row.setHeightInPoints(15);//将行高设置成15px
  • 设置列宽
//根据一列数据中的最长的字符串长度设置宽度
sheet.AutoSizeColumn(i)//i为列,只能解决英文、数字列宽自适应。
sheet.setColumnWidth(i, sheet.getColumnWidth(i) * 18 / 10);// 解决自动设置列宽中文失效的问题

总结

到此这篇关于Java Excel Poi字体颜色自定义设置的文章就介绍到这了,更多相关Java Excel Poi字体颜色设置内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • SpringBoot之瘦身部署问题

    SpringBoot之瘦身部署问题

    这篇文章主要介绍了SpringBoot之瘦身部署问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • Spring IoC容器Bean作用域的singleton与prototype使用配置

    Spring IoC容器Bean作用域的singleton与prototype使用配置

    这篇文章主要为大家介绍了Spring IoC容器Bean作用域的singleton与prototype使用配置详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-12-12
  • Spring Security自定义认证逻辑实例详解

    Spring Security自定义认证逻辑实例详解

    这篇文章主要给大家介绍了关于Spring Security自定义认证逻辑的相关资料,文中通过实例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2022-01-01
  • Java 项目中使用递归的小结

    Java 项目中使用递归的小结

    在 Java 中,递归是指在方法的定义中调用自身的过程,递归是基于方法调用栈的原理实现的:当一个方法被调用时,会在调用栈中创建一个对应的栈帧,包含方法的参数、局部变量和返回地址等信息,这篇文章主要介绍了Java 项目中对使用递归的理解分享,需要的朋友可以参考下
    2024-07-07
  • spring-boot-plus V1.4.0发布 集成用户角色权限部门管理(推荐)

    spring-boot-plus V1.4.0发布 集成用户角色权限部门管理(推荐)

    这篇文章主要介绍了spring-boot-plus V1.4.0发布 集成用户角色权限部门管理,本文给大家介绍的非常详细,具有一定的参考借鉴价值需要的朋友可以参考下
    2019-11-11
  • JDK8新特性-java.util.function-Function接口使用

    JDK8新特性-java.util.function-Function接口使用

    这篇文章主要介绍了JDK8新特性-java.util.function-Function接口使用,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04
  • Eclipse自定义启动画面和图标的方法介绍

    Eclipse自定义启动画面和图标的方法介绍

    这篇文章主要介绍了Eclipse自定义启动画面和图标的方法介绍,以及一些eclipse的快捷键,具有一定参考价值,需要的朋友可以了解下。
    2017-11-11
  • SpringBoot集成Seata的全过程

    SpringBoot集成Seata的全过程

    本文介绍了事务的四大特性(原子性、一致性、隔离性、持久性)以及本地事务和分布式事务的概念,本地事务是指在单个数据库级别的事务管理,而分布式事务则是跨多个数据库或服务的事务管理,感兴趣的朋友一起看看吧
    2024-11-11
  • MyBatis注解CRUD与执行流程深入探究

    MyBatis注解CRUD与执行流程深入探究

    这篇文章主要介绍了MyBatis注解CRUD与执行流程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
    2023-02-02
  • redisson分布式限流RRateLimiter源码解析

    redisson分布式限流RRateLimiter源码解析

    这篇文章主要为大家介绍了redisson分布式限流RRateLimiter源码解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-11-11

最新评论