(8) 如何用Apache POI操作Excel文件-----POI-3.10.1 的一个颜色黑白色颠倒的一个bug和解决方案

在用POI-3.10.1 的版本设置Excel单元格的字体的颜色或者单元格背景色的时候,对于XSSF方式,如果设置的颜色为黑色,则实际在Excel中渲染出来的却是白色;反之,如果设置的颜色为白色,则实际在Excel中渲染出来的却是黑色。

这个是POI-3.10中XSSF中一个bug. 重现的代码如下:

import java.awt.Color;
import java.io.FileOutputStream;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFCellStyle;
import org.apache.poi.xssf.usermodel.XSSFColor;
import org.apache.poi.xssf.usermodel.XSSFFont;
import org.apache.poi.xssf.usermodel.XSSFRichTextString;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

/**
 * XSSF Color issue
 */
public class ColorIssues {
    public static void main(String[] args) throws Exception {
    <span style="white-space:pre">	</span>XSSFWorkbook wb = new XSSFWorkbook(); 
        Sheet sheet = wb.createSheet("Sheet1");
        Row row = sheet.createRow((short) 0);

        // 1.设置第一行第一列 (A1)
        XSSFCellStyle style = wb.createCellStyle();
        Cell cell = row.createCell((short) 0);
        cell.setCellValue(new XSSFRichTextString("Hello"));
        cell.setCellStyle(style);

        //2.设置第一行第二列(A2)的字体为白色,结果却变成了黑色
        style = wb.createCellStyle();
        XSSFFont ztFont = wb.createFont();  
        ztFont.setColor(new XSSFColor(Color.WHITE)); // 将字体设置为“白色”  
        //ztFont.setColor(HSSFColor.WHITE.index);
        style.setFont(ztFont);
        
        style.setFillForegroundColor(new XSSFColor(Color.BLUE));
        style.setFillPattern(FillPatternType.SOLID_FOREGROUND);
        
        cell = row.createCell((short) 1);
        cell.setCellValue("World");
        cell.setCellStyle(style);

        // 输出Excel文件
        FileOutputStream fileOut = new FileOutputStream("colorissus.xlsx");
        wb.write(fileOut);
        fileOut.close();

    }
}

如上图代码所示意,我设置了字体的颜色为白色,结果在输出的Excel文件中却是黑色。

 ztFont.setColor(new XSSFColor(Color.WHITE)); // 将字体设置为“白色”  

解决方案至少有两个.

(1) 方案一

把POI的版本从POI 3.10 换成 POI 3.12,则这个问题将会自动解决,不需要修改任何的代码。

(2) 方案二

保持POI的版本不变,把上面代码中的第30行代码

  ztFont.setColor(new XSSFColor(Color.WHITE)); // 将字体设置为“白色”

替换成

ztFont.setColor(HSSFColor.WHITE.index);

具体代码如下:

import java.awt.Color;
import java.io.FileOutputStream;

import org.apache.poi.hssf.util.HSSFColor;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFCellStyle;
import org.apache.poi.xssf.usermodel.XSSFColor;
import org.apache.poi.xssf.usermodel.XSSFFont;
import org.apache.poi.xssf.usermodel.XSSFRichTextString;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

/**
 * XSSF Color issue
 */
public class ColorIssues {
    public static void main(String[] args) throws Exception {
    	XSSFWorkbook wb = new XSSFWorkbook();
        Sheet sheet = wb.createSheet("Sheet1");
        Row row = sheet.createRow((short) 0);

        // 1.设置第一行第一列 (A1)
        XSSFCellStyle style = wb.createCellStyle();
        Cell cell = row.createCell((short) 0);
        cell.setCellValue(new XSSFRichTextString("Hello"));
        cell.setCellStyle(style);

        //2.设置第一行第二列(A2)的字体为白色,结果是正确的
        style = wb.createCellStyle();
        XSSFFont ztFont = wb.createFont();
        ztFont.setColor(HSSFColor.WHITE.index);
        style.setFont(ztFont);

        style.setFillForegroundColor(new XSSFColor(Color.BLUE));
        style.setFillPattern(FillPatternType.SOLID_FOREGROUND);

        cell = row.createCell((short) 1);
        cell.setCellValue("World");
        cell.setCellStyle(style);

        // 输出Excel文件
        FileOutputStream fileOut = new FileOutputStream("colorissus.xlsx");
        wb.write(fileOut);
        fileOut.close();

    }
}
时间: 2024-08-24 23:20:44

(8) 如何用Apache POI操作Excel文件-----POI-3.10.1 的一个颜色黑白色颠倒的一个bug和解决方案的相关文章

(5) 如何用Apache POI操作Excel文件-----发现Apache的POI的Bug后,如何给Apache的POI报Bug?

在我上篇文章中,(4) 如何用Apache POI操作Excel文件-----发现了POI-3.12一个回归,通过测试POI-3.12的版本,我发现了一个bug,那么发现bug后,该如何处理.我们有2种处理方式,首先我们到Apache POI的bug库里面搜索,看别人有没有创建类似的bug,如果有创建的,这个是最好的结果,我们只需要关注这个bug什么时候被修复.如果没有搜索不到,这个时候我们就需要给Apache POI报bug了.那么,如何给Apache报Bug? 第一步: 打开https://

java使用POI操作excel文件,实现批量导出,和导入

一.POI的定义 JAVA中操作Excel的有两种比较主流的工具包: JXL 和 POI .jxl 只能操作Excel 95, 97, 2000也即以.xls为后缀的excel.而poi可以操作Excel 95及以后的版本,即可操作后缀为 .xls 和 .xlsx两种格式的excel. POI全称 Poor Obfuscation Implementation,直译为"可怜的模糊实现",利用POI接口可以通过JAVA操作Microsoft office 套件工具的读写功能.官网:htt

java使用Apache POI操作excel文件

官方介绍 HSSF is the POI Project's pure Java implementation of the Excel '97(-2007) file format. XSSF is the POI Project's pure Java implementation of the Excel 2007 OOXML (.xlsx) file format. 从官方文档中了解到:POI提供的HSSF包用于操作 Excel '97(-2007)的.xls文件,而XSSF包则用于操作

(1) 如何用Apache POI操作Excel文件-----入门

Apache POI项目的目标就是可以用Java API来创建和维护各种Office文件(MS Word,MS PowerPoint和MS Excel). 本系列文章主要是针对Excel文件的操作.对于Excel的操作,Apache POI提供两种模型:HSSF和XSSF. 其区别,请参考下面的图1.截止到2015年5月28日,当前的最新版本是3.12. 具体信息,我们可以访问其官方网站:http://poi.apache.org/ 1.下面是用Apache POI创建一个工作薄的基本的代码 i

(2) 如何用Apache POI操作Excel文件-----如何在已有的Excel文件中插入一行新的数据?

在POI的第一节入门中,我们提供了两个简单的例子,一个是如何用Apache POI新建一个工作薄,另外一个例子是,如果用Apache POI新建一个工作表.那么在这个章节里面,我将会给大家演示一下,如何用Apache POI在已有的Excel文件中插入一行新的数据.具体代码,请看下面的例子. import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.

如何用Apache POI操作Excel文件-----如何对一个单元格加注解?

有的时候,我们需要通过操作Apache POI,在生成Cell数据的同时,能对其生成的Cell,加上注解(comments),类似于下面的. 那么对于这种情况,我们的代码应该如何写呢? 借花献佛,我就用Apache POI官方提供的例子,然后加上一些注解,给大家看一下.本例子的测试代码是基于POI-3.12的. 执行完后,将会生成上图所示的Excel工作表单(sheet) [java] view plain copy import org.apache.poi.ss.usermodel.*; i

如何用Apache POI操作Excel文件-----如何在已有的Excel文件中插入一行新的数据?

在POI的第一节入门中,我们提供了两个简单的例子,一个是如何用Apache POI新建一个工作薄,另外一个例子是,如果用Apache POI新建一个工作表.那么在这个章节里面,我将会给大家演示一下,如何用Apache POI在已有的Excel文件中插入一行新的数据.具体代码,请看下面的例子. [java] view plain copy import java.io.File; import java.io.FileInputStream; import java.io.FileNotFound

(3) 如何用Apache POI操作Excel文件-----如何对一个单元格加注解?

有的时候,我们需要通过操作Apache POI,在生成Cell数据的同时,能对其生成的Cell,加上注解(comments),类似于下面的. 那么对于这种情况,我们的代码应该如何写呢? 借花献佛,我就用Apache POI官方提供的例子,然后加上一些注解,给大家看一下.本例子的测试代码是基于POI-3.12的. 执行完后,将会生成上图所示的Excel工作表单(sheet) import org.apache.poi.ss.usermodel.*; import org.apache.poi.xs

(6) 如何用Apache POI操作Excel文件-----POI-3.10的一个和注解(comment)相关的另外一个bug

如果POI-3.10往一个工作表(sheet)里面插入数据的话,需要注意了,其有一个不太被容易发现的bug. 被插入的工作表(sheet)里面的单元格没有包含任何的注解(comment)的时候,插入一行数据,不会有任何问题.但是如果被插入的工作表(sheet)里面的单元格只要包含任何的注解(comment)的时候,这个时候插入一行数据的时候,就会破坏这个文件.当程序执行完后,如果打开被插入数据的Excel文件,我们将会发现,其会弹出下面的对话框. 程序代码如下, package com.tibc