或是将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#实现猜数字游戏
本文实例为大家分享了c#实现猜数字游戏具体代码,供大家参考,具体内容如下给定一个0-100的随机数字猜其大小题目样式:电脑产生一个0到100之间的随机数字,并且...
[阅读全文]
-
-
C# 可空类型的具体使用
在项目中我们经常会遇到可为空类型,那么到底什么是可为空类型呢?下面我们将从4个方面为大家剖析。1、可空类型基础知识顾名思义,可空类型指的就是某个对象类型可以为空...
[阅读全文]
-
-
-
C#实现猜数字小游戏
本文实例为大家分享了c#实现猜数字小游戏的具体代码,供大家参考,具体内容如下效果如图:代码:using system;using system.collecti...
[阅读全文]
-
-
C#实现简单俄罗斯方块
最近在看《.net游戏编程入门经典 c#篇》 第一章介绍了如何制作俄罗斯方块,自己试了试按照书上的步骤,可算是完成了。于是写下这篇文章留作纪念。1.类的设计在充...
[阅读全文]
-
-
网友评论