POI下载表格数据,带有表格样式时下载文件为0

1 现象描述:

公司要求做数据下载,同时下载的时候要求excel格式和前端配置的报表要保持一致,因此开发了新功能,增加了单元格字体,背景色,计算公式,小数位数等相应的功能。新功能上线后,偶尔报错

Excel 无法打开文件“*******.xlsx”,因为文件格式或文件扩展名无效。请确定文件未损坏,并且文件扩展名与文件的格式匹配。 

但是执行的代码一直往workbook里面写的代码一直没有报错,都是正常的,直到workbook。write(outputstream)这一行报错nullpoint。

后来经过被领导批评,自己慢慢找发现了原因

2 问题所在:

在写每一行数据的时候,循环调用了该语句。创建字体。

XSSFFont font = (XSSFFont) context.getWorkbook().createFont();

有资料显示:poi的这种字体,cellstyle等,样式信息,哪怕没有用到,只是create了,没有进行set到cell里面,他也是会存在于excel中的,所以当字体放在循环语句中时,excel就会下载失败。

需要把这些样式信息,按照列提前提取出来。放到一边。然后循环往里写。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您好!您可以使用poi-tl库来导出带有合并列的Word表格,并将其下载。下面是一个简单的示例代码: ```java import org.apache.poi.xwpf.usermodel.*; import org.apache.poi.xwpf.usermodel.XWPFTableCell.XWPFVertAlign; import java.io.FileOutputStream; import java.io.IOException; public class WordTableMergeColumnsExample { public static void main(String[] args) { // 创建一个新的文档 XWPFDocument document = new XWPFDocument(); // 创建一个表格 XWPFTable table = document.createTable(3, 3); // 合并第一行的前两列 table.getRow(0).getCell(0).getCTTc().addNewTcPr().addNewHMerge().setVal(STMerge.RESTART); table.getRow(0).getCell(0).setText("Merged Cells"); table.getRow(0).getCell(1).getCTTc().addNewTcPr().addNewHMerge().setVal(STMerge.CONTINUE); // 设置表格其他单元格的内容 table.getRow(1).getCell(0).setText("Cell 1"); table.getRow(1).getCell(1).setText("Cell 2"); table.getRow(1).getCell(2).setText("Cell 3"); table.getRow(2).getCell(0).setText("Cell 4"); table.getRow(2).getCell(1).setText("Cell 5"); table.getRow(2).getCell(2).setText("Cell 6"); // 设置表格样式 CTTblPr tblPr = table.getCTTbl().getTblPr(); CTTblWidth tblWidth = tblPr.getTblW(); tblWidth.setW(BigInteger.valueOf(5000)); // 调整表格所有单元格的垂直对齐方式 for (XWPFTableRow row : table.getRows()) { for (XWPFTableCell cell : row.getTableCells()) { cell.setVerticalAlignment(XWPFVertAlign.CENTER); } } // 将文档保存到文件 try (FileOutputStream out = new FileOutputStream("merged_table.docx")) { document.write(out); System.out.println("表格导出成功!"); } catch (IOException e) { System.out.println("表格导出失败:" + e.getMessage()); } } } ``` 这个示例代码创建了一个3x3的表格,并将第一行的前两列进行了合并。您可以根据自己的需求修改表格内容和样式。最后,将文档保存到名为 "merged_table.docx" 的文件。 希望对您有所帮助!如有其他问题,请随提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值