Gridview 分多页时导出excel的解决方案

时间:2021-11-17 13:51:22

在开发会遇到将gridview中的数据导入到excel 这样的需求,当girdview有多页数据时按照一般的方式导出的数据只可能是当前页的数据,后几页的数据还在数据库内,没有呈现到页面上,传统的方式是将标记字符和文本写入到 ASP.NET 服务器控件输出流,没有呈现的页面不可能输出到excel中。下面提供一种解决方式将所以数据都能导入到excel中。

第一步:记录查询条件,当用户点击下载的时候以相同的条件查询,呈现到datatable

这一步没有固定的代码,可以在用户查询的时候用ViewState记录查询条件,例如

OrderMng.OrderList_GetSupOrderList_BindData( Param, fDynamicParam, PageParamByCus, dystr);(查询出单页的数据绑定到girdview)
 ViewState["GParam"] = Param; ViewState["DPaRam"] = fDynamicParam; ViewState["PageParam"] = PageParamByCus; ViewState["strparam"] = dystr;(记录查询条件)

用户点下载的时候再以相同的条件,查询出所有数据到datatable

Hashtable GParam = (Hashtable)ViewState["GParam"];
   Hashtable DPaRam = (Hashtable)ViewState["DPaRam"]; 
   Hashtable PageParam= (Hashtable)ViewState["PageParam"];
   string strparam=ViewState["strparam"].ToString();

是将开始查询的条件转化回来
    DataTable  dt = OrderMng.OrderList_GetSupOrderList(GParam, DPaRam, PageParam, strparam);

相同的条件查询后到datatable

  第二步:处理datatable , 修改列名,排序,修改显示的内容

代码
Gridview 分多页时导出excel的解决方案
}
Gridview 分多页时导出excel的解决方案

 第三步:将datatable转化成excel

代码
Gridview 分多页时导出excel的解决方案
publicstaticvoid TableToExcel(DataTable tb,string fileName)
{
string Filename = fileName;
System.Web.HttpContext context = System.Web.HttpContext.Current;
if ((tb !=null))
{
context.Response.Clear();
context.Response.Charset ="GB2312";
context.Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");
context.Response.ContentType ="application/ms-excel";
context.Response.AppendHeader("content-disposition", "attachment;filename=\"" + System.Web.HttpUtility.UrlEncode(Filename, System.Text.Encoding.GetEncoding("GB2312")) +DateTime.Now.ToString("yyyyMMdd")+ ".xls\"");

CultureInfo cult =new CultureInfo("zh-CN", true);
StringWriter sw =new StringWriter(cult);
HtmlTextWriter htw =new HtmlTextWriter(sw);
DataGrid dgrid =new DataGrid();
dgrid.DataSource = tb.DefaultView;
dgrid.AllowPaging =false;
dgrid.DataBind();
htw.WriteLine("<meta http-equiv=\"Content-Type\" content=\"text/html;charset=GB2312\">");
dgrid.RenderControl(htw);
context.Response.Write(sw.ToString());
context.Response.End();
}
}