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

时间:2022-03-15 05:47:54 

或是将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();
}
标签:C#,excel
0
投稿

猜你喜欢

  • java调用淘宝api联网查询ip归属地

    2022-06-11 12:21:20
  • C# 线程安全详解

    2023-02-07 10:40:46
  • springboot整合solr的方法详解

    2023-01-20 17:54:37
  • Java ArrayList与LinkedList使用方法详解

    2023-08-12 08:23:46
  • java框架之maven是用来做什么的

    2023-04-20 21:59:43
  • Android贝塞尔曲线初步学习第二课 仿QQ未读消息气泡拖拽黏连效果

    2023-08-18 10:18:20
  • 关于MD5算法原理与常用实现方式

    2023-03-18 11:09:04
  • C#实现快速排序算法

    2023-03-20 08:41:51
  • java分割文本字符串的方法

    2023-11-13 03:52:24
  • Spring定时任务中@PostConstruct被多次执行异常的分析与解决

    2022-08-20 07:28:22
  • 如何把本地jar包导入maven并pom添加依赖

    2021-12-31 04:11:28
  • Java实现获取内网的所有IP地址

    2023-01-01 07:48:56
  • C# goto语句的具体使用

    2021-07-22 22:26:22
  • Java程序设计之12个经典样例

    2022-09-22 18:44:00
  • C#中this指针的用法示例

    2021-07-21 14:12:24
  • 关于各种排列组合java算法实现方法

    2023-11-15 05:46:55
  • Flutter Widgets之标签类控件Chip详解

    2023-06-26 14:22:35
  • 详解Struts2动态方法调用

    2022-10-18 11:19:25
  • java实现电话本管理系统

    2023-10-11 14:51:19
  • SpringBoot实现多个子域共享cookie的示例

    2021-08-02 17:56:47
  • asp之家 软件编程 m.aspxhome.com