乔山办公网我们一直在努力
您的位置:乔山办公网 > excel表格制作 > java语言怎么读取excel文件公式-java调用excel,java读取excel

java语言怎么读取excel文件公式-java调用excel,java读取excel

作者:乔山办公网日期:

返回目录:excel表格制作


自己zhidao算平均值吧,目前还没有什么方式可以解决这个问题。

理论上这个设想也不合理,Excel表格计算肯定会调用Excel程序,Excel是Windows平台的软件,Java在非Windows平台实现不了这个需求。

有个第三方jar包,可以读取excel文件里每个单元格的值,操作很简单,你百度一下,我忘了

在Java中读取Excel文件的内容

在这里,636f70797a64363我使用的是一个叫Java Excel API的东西,类似的还有jakarta的POI,不过感觉那个

太复杂了点儿。而且jxl对中文的支持相当的好,至少我在用的过程中一点问题没出。

一、下载地址

http:///jexcelapi/

二、特性

可以读取Excel 95, 97, 2000文件

可以读或写Excel 97及其以后版本的的公式(不过我发现好像有bug)

生成Excel 97格式的电子表格

支持字体、数字和日期格式化

支持单元格的颜色和阴影

可以编辑现有的文件

三、读文件

//声明一下,记得后面要关闭哦。。

Workbook workbook = null;

try {

workbook = Workbook.getWorkbook(new File("d:\\temp\\TestRead.xls"));

} catch (Exception e) {

throw new Exception("file to import not found!");

}

Sheet sheet = workbook.getSheet(0);

Cell cell = null;

int columnCount=3;

int rowCount=sheet.getRows();

for (int i = 0; i<rowcount; p="" {

for (int j = 0; j<columncount; p="" {

//注意,这里的两个参数,第一个是表示列的,第二才表示行

cell=sheet.getCell(j, i);

//要根据单元格的类型分别做处理,否则格式化过的内容可能会不正确

if(cell.getType()==CellType.NUMBER){

System.out.print(((NumberCell)cell).getValue());

}

else if(cell.getType()==CellType.DATE){

System.out.print(((DateCell)cell).getDate());

}

else{

System.out.print(cell.getContents());

}

//System.out.print(cell.getContents());

System.out.print("\t");

}

System.out.print("\n");

}

//关闭它,否则会有内存泄露

workbook.close();



针对此问题,写了一个测试,代码如下:e68a84e8a2ade79fa5e98193339package 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();

相关阅读

  • <em>java</em> poi <em>excel</em> <

  • 乔山办公网excel表格制作
  • 你可以在服务器响应的时候加一个response.setContentType("application/msexcel;charset=UTF-8");java poi导出excel乱码" src="/uploads/tu/436.jpg" style="width: 400px; height:
关键词不能为空
极力推荐

ppt怎么做_excel表格制作_office365_word文档_365办公网