Java代码使用POI导出的单元格加上边框和背景色

简介: 【5月更文挑战第3天】Java代码使用POI导出的单元格加上边框和背景色

在Java中使用Apache POI为Excel单元格添加边框和背景色的步骤如下:

  1. 导入所需库
    确保项目中已引入Apache POI相关依赖,特别是poi-ooxml

  2. 创建或加载Excel工作簿
    使用Apache POI创建一个新的或加载一个现有的Excel工作簿。

    import org.apache.poi.xssf.usermodel.XSSFWorkbook;
    import org.apache.poi.xssf.usermodel.XSSFSheet;
    
    // 创建新的工作簿
    XSSFWorkbook workbook = new XSSFWorkbook();
    // 或加载已有工作簿
    XSSFWorkbook workbook = new XSSFWorkbook(new FileInputStream("path_to_your_file.xlsx"));
    
    XSSFSheet sheet = workbook.createSheet("Sheet1"); // 创建或获取工作表
    
  3. 定位目标单元格
    根据需要,通过getRow()getCell()方法获取目标单元格。

    import org.apache.poi.ss.usermodel.Cell;
    
    int rowIndex = 0; // 目标行索引
    int columnIndex = 0; // 目标列索引
    Cell cell = sheet.getRow(rowIndex).getCell(columnIndex);
    
  4. 设置单元格样式:边框与背景色
    获取单元格的样式对象(CellStyle),并设置边框样式和背景色。

    import org.apache.poi.ss.usermodel.BorderStyle;
    import org.apache.poi.ss.usermodel.CellStyle;
    import org.apache.poi.ss.usermodel.IndexedColors;
    
    // 获取或创建单元格样式
    CellStyle style = cell.getCellStyle();
    if (style == null) {
         
        style = workbook.createCellStyle();
    }
    
    // 设置边框样式
    style.setBorderTop(BorderStyle.THIN); // 上边框
    style.setBorderBottom(BorderStyle.THIN); // 下边框
    style.setBorderLeft(BorderStyle.THIN); // 左边框
    style.setBorderRight(BorderStyle.THIN); // 右边框
    
    // 设置边框颜色
    style.setTopBorderColor(IndexedColors.BLACK.getIndex()); // 上边框颜色
    style.setBottomBorderColor(IndexedColors.BLACK.getIndex()); // 下边框颜色
    style.setLeftBorderColor(IndexedColors.BLACK.getIndex()); // 左边框颜色
    style.setRightBorderColor(IndexedColors.BLACK.getIndex()); // 右边框颜色
    
    // 设置背景色(填充色)
    style.setFillForegroundColor(IndexedColors.LIGHT_GREEN.getIndex()); // 背景色为浅绿色
    style.setFillPattern(FillPatternType.SOLID_FOREGROUND); // 填充模式为纯色填充
    
    // 将更新后的样式应用到单元格
    cell.setCellStyle(style);
    
  5. 保存工作簿
    完成所有操作后,确保将修改后的Excel工作簿保存到文件或输出流。

    try (FileOutputStream outputStream = new FileOutputStream("output_file.xlsx")) {
         
        workbook.write(outputStream);
    } catch (IOException e) {
         
        e.printStackTrace();
    }
    

综上所述,完整的代码示例如下:

```java
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.apache.poi.xssf.usermodel.XSSFColor;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFCellStyle;
import org.apache.poi.ss.usermodel.FillPatternType;
import org.apache.poi.ss.usermodel.IndexedColors;

import java.io.FileOutputStream

目录
相关文章
|
18天前
|
Java API 开发工具
【Azure Developer】Java代码实现获取Azure 资源的指标数据却报错 "invalid time interval input"
在使用 Java 调用虚拟机 API 获取指标数据时,因本地时区设置非 UTC,导致时间格式解析错误。解决方法是在代码中手动指定时区为 UTC,使用 `ZoneOffset.ofHours(0)` 并结合 `withOffsetSameInstant` 方法进行时区转换,从而避免因时区差异引发的时间格式问题。
114 3
|
27天前
|
缓存 Java 开发者
Java 开发者必看!ArrayList 和 LinkedList 的性能厮杀:选错一次,代码慢成蜗牛
本文深入解析了 Java 中 ArrayList 和 LinkedList 的性能差异,揭示了它们在不同操作下的表现。通过对比随机访问、插入、删除等操作的效率,指出 ArrayList 在多数场景下更高效,而 LinkedList 仅在特定情况下表现优异。文章强调选择合适容器对程序性能的重要性,并提供了实用的选择法则。
101 3
|
30天前
|
人工智能 监控 安全
智慧工地解决方案,java智慧工地程序代码
智慧工地系统融合物联网、AI、大数据等技术,实现对施工现场“人、机、料、法、环”的全面智能监控与管理,提升安全、效率与决策水平。
|
1月前
|
算法 IDE Java
Java 项目实战之实际代码实现与测试调试全过程详解
本文详细讲解了Java项目的实战开发流程,涵盖项目创建、代码实现(如计算器与汉诺塔问题)、单元测试(使用JUnit)及调试技巧(如断点调试与异常排查),帮助开发者掌握从编码到测试调试的完整技能,提升Java开发实战能力。
259 0
|
2月前
|
安全 Java 测试技术
Java 项目实战中现代技术栈下代码实现与测试调试的完整流程
本文介绍基于Java 17和Spring技术栈的现代化项目开发实践。项目采用Gradle构建工具,实现模块化DDD分层架构,结合Spring WebFlux开发响应式API,并应用Record、Sealed Class等新特性。测试策略涵盖JUnit单元测试和Testcontainers集成测试,通过JFR和OpenTelemetry实现性能监控。部署阶段采用Docker容器化和Kubernetes编排,同时展示异步处理和反应式编程的性能优化。整套方案体现了现代Java开发的最佳实践,包括代码实现、测试调试
133 0
|
2月前
|
Java 编译器 数据库连接
Java异常处理:写出更健壮的代码
Java异常处理:写出更健壮的代码
159 0
|
2月前
|
SQL Java 数据库连接
Java 期末考试救急必备涵盖绝大多数核心考点及五大类经典代码助你过关
本文为Java期末考试复习指南,涵盖基础语法、面向对象编程、异常处理、文件操作、数据库连接五大核心考点,提供详细解析与实用代码示例,助力快速掌握重点,高效备考,轻松应对考试。
78 0
|
2月前
|
Java 数据安全/隐私保护
快手小红书抖音留痕工具,自动留痕插件工具,java代码开源
这个框架包含三个核心模块:主操作类处理点赞评论、配置管理类和代理管理类。使用时需要配合
|
2月前
|
Java 机器人 API
tiktok群控脚本,养号关注私信点赞脚本插件,java代码分享
这个代码模拟了一个社交机器人的基本行为模式,包括登录、关注、点赞、私信等操作。请注意