C#从实体对象集合中导出Excel的代码
发布时间:2020-12-15 05:59:47 所属栏目:百科 来源:网络整理
导读:或是将Datagrid或是Gridview的输出导出,实现大体上又分为调用COM+组件或是利用Response(当然是B/S架构的项目)的输出来做,COM+组件的方式以前在项目中也应用过,但说实话感觉效果并不好,一是布署很麻烦,二是当时记得好像WEB服务器端的有个进程老关不掉
或是将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 ExExcel<T>(List<T> objList,string FileName,Dictionary<string,string> columnInfo) { if (columnInfo.Count == 0) { return; } if (objList.Count == 0) { return; } //生成EXCEL的HTML string excelStr = ""; Type myType = objList[0].GetType(); //根据反射从传递进来的属性名信息得到要显示的属性 List<PropertyInfo> myPro = new List<PropertyInfo>(); 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(); } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |