使用NPOI和委托做EXCEL导出

首先,在用NPOI导出时,学习了邀月这篇文章NPOI根据Excel模板生成原生的Excel文件实例,在这里先行谢过了。

本篇文章在邀月的基本上,做了一些小的改动,加上委托的机制。因为在做导出时,加载模板,下载为EXCEL的代码相同,但是在设置EXCEL模板中的值时有很大的不同。所以以了一些小的改动。

改动后的主要类文件如下:

ExcelHelper:

View Code
public class ExcelHelper{private string templatePath;private string newFileName;private string templdateName;private string sheetName;public string SheetName{get { return sheetName; }set { sheetName = value; }}public ExcelHelper(string templdateName, string newFileName){this.sheetName = "sheet1";templatePath = HttpContext.Current.Server.MapPath("/") + "/Config/Template/";this.templdateName = string.Format("{0}{1}", templatePath, templdateName);this.newFileName = newFileName;}public void ExportDataToExcel(Action<HSSFSheet> actionMethod){using (MemoryStream ms = SetDataToExcel(actionMethod)){byte[] data = ms.ToArray();#region response to the clientHttpResponse response = System.Web.HttpContext.Current.Response;response.Clear();response.Charset = "UTF-8";response.ContentType = "application/vnd-excel";//"application/vnd.ms-excel";System.Web.HttpContext.Current.Response.AddHeader("Content-Disposition", string.Format("attachment; filename=" + newFileName));System.Web.HttpContext.Current.Response.BinaryWrite(data);#endregion}}private MemoryStream SetDataToExcel(Action<HSSFSheet> actionMethod){//Load template fileFileStream file = new FileStream(templdateName, FileMode.Open, FileAccess.Read);HSSFWorkbook workbook = new HSSFWorkbook(file);HSSFSheet sheet = workbook.GetSheet(SheetName);if (actionMethod != null) actionMethod(sheet);sheet.ForceFormulaRecalculation = true;using (MemoryStream ms = new MemoryStream()){workbook.Write(ms);ms.Flush();ms.Position = 0;sheet = null;workbook = null;return ms;}}}

PrintManager:

View Code
public class PrintManager{public void PrintPurchase(){ExcelHelper helper = new ExcelHelper("PurchaseOrder.xls", "PurchaseOrder_C000001.xls");helper.ExportDataToExcel(SetPurchaseOrder);}private void SetPurchaseOrder(HSSFSheet sheet){HSSFRow row = null;HSSFCell cell = null;row = sheet.GetRow(2);cell = row.GetCell(1);cell.SetCellValue("C0000001");cell = row.GetCell(7);cell.SetCellValue("2013-04-18");DataTable itemDT = PrepareItemDTForTest();SetDataTableValue(sheet, 7, 0, itemDT);row = sheet.GetRow(14);cell = row.GetCell(0);cell.SetCellValue("NOKIA");cell = row.GetCell(6);cell.SetCellValue("CMCC");}public void SetDataTableValue(HSSFSheet sheet, int rowIndex, int columnIndex,DataTable dt) {HSSFRow row = null;HSSFCell cell = null;foreach (DataRow dataRow in dt.Rows){row = sheet.GetRow(rowIndex);columnIndex = 0;foreach (DataColumn column in dt.Columns){cell = row.GetCell(columnIndex);string drValue = dataRow[column].ToString();switch (column.DataType.ToString()){case "System.String":cell.SetCellValue(drValue);break;case "System.DateTime":DateTime dateV;DateTime.TryParse(drValue, out dateV);cell.SetCellValue(dateV);break;case "System.Boolean":bool boolV = false;bool.TryParse(drValue, out boolV);cell.SetCellValue(boolV);break;case "System.Int16":case "System.Int32":case "System.Int64":case "System.Byte":int intV = 0;int.TryParse(drValue, out intV);cell.SetCellValue(intV);break;case "System.Decimal":case "System.Double":double doubV = 0;double.TryParse(drValue, out doubV);cell.SetCellValue(doubV);break;case "System.DBNull":cell.SetCellValue("");break;default:cell.SetCellValue("");break;}columnIndex++;}rowIndex++;}}private DataTable PrepareItemDTForTest() {DataTable itemDT = new DataTable();itemDT.Columns.Add("Name");itemDT.Columns.Add("Qty", Type.GetType("System.Decimal"));itemDT.Columns.Add("UnitPrice", Type.GetType("System.Decimal"));DataRow newRow = itemDT.NewRow();newRow[0] = "820";newRow[1] = "100";newRow[2] = "3000";itemDT.Rows.Add(newRow);DataRow newRow2 = itemDT.NewRow();newRow2[0] = "920";newRow2[1] = "100";newRow2[2] = "4000";itemDT.Rows.Add(newRow2);return itemDT;}}

备注:

ExcelHelper类:负责打开模板,调用传来的方法设置值,输出流。

PrintManager类:负责调用ExcelHelper然后到业务模块取数据,然后将业务数据填充到HSSFSheet中去。

 

效果

EXCEL模板:

导出的EXCEL:

DEMO下载:NopiTest.zip

转载于:https://www.cnblogs.com/dataadapter/archive/2013/04/18/3029433.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/266168.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

android 放大镜功能,简单实现Android放大镜效果

利用之前学过的图形图像绘画技术和图片添加特效技术&#xff0c;我们来实现一个Android放大镜的简单应用。最终效果如图具体实现:用来显示自定义的绘图类的布局文件res/layout/main.xml:xmlns:tools"http://schemas.android.com/tools"android:layout_width"fil…

android 音乐播放器的状态栏通知,Android仿虾米音乐播放器之通知栏notification解析...

通知栏notification是Android中一个很重要的组件&#xff0c;可以在顶部状态栏中存在&#xff0c;用户也可以通过此来操作应用&#xff0c;在Android中只有3.0以上的版本才加入了notification的按钮点击功能。先看一下仿虾米写出来的通知的效果这是一个自定义的notification&am…

mysql 查询语句_SQL语言mysql基础查询语句

单表查询、条件查询、查询并排序、限制结果查询、查询并排名、分组聚合查询、-- DQL操作&#xff0c;数据基本查询语言使用----------------------------------------------------------------------------------------------- -- 创建数据表-- 注释&#xff1a;员工编号&#…

mvdr波束形成原理_5G的“波束赋形”技术是什么东东?

工业互联网建设巳拉开帷幕&#xff0c;作为其“基础设施”的5G许多通信技术将发挥极大作用。波束赋形就是其中之一。电磁波发射波束、如不加人为干涉&#xff0c;是向其四周无死角散射&#xff0c;大部分是做无用功或浪费掉了。而5G的波束赋形技术、就是使用很多微型的毫米级天…

python 2 类与对象

1、类与对象的概念 类即类别、种类&#xff0c;是面向对象设计最重要的概念&#xff0c;从一小节我们得知对象是特征与技能的结合体&#xff0c;而类则是一系列对象相似的特征与技能的结合体。 那么问题来了&#xff0c;先有的一个个具体存在的对象&#xff08;比如一个具体存在…

mx4 pro 刷 原生 android,魅族MX4 Pro怎么刷机?通用刷机和固件升级教程

魅族MX4 Pro是一款性价比很高的手机&#xff0c;使用这款手机的用户也非常多。不过在魅族MX4 Pro的使用过程中&#xff0c;难免会出现系统方面的问题&#xff0c;又或者官方发布了新的固件升级包&#xff0c;这个时候就需要通过刷机的方法来解决问题或者升级魅族MX4 Pro固件。在…

#linux# su命令细节错误

2019独角兽企业重金招聘Python工程师标准>>> #前言# 在学习su命令时&#xff0c;几乎所有的国内书籍都说是切换用户功能。今天在linux系统下想开启httpd&#xff08;即Apache服务器&#xff09;&#xff0c;输入指令<code>service httpd start</code>结…

ASP.NET MVC5+EF6+EasyUI 后台管理系统(92)-打印EasyUI 的datagrid表格

前言 应用系统有时候需要打印Datagrid的表格内容&#xff0c;我们本节就来学习打印datagrid内容 打印主要使用&#xff1a;web打印&#xff08;我们之前有讲过web打印插件jqprint&#xff09; 将datagrid重新编制成可以打印的html格式 一、建立一个普通的例子 我们使用官方下载…

速读训练软件_记忆宫殿记忆力训练教程-第八天

第四部分 右脑开发及训练前面我们已经知道了右脑的记忆能力是左脑的100万倍&#xff0c;这可不是个小数字&#xff0c;如果我们能利用右脑来处理眼睛所收集到的信息&#xff0c;我们的记忆能力就会达到每分钟数万字的超级速度右脑不同于左脑的四种能力为&#xff1a;1、共振能力…

浅谈mysql的子查询

2019独角兽企业重金招聘Python工程师标准>>> mysql的子查询的优化一直不是很友好&#xff0c;一直有受业界批评比较多,也是我在sql优化中遇到过最多的问题之一&#xff0c;mysql在处理子查询的时候&#xff0c;会将子查询改写,通常情况下&#xff0c;我们希望由内到…

选择符合语义的html标签,最容易犯的HTML标签错误写法

我们最好开始注意了,因为HTML Police会走遍你的代码然后挑出你所有没有语义的标签,这份列表包含了10个最经常犯得HTML标签错误,记下他们,能够让我们避免犯此常见错误,让我们的HTML标签符合语义,和标准的要求.罪行1:把块级元素放入了行内元素内HTML 元素的表现方式不外乎就两种:…

Linux进程编程(PS: exec族函数、system、popen函数)

目录1.进程相关概念程序和进程查看系统中的进程ps指令top指令进程标识符 使用getpid()获取父进程&#xff0c;子进程2.创建进程fork进程创建发生了什么——C程序的存储空间如何分配3.创建进程vfork(区别fork)4.进程退出正常退出异常退出5.父进程等待子进程退出父进程收集子进程…

简练软考知识点整理-控制成本过程

控制成本是监督项目状态&#xff0c;以更新项目成本&#xff0c;管理成本基准变更的过程。本过程的主要作用是&#xff0c;发现实际与计划的差异&#xff0c;以便采取纠正措施&#xff0c;降低风险。要更新预算&#xff0c;就需要了解截至目前的实际成本。只有经过实施整体变更…

求一列数据中的波峰_PowerQuery:横向/纵向追加数据

上一篇文章都是在原表数据基础上的分分合合&#xff0c;但做数据分析的时候还经常需要在原有数据的基础上增加一些辅助数据&#xff0c;比如加入新列、新行&#xff0c;或者从其他表中添加进来更多维度的数据&#xff0c;这些就是数据丰富的过程。01添加列Power Query中添加列有…

HTML对字体的操作详解

摘自&#xff1a;HTML对字体的所有操作详解&#xff08;经典&#xff09; 作者&#xff1a;HeroKern 发布时间&#xff1a; 2016-01-31 21:15:31 网址&#xff1a;https://blog.csdn.net/qq_21792169/article/details/50615919/?utm_termhtml%E6%A0%87%E8%AE%B0%E5%AD%97%E4%B…

数学学习笔记-三角函数

1.圆的一周的弧度数为2π&#xff0c;360角2π弧度&#xff0c;1为π/180弧度 2.如下图&#xff0c;在一个直角三角形中 角A的对边为正对着的那个边a角A的邻边为另外一条直角边b角A的斜边为斜边c其中 正弦sin(A)对边/斜边余弦cos(A)邻边/斜边正切tan(A)对边/邻边正割csc(A)1/si…

云计算呼叫中心_SaaS云呼叫中心系统只用于销售或客服?

随着时代的发展&#xff0c;公司企业不一定有规模了才需要呼叫中心系统。SaaS云部署方式呼叫中心系统的出现&#xff0c;已经能够满足所有公司的需要&#xff0c;成本低、功能完善、效率高。公司电话管理系统通常大家的理解是&#xff0c;呼叫中心只是应用于针对营销部门或是客…

mvc4 html.pager,MVC分页之MvcPager使用详解

最近刚刚接触MVC不久&#xff0c;因项目中要用到分页&#xff0c;网上找了下资料&#xff0c;最后采用了MvcPager(http://www.webdiyer.com/),支持同步和Ajax异步分页。废话不多说了直接上代码。一.MvcPager异步 ViewModel:public class Article{[Display(Name "信息编号…

原生希望原生JavaScript开篇

本篇文章个人在深圳游玩的时候突然想到的...最近就有想写几篇关于原生希望的文章&#xff0c;所以回家到之后就奋笔疾书的写出来发布了 一直对前端技巧很有兴致&#xff0c;就心生了写一个专栏的动机&#xff0c;然后就申请了原生JavaScript这个专栏&#xff0c;旨在与大家同共…

POJ 1836 Alignment

有一排人&#xff0c;身高可能不同&#xff0c;现在有一个理想状态是这排的每个人向左或向右看没有被挡住视野(当遇到等高或更高的人时会被挡住)&#xff0c;现在问最少让几人出列可以达到这个理想状态。 最少人出列&#xff0c;其实就是一个人数最多的理想状态。求一个人数最多…