Apache POI(5):公式(formula)

Apache POI(5):公式(formula)

2016年08月01日 17:44:49

阅读数:1145
  1.  
    package com.hthk.iisz.util;
  2.  
     
  3.  
    import java.io.File;
  4.  
    import java.io.FileOutputStream;
  5.  
     
  6.  
    import org.apache.poi.xssf.usermodel.XSSFCell;
  7.  
    import org.apache.poi.xssf.usermodel.XSSFRow;
  8.  
    import org.apache.poi.xssf.usermodel.XSSFSheet;
  9.  
    import org.apache.poi.xssf.usermodel.XSSFWorkbook;
  10.  
     
  11.  
    public class FormulaTest {
  12.  
     
  13.  
    public static void main(String[] args) throws Exception {
  14.  
    formula();
  15.  
    }
  16.  
     
  17.  
    public static void formula() throws Exception {
  18.  
    XSSFWorkbook workbook = new XSSFWorkbook();
  19.  
    XSSFSheet sheet = workbook.createSheet("formula");
  20.  
    XSSFRow row = sheet.createRow(1);
  21.  
    XSSFCell cell = row.createCell(1);
  22.  
    cell.setCellValue("A =");
  23.  
    cell = row.createCell(2);
  24.  
    cell.setCellValue(2);
  25.  
    row = sheet.createRow(2);
  26.  
    cell = row.createCell(1);
  27.  
    cell.setCellValue("B =");
  28.  
    cell = row.createCell(2);
  29.  
    cell.setCellValue(4);
  30.  
    row = sheet.createRow(3);
  31.  
    cell = row.createCell(1);
  32.  
    cell.setCellValue("Total =");
  33.  
    cell = row.createCell(2);
  34.  
    // create sum formula
  35.  
    cell.setCellType(XSSFCell.CELL_TYPE_FORMULA);
  36.  
    cell.setCellFormula("SUM(C2:C3)");
  37.  
     
  38.  
    cell = row.createCell(3);
  39.  
    cell.setCellValue("SUM(C2:C3)");
  40.  
    row = sheet.createRow(4);
  41.  
    cell = row.createCell(1);
  42.  
    cell.setCellValue("POWER =");
  43.  
    cell = row.createCell(2);
  44.  
    // create power formula
  45.  
    cell.setCellType(XSSFCell.CELL_TYPE_FORMULA);
  46.  
    cell.setCellFormula("POWER(C2,C3)");
  47.  
     
  48.  
    cell = row.createCell(3);
  49.  
    cell.setCellValue("POWER(C2,C3)");
  50.  
    row = sheet.createRow(5);
  51.  
    cell = row.createCell(1);
  52.  
    cell.setCellValue("MAX =");
  53.  
    cell = row.createCell(2);
  54.  
    // Create MAX formula
  55.  
    cell.setCellType(XSSFCell.CELL_TYPE_FORMULA);
  56.  
    cell.setCellFormula("MAX(C2,C3)");
  57.  
     
  58.  
    cell = row.createCell(3);
  59.  
    cell.setCellValue("MAX(C2,C3)");
  60.  
    row = sheet.createRow(6);
  61.  
    cell = row.createCell(1);
  62.  
    cell.setCellValue("FACT =");
  63.  
    cell = row.createCell(2);
  64.  
    // Create FACT formula
  65.  
    cell.setCellType(XSSFCell.CELL_TYPE_FORMULA);
  66.  
    cell.setCellFormula("FACT(C3)");
  67.  
     
  68.  
    cell = row.createCell(3);
  69.  
    cell.setCellValue("FACT(C3)");
  70.  
    row = sheet.createRow(7);
  71.  
    cell = row.createCell(1);
  72.  
    cell.setCellValue("SQRT =");
  73.  
    cell = row.createCell(2);
  74.  
    // Create SQRT formula
  75.  
    cell.setCellType(XSSFCell.CELL_TYPE_FORMULA);
  76.  
    cell.setCellFormula("SQRT(C5)");
  77.  
     
  78.  
    cell = row.createCell(3);
  79.  
    cell.setCellValue("SQRT(C5)");
  80.  
    workbook.getCreationHelper().createFormulaEvaluator().evaluateAll();
  81.  
    FileOutputStream out = new FileOutputStream(new File("formula.xlsx"));
  82.  
    workbook.write(out);
  83.  
    out.close();
  84.  
    System.out.println("fromula.xlsx written successfully");
  85.  
    }
  86.  
     
  87.  
    }

效果截图

 
 
cell.SetCellType(CellType.FORMULA);
sheet.ForceFormulaRecalculation = true;

1.使用cell.setCellFormula方法重新在制定Cell里写入公式。

2.使用sheet.setForceFormulaRecalculation(true);方法强制让改Sheet执行公式。

EvaluateFormulaCell

#region 插入块
int rowsindex = 0;
for (int i = 0; i < lastarea.Count - 1; i++)
{
int tj = rowsindex + 70;
for (; rowsindex < tj; rowsindex++)
{
sheet.CreateRow(rowsindex + 70);   //有些行为null  统一创建一下
sheet.CopyRow(rowsindex, rowsindex + 70);
}
}
#endregion

//统计
if ((HSSFCell)sheet.GetRow(dataarea + 40).GetCell(3) == null) //一个道理 为空 创建
{
ICell cell = (HSSFCell)sheet.GetRow(dataarea + 40).CreateCell(3);
}
((HSSFCell)sheet.GetRow(dataarea + 40).GetCell(3)).SetCellType(CellType.FORMULA); //设置表达式格式

//((HSSFRow)sheet.GetRow(dataarea + 40)).GetCell(3).SetCellValue("=SUM(D" + (dataarea + 1) + ":D" + (dataarea + 40) + ")");
((HSSFRow)sheet.GetRow(dataarea + 40)).GetCell(3).SetCellFormula("SUM(D" + (dataarea + 1) + ":D" + (dataarea + 40) + ")"); //设置表达式的值 不用=

工作总结 npoi 模板 导出公式 excel的更多相关文章

  1. c#使用NPOI快速导出到Excel

    接上篇博文<C#快速导出到excel>:由于此种方法不能导出成.xlsx格式,为解决此问题,本次分享使用NPOI. 参考:https://www.cnblogs.com/lazyneal/ ...

  2. c#.net 使用NPOI导入导出标准Excel (asp.net winform csharp)

    尝试过很多Excel导入导出方法,都不太理想,无意中逛到oschina时,发现了NPOI,无需Office COM组件且不依赖Office,顿时惊为天人,怀着无比激动的心情写下此文. 曾使用过的方法 ...

  3. ASP.NET- 使用NPOI导入导出标准Excel

    尝试过很多Excel导入导出方法,都不太理想,无意中逛到oschina时,发现了NPOI,无需Office COM组件且不依赖Office,顿时惊为天人,怀着无比激动的心情写下此文. 曾使用过的方法 ...

  4. 使用NPOI导入导出标准Excel

    尝试过很多Excel导入导出方法,都不太理想,无意中逛到oschina时,发现了NPOI,无需Office COM组件且不依赖Office,顿时惊为天人,怀着无比激动的心情写下此文. 曾使用过的方法 ...

  5. NPOI 设置导出的excel内容样式

    导出excel时,有时要根据需要加上一些样式,以上几种样式是我在项目中用到的 一.给单元格加背景色只需两步:一是创建单元格背景景色对象:二是给单元格绑定样式 //创建单元格背景颜色对象 HSSFPal ...

  6. 使用NPOI快速导出导入Excel

    这两天做项目需要导入导出EXCEL,是基于NPOI的封装,设计思路是使用DataTable,然后导出一个和DataTable一模一样的Excel表出来 github地址:https://github. ...

  7. NOPI读取模板导出(Excel中追加数据)

    在Controller里,我们定义一个FileResult的Action,返回值是一个文件形式被浏览器下载下来. [HttpGet] public FileResult ExportProductLi ...

  8. asp.net Mvc Npoi 导出导入 excel

    因近期项目遇到所以记录一下: 首先导出Excel : 首先引用NPOI包 http://pan.baidu.com/s/1i3Fosux (Action一定要用FileResult) /// < ...

  9. ASP.NET Core 2.2 : 十六.扒一扒新的Endpoint路由方案 try.dot.net 的正确使用姿势 .Net NPOI 根据excel模板导出excel、直接生成excel .Net NPOI 上传excel文件、提交后台获取excel里的数据

    ASP.NET Core 2.2 : 十六.扒一扒新的Endpoint路由方案   ASP.NET Core 从2.2版本开始,采用了一个新的名为Endpoint的路由方案,与原来的方案在使用上差别不 ...

随机推荐

  1. MongoDB中$redact操作符的使用

    介绍 redact <- redaction 修订/校验,意思是对文档内容进行过滤,选择一些过滤或保留的信息 . access level 存取等级 有三种: - $$DESCEND 返回当前等 ...

  2. IFC and BFC

    BFC and IFC 1,IFC -- 针对行内元素 -- 行内格式上下文 BFC --针对块级元素 -- 块级格式上下文 2,IFC特点: 行框的高度由包含元素的高度和有没有float元素决定. ...

  3. MVC中@Html.Action的用法(类似自定义控件)

    MVC项目中如果有公共部分的代码就可以单独拿出来作为控件来用(比如头部和底部代码).跟ASP.NET中的ASCX实现的效果一样,但MVC比它方便的多. 一.@Html.Action的用法 @Html. ...

  4. python 读取excel数据插入到另外一个excel

    #-*-coding:utf-8-*- import xlrd import xlwt def excel_copy(dir_from, dir_to, sheet_name): '''从一个exce ...

  5. HDU 1171 Big Event in HDU【01背包/求两堆数分别求和以后的差最小】

    Big Event in HDU Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) T ...

  6. 新疆大学ACM-ICPC程序设计竞赛五月月赛(同步赛)- XOR(二进制使用)

    链接:https://www.nowcoder.com/acm/contest/116/H来源:牛客网 题目描述 Once there was a king called XOR, he had a ...

  7. CQRS读写职责分离模式(Command and Query Responsibility Segregation (CQRS) Pattern)

    此文翻译自msdn,侵删. 原文地址:https://msdn.microsoft.com/en-us/library/dn568103.aspx 通过使用不同的接口来分离读和写操作,这种模式最大化了 ...

  8. SQL Server 2008 R2 SP3 and SQL Server 2008 SP4 are now available!

    时间 2014-10-02 00:00:00 SQL Server Team Blog   原文  http://blogs.technet.com/b/dataplatforminsider/arc ...

  9. 如何暂停sqlserver数据订阅服务

    原文:如何暂停sqlserver数据订阅服务 从 Management Studio 启动和停止快照代理或日志读取器代理 在 Management Studio 中连接到发布服务器,然后展开服务器节点 ...

  10. lodop 控件实现web打印功能

    WEB套打可选方案不多,理想的更少,利用免费控件Lodop+JavaScript实现精确套打,算是较为经典的选择.这种方案其实比较简单,利用一个htm文件就可以实现模板设计过程,几乎是“空手套”式的开 ...