前言
在前文中,我介绍过如何使用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
最终导入效果如下图所示:
代码示例
示例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); }}
效果图
示例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); }}
效果图
示例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); }}
效果图