加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

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

发布时间:2020-12-14 16:31:50 所属栏目:Java 来源:网络整理
导读:我正在使用Apache POI将数据导出到.xlsx文件,我想为文件中包含的一些行和单元格设置样式. 我正在使用XSSF,因为该文件将在Excel 2007中读取. 基本上,我的问题是,我正在尝试设置一个行风格,如下例所示,它为索引0的整行设置一个黑色的前景色.它工作正常,但每当
我正在使用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);

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读