POI刷新数据后的函数(公式)更新问题
使用POI将Excel模板中的数据进行更新,这应该是很常见的操作
下面就贴上我的一小段代码
public class ModifyExcel { /**
* @param fileName Excel报表路径
* @param sheetName Excel中需要修改的sheet名
* @param modify_from 从哪一个坐标点开始刷新数据
* @param crs 从Oracle中读取出来的缓存数据集
* @throws Exception
*/
public void doModify(String fileName,String sheetName,int[] modify_from,CachedRowSet crs) throws Exception{
Workbook wb=WorkbookFactory.create(new FileInputStream(fileName));
Sheet sheet=wb.getSheet(sheetName); int i=0;
while(crs.next()){
if(sheet.getRow(i+modify_from[0])==null)
sheet.createRow(i+modify_from[0]);
for(int j=0;j<crs.getMetaData().getColumnCount();j++){
Cell cell=sheet.getRow(i+modify_from[0]).getCell(j+modify_from[1]);
if(cell==null)
cell=sheet.getRow(i+modify_from[0]).createCell(j+modify_from[1]); String content=crs.getString(j+1);
try{
cell.setCellValue(Double.parseDouble(content));
}catch(Exception e){
cell.setCellValue(content);
} }
i++;
} FileOutputStream fout = new FileOutputStream(fileName);
wb.write(fout);
fout.flush();
fout.close(); wb.close();
}
}
这一段代码是使用POI将从数据库中取到的结果集更新到报表中的一个隐藏sheet中去
然而遇到一个问题
隐藏的sheet作为数据源,为多个非隐藏的报表sheet提供基础数据,也就是说Excel中还有很多sheet是要调用这个隐藏sheet中的数据的
使用POI将数据源的sheet更新后,你的Excel模板并没有触发任何的数据修改事件,因为你本身并没有打开WPS或者Office
所以报表sheet中那些代入,那些引用,那些函数和公式,全部都不会有更新
除非你在 wb.write(fout); 之前加上一句
wb.setForceFormulaRecalculation(true);
强制整个Excel在你打开WPS或者Office的一瞬间,重新计算更新一下函数公式
接着又会碰到另一个问题
如果我不打开WPS或者Office,一直不打开,那在单纯的Excel文件里,那些报表的函数公式会更新吗?
答案是否定的
想做个这个测试很简单,先在隐藏sheet中修改数据源,然后不打开WPS或者Office
再一次使用POI去读这个文件,将读到的公式数据输出,你会发现他们还是原来的值,并没有因为数据源的变化而重新计算
经过博主的不断研究,终于发现如果要在不打开WPS或者Office的情况下,更新完数据源后强制所有sheet中的公式重新计算
需要对指定的Cell进行如下操作:
wb.getCreationHelper().createFormulaEvaluator().evaluateFormulaCell(cell);
博主最终将这行代码添加在读取公式单元格的操作中,在读的时候强制计算新值
实现代码如下:
// 设置文本
String strCell = "";
switch (cells[i][j].getCell().getCellType()) {
case HSSFCell.CELL_TYPE_NUMERIC:
strCell = String.valueOf(cells[i][j].getCell().getNumericCellValue());
break;
case HSSFCell.CELL_TYPE_STRING:
strCell = cells[i][j].getCell().getStringCellValue();
break;
case HSSFCell.CELL_TYPE_BOOLEAN:
strCell = String.valueOf(cells[i][j].getCell().getBooleanCellValue());
break;
case HSSFCell.CELL_TYPE_FORMULA:
//刚写入的数据无法及时更新,需要人为打开WPS或者Office才能更新
//使用evaluateFormulaCell对函数单元格进行强行更新计算
wb.getCreationHelper().createFormulaEvaluator().evaluateFormulaCell(cells[i][j].getCell()); try {
strCell = String.valueOf(cells[i][j].getCell().getNumericCellValue());
} catch (IllegalStateException e) {
strCell = String.valueOf(cells[i][j].getCell().getRichStringCellValue());
}
break;
default:
strCell = "";
}
POI刷新数据后的函数(公式)更新问题的更多相关文章
- 添加数据库数据后(SVN的更新和启动)、SVN启动
一.添加数据库数据: 1.修改Excel表格,添加字段 2.修改数据库,添加字段 3.修改程序 4.使用Excel生成Tabletotable文件,并修改生成文件的内容. (1)删除cpp文件所有的H ...
- UWP 自然灾害App在刷新数据后卡死的解决方案
一直以为都在纳闷,为啥我的其他app崩溃次数几乎为0,而单单这个App的崩溃次数简直逆天了,我都不敢相信. 每天都有至少上千次crash...我也是服的 不甘心,趁着这次重构的机会,把代码好好捋了1下 ...
- Adapter刷新数据的坑
adapter刷新数据的时候,要能够刷新成功,要保证每次刷新的时候都是改变数据源. 于是,我这样做了,在适配器的构造方法里面写到: private List<ListBean> listI ...
- DataGridView重新加载数据后,选中上次选中的行。
public int SelecedRow;//记录当前鼠标点中的行索引(用于解决用户获取看板数据,刷新数据后,当前选中行回到默认行) private void dataGridView1_CellC ...
- IDEA 修改JSP和后端数据后,页面刷新可以实时更新
情况:刚开始使用IDEA进行开发时,发现修改JSP页面或者后端数据后,再刷新浏览器页面,发现没有变化,页面无更新. 这样就导致不得不频繁重启tomcat服务器.非常麻烦 解决方法: 步骤1. 先设置t ...
- 关于ListView中notifyDataSetChanged()刷新数据不更新原因
使用Listview的时候: 当要动态显示更改后的数据(例如数据库改动), 很多人应该都用过notifyDataSetChanged();这个方法来刷新Listview,显示改后的数据. 这时候就要注 ...
- js实现非模态窗口增加数据后刷新父窗口数据
父窗口是由两个部分组成,一个html的table,一部分是extjs的gird. 点击grid面板[增加]按钮将会弹出非模态窗口进行新数据的编辑页面 下面是按钮的触发函数代码: var a = win ...
- [转]MFC子线程更改图像数据后更新主窗口图像显示方法
程序思路是由外部的输入输出控制卡发出采集图像信号,之后相机采集图像得到图像数据指针,接收图像数据指针创建成图像最后显示到MFC对话框应用程序的Picture Control控件上,同时,为了标定相机位 ...
- 解决Vuex持久化插件-在F5刷新页面后数据不见的问题
页面刷新后,想保存页面未保存的数据.我们总是习惯于放在浏览器的sessionStorage和localStorage中.但是用了vue后,vuex便可以被应用了. vuex优势:相比sessionSt ...
随机推荐
- Python中__init__方法/__name__系统变量讲解
__init__方法在类的一个对象被建立时,马上运行.这个方法可以用来对你的对象做一些你希望的初始化. 代码例子 test.py#!/usr/bin/python# Filename: class_i ...
- Nginx使用webbench进行压力测试(转载)
在运维工作中,压力测试是一项非常重要的工作.比如在一个网站上线之前,能承受多大访问量.在大访问量情况下性能怎样,这些数据指标好坏将会直接影响用户体验. 但是,在压力测试中存在一个共性,那就是压力测试的 ...
- JavaScript事件委托的技术原理
如今的JavaScript技术界里最火热的一项技术应该是‘事件委托(event delegation)’了.使用事件委托技术能让你避免对特定的每个节点添加事件监听器:相反,事件监听器是被添加到它们的父 ...
- Java正则表达式匹配例子
Java正则表达式匹配例子 package com.ibm.test; import java.util.regex.Matcher; import java.util.regex.Pattern; ...
- zoj 3057 Beans Game 博弈论
思路:三维DP,刚开始用记忆化搜索,MLE…… 后来改为直接预处理所有的情况. 总之就是必败态的后继是必胜态!!! 代码如下: #include<iostream> #include< ...
- lintcode:带环链表
带环链表 给定一个链表,判断它是否有环. 解题 定义两个指针p1 p2 p1每次向前走一步 p2每次向前走两步 当p2能赶上p1的时候说明有环 /** * Definition for ListNod ...
- 【PSR规范专题(3)】PSR-2 代码风格规范
[PSR规范专题(3)]PSR-2 代码风格规范 标签(空格分隔): PHP 转载自:https://github.com/PizzaLiu/PHP-FIG/blob/master/PSR-2-cod ...
- 查看服务器硬件配置信息(cpu/内存)
1.查看cpu情况: 方法一: Linux下CPU相关的参数保存在 /proc/cpuinfo 文件里 cat /proc/cpuinfo |more 方法二: 采用命令 dmesg ...
- Markdown语法和MWeb使用说明
Markdown 语法和 MWeb 写作使用说明 开始写博客,首先熟悉一下Markdown,以前过看GitHub里的README.MD,感受到了这种文字排版的简洁美观. 写博客是一种有效的学习总结和分 ...
- *在Win7中安装JDK1.7并配置环境变量
安装的过程就不废话了. 下面是环境变量的配置. 1. 配置环境变量 单机右键‘计算机--属性’ 2.点击高级系统设置 3.点击‘环境变量’ 4.增加"JAVA_HOME"系统变 ...