我正在使用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);