java – Apache POI,创建新单元格将覆盖行样式

前端之家收集整理的这篇文章主要介绍了java – Apache POI,创建新单元格将覆盖行样式前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在使用Apache POI将数据导出到.xlsx文件,我想为文件中包含的一些行和单元格设置样式.

我正在使用XSSF,因为该文件将在Excel 2007中读取.

基本上,我的问题是,我正在尝试设置一个行风格,如下例所示,它为索引0的整行设置一个黑色的前景色.它工作正常,但每当创建一个新单元格时,新创建单元格没有样式,就好像它覆盖了我指定的行样式.

这是一个代码片段来演示我在做什么:

XSSFWorkbook wb = new XSSFWorkbook();
XSSFSheet sheet = wb.createSheet("mySheet");
XSSFRow row = sheet.createRow(0);

XSSFCellStyle myStyle = wb.createCellStyle();           

myStyle.setFillForegroundColor(new XSSFColor(new Color(255,255,255)));
myStyle.setFillPattern(CellStyle.SOLID_FOREGROUND);

row.setRowStyle(myStyle); //This works,the whole row is now black

row.createCell(0); // This cell doesn't have a style,the rest of the line stays stylized
row.getCell(0).setCellValue("Test");

我也尝试过* row.createCell(0,Cell.CELL_TYPE_STRING); *,但它没有改变任何东西.

完成我想做什么的正确方法是什么?我想这样做,所以我创建之后不必设置每个单元格的样式,因为同一行上的所有单元格都具有相同的样式.

解决方法

将样式设置为新创建的单元格,例如下面:
XSSFCell newCell = row.createCell(0);
    newCell.setCellStyle(myStyle);

猜你在找的Java相关文章