我正在使用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 举报,一经查实,本站将立刻删除。