develpas 2019-04-19 16:25 采纳率: 100%
浏览 1266
已采纳

java 中 poi读取需刷新宏的excel单元格

我有excel计算模板文件,比如sheet1 G列是计算结果列,是通过好几个其他sheet页的数据透视得到的,但是excel打开时需要手动操作每个辅助计算的sheet页都点一遍,或者sheet1更改任意单元格值才会刷新G列的计算结果。
用poi循环getsheet,和在该文件sheet1单元格添加值始终无法获得计算过的G列的值,起不到手动打开excel改值刷新的效果
网上的方式下面2个种方式也试过了
wb1.setForceFormulaRecalculation(true);

wb.getCreationHelper().createFormulaEvaluator().evaluateFormulaCell(cell)
请问有解决办法吗

  • 写回答

1条回答 默认 最新

  • 迷路的公民 2019-04-19 16:42
    关注

    setForceFormulaRecalculation是有效的,我做的项目就用了这个,你这里之所以无效,有可能是你在当前编辑之后立刻读取,你试试添加单元格值后,先调用wb.write(out)写到一个ByteArrayOutputStream中,然后wb.close(),再重新打开这个流来读取数据。
    还有就是数据格式会影响计算结果,格式不对有时不会触发计算

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥20 c语言写的8051单片机存储器mt29的模块程序
  • ¥60 求直线方程 使平面上n个点在直线同侧并且距离总和最小
  • ¥50 java算法,给定试题的难度数量(简单,普通,困难),和试题类型数量(单选,多选,判断),以及题库中各种类型的题有多少道,求能否随机抽题。
  • ¥50 rk3588板端推理
  • ¥250 opencv怎么去掉 数字0中间的斜杠。
  • ¥15 这种情况的伯德图和奈奎斯特曲线怎么分析?
  • ¥250 paddleocr带斜线的0很容易识别成9
  • ¥15 电子档案元素采集(tiff及PDF扫描图片)
  • ¥15 flink-sql-connector-rabbitmq使用
  • ¥15 zynq7015,PCIE读写延时偏大