C#从实体对象集合中导出Excel的代码

2016-02-19 10:16 6 1 收藏

今天给大家分享的是由图老师小编精心为您推荐的C#从实体对象集合中导出Excel的代码,喜欢的朋友可以分享一下,也算是给小编一份支持,大家都不容易啊!

【 tulaoshi.com - 编程语言 】

或是将Datagrid或是Gridview的输出导出,实现大体上又分为调用COM+组件或是利用Response(当然是B/S架构的项目)的输出来做,COM+组件的方式以前在项目中也应用过,但说实话感觉效果并不好,一是布署很麻烦,二是当时记得好像WEB服务器端的有个进程老关不掉,并且还有个问题是服务器端安装的EXCEL版本的不同,在程序中调用的方法传入的参数个数都不相同,真是够郁闷的,但是好处是这种方式当然是最灵活的。

我们还是以一个B/S架构的项目应用来说说导出吧,通用一点儿的还是从数据集往外导出吧,毕竟将Gridview的输出导出来这种方式个人感觉适用性不高,因为大部分情况我们的页面中的运用Gridview都是要牵扯分页的,我们还是直接来做从数据集往外导吧,从DataTable往外导网上很多现成的,但是运用在一个严格分层架构的项目中,还是会有些不爽的,假如我们严格要求我们的项目是标准的三层架构,我们层与层之间传递的是我们的实体对象,我们不传递DataTable这种弱类型的东东,那我们导出的数据源就只能是实体对象集合了,于是,我们需要写一个以实体对象为数据源的导出方法,感觉还是不太完美,比如在参数中“导出列信息”参数的设计,感觉还有更好的方式,呵呵,以后有空再想吧!

贴出我的实现,大家也帮忙看看!
代码如下:


/// summary
/// 将一组对象导出成EXCEL
/// /summary
/// typeparam name="T"要导出对象的类型/typeparam
/// param name="objList"一组对象/param
/// param name="FileName"导出后的文件名/param
/// param name="columnInfo"列名信息/param
public static void ExExcelT(ListT objList, string FileName, Dictionarystring, string columnInfo)
{

if (columnInfo.Count == 0) { return; }
if (objList.Count == 0) { return; }
//生成EXCEL的HTML
string excelStr = "";

Type myType = objList[0].GetType();
//根据反射从传递进来的属性名信息得到要显示的属性
ListPropertyInfo myPro = new ListPropertyInfo();
foreach (string cName in columnInfo.Keys)
{
PropertyInfo p = myType.GetProperty(cName);
if (p != null)
{
myPro.Add(p);
excelStr += columnInfo[cName] + "t";
}
}
//如果没有找到可用的属性则结束
if (myPro.Count == 0) { return; }
excelStr += "n";

foreach (T obj in objList)
{
foreach (PropertyInfo p in myPro)
{
excelStr += p.GetValue(obj, null)+"t";
}
excelStr += "n";
}

//输出EXCEL
HttpResponse rs = System.Web.HttpContext.Current.Response;
rs.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");
rs.AppendHeader("Content-Disposition", "attachment;filename=" + FileName);
rs.ContentType = "application/ms-excel";
rs.Write(excelStr);
rs.End();
}

来源:https://www.tulaoshi.com/n/20160219/1594025.html

延伸阅读
摘要:本文介绍了Excel对象、C#中的受管代码和非受管代码,并介绍了COM组件在.NET环境中的使用。 关键词:受管代码;非受管代码;Excel对象;动态连接库 引言 Excel是微软公司办公自动化套件中的一个软件,他主要是用来处理电子表格。Excel以其功能强大,界面友好等受到了许多用户的欢迎。在设计应用系统时,对于不同的用户...
C#是纯粹的面向对象编程语言,它真正体现了一切皆为对象的精神。在C#中,即使是最基本的数据类型,如int,double,bool类型,都属于System.Object类型。此外,使用C#编程,不会存在与游离于对象之外的属于过程的东西。因此,学习C#,就必须具有面向对象思想,不明白所谓的面向对象思想,就不可能掌握C#的精髓,而对于C#的理解,就只能仅限...
关于Aspx中导Excel,网上的方法比较的多,而最主要的是用Com的控件,小弟以前也是用有如此之方法,不过嘛,这种方法有一些小小的缺点,比如:必须要进行某种复杂的注册,而且在效率上可能也会比较的慢一些,所以,小弟用了一种变通的方法,效果还不错,不敢独留,所以与大家共同分享之。 我们知道,在做Web的程序中有一个非常大的好处就是...
类(class)是C#类型中最基础的类型。类是一个数据结构,将状态(字段)和行为(方法和其他函数成员)组合在一个单元中。类提供了用于动态创建类实例的定义,也就是对象(object)。类支持继承(inheritance)和多态(polymorphism),即派生类能够扩展和特殊化基类的机制。使用类声明可以创建新的类。类声明以一个声明头开始,其组成方式如...
1.先通过程序生成报表样式的HTML页面,然后修改HTML页面的后缀名为DOC。 2.定制WORD文档的模板文件,在C#中操作WORD模板,生成新的WORD文档。 第一方案简单,只需要改动文件的扩展名就行了,但是也存在了一些问题,譬如生成的WORD文档样式的丢失。这样对于客户来说可能是一个无法通过的方案。第二方案比较复杂,需要调用OFFICE的WORD组件通过C...

经验教程

567

收藏

63
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部