我们还是以一个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的@R_419_6832@
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的代码全部内容,希望文章能够帮你解决C#从实体对象集合中导出Excel的代码所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)