datagrid设置行颜色_Java 给Excel文档设置背景色

前言

在前文中,我介绍过如何使用Java代码来给Word文档添加背景色,以此来让枯燥乏味的文本更有活力。本篇教程将演示为Excel文档设置背景色的方法。根据需求不同,本次代码演示将介绍以下三种设置背景色的情况:

  • 为Excel工作表中所有数据的单元格区域设置背景色
  • 为Excel工作表中的指定单元格区域设置背景色
  • 为Excel工作表中的添加交替背景色

测试环境

在运行代码前,需要创建测试环境。首先请下载安装好JDK和Intellij IDEA,然后将Jar包导入IDEA中。导入方式有两种:其一,在E-iceblue中文官网上下载获取Free Spire.XLS for Java产品包,解压后将lib文件夹下的Spire.Xls.jar手动导入IDEA中;其二,通过Maven仓库安装导入产品包。在IDEA中创建一个Maven项目,然后在pom.xml文件下键入以下代码,最后点击“Import Changes”即可。

com.e-icebluehttp://repo.e-iceblue.cn/repository/maven-public/e-iceblue        spire.xls.free        3.9.1

最终导入效果如下图所示:

f8024f58fe8c982b2ebfd749e43745d8.png

代码示例

示例1 为Excel工作表中所有数据的单元格区域设置背景色

import com.spire.xls.ExcelVersion;import com.spire.xls.Workbook;import com.spire.xls.Worksheet;import java.awt.*;public class SetBackgroundColor {    public static void main(String[] args) {        //创建Workbook实例        Workbook workbook = new Workbook();        //加载Excel文档        workbook.loadFromFile("C:甥敳獲Test1DesktopTest.xlsx");        //获取第一个工作表        Worksheet sheet = workbook.getWorksheets().get(0);        //给工作表中已使用的单元格区域设置背景颜色        sheet.getAllocatedRange().getStyle().setColor(Color.green);        //保存文档        workbook.saveToFile("output/SetBackColor.xlsx", ExcelVersion.Version2013);    }}

效果图

78a887396662ac7fd0945ce71d6a342f.png

示例2 为Excel工作表中的指定单元格区域设置背景色

import com.spire.xls.ExcelVersion;import com.spire.xls.Workbook;import com.spire.xls.Worksheet;import java.awt.*;public class SetBackgroundColor {    public static void main(String[] args) {        //创建Workbook实例        Workbook workbook = new Workbook();        //加载Excel文档        workbook.loadFromFile("C:甥敳獲Test1DesktopTest.xlsx");        //获取第一个工作表        Worksheet sheet = workbook.getWorksheets().get(0);        //给指定单元格区域设置背景颜色        sheet.getCellRange("A1:D3").getStyle().setColor(Color.yellow);        //保存文档        workbook.saveToFile("output/SetBackColor.xlsx", ExcelVersion.Version2013);    }}

效果图

23fe6b8e69bac51fa41003a0bf1448a8.png

示例3 为Excel工作表中的行设置交替背景色

import com.spire.xls.*;import java.awt.*;public class SetRowColor {    public static void main(String[] args) {        //创建Workbook对象        Workbook workbook = new Workbook();        //加载一个Excel文档        workbook.loadFromFile("C:甥敳獲Test1DesktopTest.xlsx");        //获取一个工作表        Worksheet sheet = workbook.getWorksheets().get(0);        //获取有数据的区域        CellRange dataRange = sheet.getAllocatedRange();        //使用条件格式将偶数行的背景色设为浅灰色        ConditionalFormatWrapper format1 = dataRange.getConditionalFormats().addCondition();        format1.setFirstFormula("=MOD(ROW(),2)=0");        format1.setFormatType(ConditionalFormatType.Formula);        format1.setBackColor(Color.lightGray);        //使用条件格式将奇数行的背景色设为黄色        ConditionalFormatWrapper format2 = dataRange.getConditionalFormats().addCondition();        format2.setFirstFormula("=MOD(ROW(),2)=1");        format2.setFormatType(ConditionalFormatType.Formula);        format2.setBackColor(Color.yellow);        //保存文档        workbook.saveToFile("output/AlternateColor.xlsx", ExcelVersion.Version2016);    }}

效果图

56c7e8d175e60646903ada990b7d9fb6.png
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值