工作总结 npoi 模板 导出公式 excel
Apache POI(5):公式(formula)
Apache POI(5):公式(formula)
- package com.hthk.iisz.util;
- import java.io.File;
- import java.io.FileOutputStream;
- import org.apache.poi.xssf.usermodel.XSSFCell;
- import org.apache.poi.xssf.usermodel.XSSFRow;
- import org.apache.poi.xssf.usermodel.XSSFSheet;
- import org.apache.poi.xssf.usermodel.XSSFWorkbook;
- public class FormulaTest {
- public static void main(String[] args) throws Exception {
- formula();
- }
- public static void formula() throws Exception {
- XSSFWorkbook workbook = new XSSFWorkbook();
- XSSFSheet sheet = workbook.createSheet("formula");
- XSSFRow row = sheet.createRow(1);
- XSSFCell cell = row.createCell(1);
- cell.setCellValue("A =");
- cell = row.createCell(2);
- cell.setCellValue(2);
- row = sheet.createRow(2);
- cell = row.createCell(1);
- cell.setCellValue("B =");
- cell = row.createCell(2);
- cell.setCellValue(4);
- row = sheet.createRow(3);
- cell = row.createCell(1);
- cell.setCellValue("Total =");
- cell = row.createCell(2);
- // create sum formula
- cell.setCellType(XSSFCell.CELL_TYPE_FORMULA);
- cell.setCellFormula("SUM(C2:C3)");
- cell = row.createCell(3);
- cell.setCellValue("SUM(C2:C3)");
- row = sheet.createRow(4);
- cell = row.createCell(1);
- cell.setCellValue("POWER =");
- cell = row.createCell(2);
- // create power formula
- cell.setCellType(XSSFCell.CELL_TYPE_FORMULA);
- cell.setCellFormula("POWER(C2,C3)");
- cell = row.createCell(3);
- cell.setCellValue("POWER(C2,C3)");
- row = sheet.createRow(5);
- cell = row.createCell(1);
- cell.setCellValue("MAX =");
- cell = row.createCell(2);
- // Create MAX formula
- cell.setCellType(XSSFCell.CELL_TYPE_FORMULA);
- cell.setCellFormula("MAX(C2,C3)");
- cell = row.createCell(3);
- cell.setCellValue("MAX(C2,C3)");
- row = sheet.createRow(6);
- cell = row.createCell(1);
- cell.setCellValue("FACT =");
- cell = row.createCell(2);
- // Create FACT formula
- cell.setCellType(XSSFCell.CELL_TYPE_FORMULA);
- cell.setCellFormula("FACT(C3)");
- cell = row.createCell(3);
- cell.setCellValue("FACT(C3)");
- row = sheet.createRow(7);
- cell = row.createCell(1);
- cell.setCellValue("SQRT =");
- cell = row.createCell(2);
- // Create SQRT formula
- cell.setCellType(XSSFCell.CELL_TYPE_FORMULA);
- cell.setCellFormula("SQRT(C5)");
- cell = row.createCell(3);
- cell.setCellValue("SQRT(C5)");
- workbook.getCreationHelper().createFormulaEvaluator().evaluateAll();
- FileOutputStream out = new FileOutputStream(new File("formula.xlsx"));
- workbook.write(out);
- out.close();
- System.out.println("fromula.xlsx written successfully");
- }
- }
效果截图
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的更多相关文章
- c#使用NPOI快速导出到Excel
接上篇博文<C#快速导出到excel>:由于此种方法不能导出成.xlsx格式,为解决此问题,本次分享使用NPOI. 参考:https://www.cnblogs.com/lazyneal/ ...
- c#.net 使用NPOI导入导出标准Excel (asp.net winform csharp)
尝试过很多Excel导入导出方法,都不太理想,无意中逛到oschina时,发现了NPOI,无需Office COM组件且不依赖Office,顿时惊为天人,怀着无比激动的心情写下此文. 曾使用过的方法 ...
- ASP.NET- 使用NPOI导入导出标准Excel
尝试过很多Excel导入导出方法,都不太理想,无意中逛到oschina时,发现了NPOI,无需Office COM组件且不依赖Office,顿时惊为天人,怀着无比激动的心情写下此文. 曾使用过的方法 ...
- 使用NPOI导入导出标准Excel
尝试过很多Excel导入导出方法,都不太理想,无意中逛到oschina时,发现了NPOI,无需Office COM组件且不依赖Office,顿时惊为天人,怀着无比激动的心情写下此文. 曾使用过的方法 ...
- NPOI 设置导出的excel内容样式
导出excel时,有时要根据需要加上一些样式,以上几种样式是我在项目中用到的 一.给单元格加背景色只需两步:一是创建单元格背景景色对象:二是给单元格绑定样式 //创建单元格背景颜色对象 HSSFPal ...
- 使用NPOI快速导出导入Excel
这两天做项目需要导入导出EXCEL,是基于NPOI的封装,设计思路是使用DataTable,然后导出一个和DataTable一模一样的Excel表出来 github地址:https://github. ...
- NOPI读取模板导出(Excel中追加数据)
在Controller里,我们定义一个FileResult的Action,返回值是一个文件形式被浏览器下载下来. [HttpGet] public FileResult ExportProductLi ...
- asp.net Mvc Npoi 导出导入 excel
因近期项目遇到所以记录一下: 首先导出Excel : 首先引用NPOI包 http://pan.baidu.com/s/1i3Fosux (Action一定要用FileResult) /// < ...
- 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的路由方案,与原来的方案在使用上差别不 ...
随机推荐
- python 实现经典算法
import time start_time = time.clock() list_ = [9, 2, 7, 4, 5, 6, 3, 8, 1] """ # 堆排序(通 ...
- Laravel 添加自定义辅助函数
1. 在 app 目录下新建一个文件 helpers.php 2. 在 composer.json 文件的 autoload 字典中添加 "files":["app/he ...
- (3)oracle建用户、建表、权限、命名空间
一.表空间 创建表空间 create tablespace ts001 datafile ‘d:\test\a.dbf’ size 20m uniform size 128k; 使用表空间 cre ...
- 51nod 1596 搬货物【贪心/二进制】
1596 搬货物 题目来源: CodeForces 基准时间限制:1 秒 空间限制:131072 KB 分值: 10 难度:2级算法题 收藏 取消关注 现在有n个货物,第i个货物的重量是 2wi ...
- 2018 JUST Programming Contest 1.0 题解
题目链接 gym101778 Problem A 转化成绝对值之后算一下概率.这个题有点像 2018 ZOJ Monthly March Problem D ? 不过那个题要难一些~ #includ ...
- 数值计算方法 | C语言实现几个数值计算方法(实验报告版)
目录 写在前面 实验一 牛顿插值方法的实现 实验二 龙贝格求积算法的实现 实验三 高斯列主元消去法的实现 实验四 最小二乘方法的实现 写在前面 使用教材:<数值计算方法>黄云清等编著 科学 ...
- ReactNative学习笔记1 Flexbox布局
一.比例属性flex和布局方向属性flexDirection 例如三个视图的flex属性值分别为2.4.8,则它们的高度比例为2:4:8.,宽度不指定,默认为全屏的宽度. class ZLFReact ...
- 删除VisualStudio 2013中的 "send Feedback" 按钮
在VisualStudio 2013中,在标题栏中增加了一个 "send Feedback" 按钮,用于给微软发送Bug和回馈(或者一个哭脸和笑脸).这个按钮对于开发来说基本上没用 ...
- sqlite db-journal文件产生原因及说明
今天在Android中将sqlite的数据库文件生成在SD卡上的过程中,发现生成的.db文件的旁边 生成了一个大小为0的与数据库文件同名的.db-journal文件,不明白此文件的用途,于是 goog ...
- JAVA常见算法题(十七)
package com.xiaowu.demo; //输出九九乘法表. public class Demo17 { public static void main(String[] args) { t ...