微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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);

原文地址:https://www.jb51.cc/java/125149.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐