我正在使用Apache POI 3.9以编程方式生成xlsx格式的excel .

对于特定列,所有单元格值应为蓝色字体 . 我的工作表有超过1500行,最少50列 .

我有一个返回blueFont颜色样式的方法 . 这是代码:

public CellStyle createBlueFont(){
    CellStyle fontStyle = workbook.createCellStyle(); // Creates new style
    Font blueFont = workbook.createFont(); // Creates new font
    blueFont.setColor(HSSFColor.BLUE.index);        
    fontStyle.setFont(blueFont);
    fontStyle.setWrapText(true);
    return fontStyle;
}

每次创建单元格时都会调用上述方法 .

生成Excel时没有任何异常 . 但是,当我双击一个值为蓝色字体的单元格时,它会自动恢复为黑色(默认颜色) .

我通过全局创建样式和字体解决了这个问题 . 我不明白为什么我的老方法是错误的 .

Note : 使用SXSSF库创建工作簿和电子表格 . 有人可以在我以前的代码中解释我错在哪里吗?

谢谢Aswini J.