使用POI处理Excel中公式不能自动计算出来的问题
2008-03-19 22:53
1191 查看
使用POI导入了拥有公式的Excel模板后,发现其中原有公式单元格计算出来的值不能正常显示出来,需要重新刷新该公式后方可正常得出计算结果.
针对此问题,写了一个测试,代码如下:
package cn.fory.formula;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
public class TestFormula {
/**
* 测试POI处理公式
*
* 问题描述:通过POI导入的数据后,引用导入数据的原有公式单元格不能显示出来,需要重新定位到公式单元
* 格然后重新转入公式才行成得结果
*
* 解决办法:重新对公式单元格设置公式
*
* 相关文件:test.xls文件中手工设置单元格B2=C2+D2
*
*/
public static void main(String[] args) throws FileNotFoundException {
POIFSFileSystem fs;
try {
fs = new POIFSFileSystem(new FileInputStream("test.xls"));
HSSFWorkbook wb = new HSSFWorkbook(fs);
HSSFSheet sheet = wb.getSheet("Sheet1");
HSSFRow row = sheet.getRow((short) 1);
HSSFCell cell = row.getCell((short) 2);
cell.setCellValue((short) 5);
cell = row.getCell((short) 3);
cell.setCellValue((short) 40);
HSSFCell cell1 = row.getCell((short)1);
if (HSSFCell.CELL_TYPE_FORMULA == cell1.getCellType()) {
//取得公式单元格的公式,重新设置
cell1.setCellFormula(cell1.getCellFormula());
}
FileOutputStream fileOut = new FileOutputStream("test.xls");
wb.write(fileOut);
fileOut.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
针对此问题,写了一个测试,代码如下:
package cn.fory.formula;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
public class TestFormula {
/**
* 测试POI处理公式
*
* 问题描述:通过POI导入的数据后,引用导入数据的原有公式单元格不能显示出来,需要重新定位到公式单元
* 格然后重新转入公式才行成得结果
*
* 解决办法:重新对公式单元格设置公式
*
* 相关文件:test.xls文件中手工设置单元格B2=C2+D2
*
*/
public static void main(String[] args) throws FileNotFoundException {
POIFSFileSystem fs;
try {
fs = new POIFSFileSystem(new FileInputStream("test.xls"));
HSSFWorkbook wb = new HSSFWorkbook(fs);
HSSFSheet sheet = wb.getSheet("Sheet1");
HSSFRow row = sheet.getRow((short) 1);
HSSFCell cell = row.getCell((short) 2);
cell.setCellValue((short) 5);
cell = row.getCell((short) 3);
cell.setCellValue((short) 40);
HSSFCell cell1 = row.getCell((short)1);
if (HSSFCell.CELL_TYPE_FORMULA == cell1.getCellType()) {
//取得公式单元格的公式,重新设置
cell1.setCellFormula(cell1.getCellFormula());
}
FileOutputStream fileOut = new FileOutputStream("test.xls");
wb.write(fileOut);
fileOut.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
相关文章推荐
- Poi处理Excel时公式不能更新的问题
- Poi处理Excel时公式不能更新的问题
- 使用POI生成Excel文件,可以自动调整excel列宽遇到的问题及解决
- POI生成EXCEL,公式不自动执行的有关问题
- jxls--使用模版导出excel,单元格无法自动计算问题解决
- 解决poi导出EXCEL报表之后,金额不能自动求和的问题
- 关于EXCEL中公式复制后不自动计算的问题!
- POI生成EXCEL,公式不自动执行的问题
- poi读取excel模板,填充内容并导出,支持导出2007支持公式自动计算
- poi读取excel模板,填充内容并导出,支持导出2007支持公式自动计算
- 使用poi更新excel,有公式的cell不计算的解决办法
- poi读取excel模板,填充内容并导出,支持导出2007支持公式自动计算
- poi读取excel模板,填充内容并导出,支持导出2007支持公式自动计算
- poi 操作 excel 里面设置的公式不会自动计算 需要双击才会触发
- 使用Pear的RPN库处理工资计算公式
- 如何解决eWebEditor在线编辑器的远程自动上传功能不能使用的问题?
- 用Excel打开csv文件时,如何处理数字内容展现会自动转换格式的问题
- java使用poi解析或处理excel的时候,如何防止数字变成科学计数法的形式
- 使用Pear的RPN库处理工资计算公式
- 使用poi向excel中插入内容遇到的问题总结