ASP.NET 2.0中将 GridView 导出到 Excel 文件中

系统 1828 0

下面代码实现将 GridView 导出到 Excel文件中。

值得注意的是VerifyRenderingInServerForm重载方法:
  MSDN上的 VerifyRenderingInServerForm 方法的描述:
  必须位于 <form runat=server> 标记中的控件可以在呈现之前调用此方法,以便在控件被置于标记外时显示错误信息。发送回或依赖于注册的脚本块的控件应该在 Control.Render 方法的重写中调用此方法。呈现服务器窗体元素的方式不同的页可以重写此方法以在不同的条件下引发异常。
  如果回发或使用客户端脚本的服务器控件没有包含在 HtmlForm 服务器控件 (<form runat="server">) 标记中,它们将无法正常工作。这些控件可以在呈现时调用该方法,以在它们没有包含在 HtmlForm 控件中时提供明确的错误信息。
  开发自定义服务器控件时,通常在为任何类型的输入标记重写 Render 方法时调用该方法。这在输入控件调用 GetPostBackEventReference 或发出客户端脚本时尤其重要。复合服务器控件不需要作出此调用。

没有这个方法,程序将报错。

C# 代码

<% @ Page Language = " C# " EnableEventValidation = " false " %>

<! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"
>

< script runat ="server" >
   ICollection CreateDataSource( )
{

     System.Data.DataTable dt
= new System.Data.DataTable();
     System.Data.DataRow dr;
     dt.Columns.Add(
new System.Data.DataColumn( " id " , typeof (Int32)));
     dt.Columns.Add(
new System.Data.DataColumn( " PkID " , typeof (string)));
     dt.Columns.Add(
new System.Data.DataColumn( " Title " , typeof (string)));
    
for ( int i = 0 ; i < 6 ; i ++ )
    {

       dr
= dt.NewRow();
       dr[
0 ] = i;
       dr[
1 ] = " 123456789123456789123456789 " ;
       dr[
2 ] = " <a href='http://dotnet.aspx.cc/'>欢迎光临【孟宪会之精彩世界】</a> " ;
       dt.Rows.Add(dr);
     }

     System.Data.DataView dv
= new System.Data.DataView(dt);
    
return dv;
   }


   protected
void Page_Load( object sender, EventArgs e )
{

    
if ( ! IsPostBack)
{

       GridView1.BorderWidth
= Unit.Pixel( 2 );
       GridView1.BorderColor
= System.Drawing.Color.DarkOrange;
       GridView1.DataSource
= CreateDataSource();
       GridView1.DataBind();
     }

   }


   protected
void Button1_Click( object sender, System.EventArgs e )
{

     Response.Clear();
     Response.Buffer
= true ;
     Response.Charset
= " GB2312 " ;
     Response.AppendHeader(
" Content-Disposition " , " attachment;filename=FileName.xls " );
    
// 如果设置为 GetEncoding("GB2312");导出的文件将会出现乱码!!!
     Response.ContentEncoding = System.Text.Encoding.UTF7;
     Response.ContentType
= " application/ms-excel " ; // 设置输出文件类型为excel文件。
     System.IO.StringWriter oStringWriter = new System.IO.StringWriter();
     System.Web.UI.HtmlTextWriter oHtmlTextWriter
= new System.Web.UI.HtmlTextWriter(oStringWriter);
    
this .GridView1.RenderControl(oHtmlTextWriter);
     Response.Output.Write(oStringWriter.ToString());
     Response.Flush();
     Response.End();

   }

   public override
void VerifyRenderingInServerForm( Control control )
{ }
   protected
void GridView1_RowDataBound( object sender, GridViewRowEventArgs e )
{
    
if (e.Row.RowType == DataControlRowType.DataRow)
   
{
       e.Row.Cells[
1 ].Attributes.Add( " style " , " vnd.ms-excel.numberformat:@; " );
     }

   }

</ script >

< html xmlns ="http://www.w3.org/1999/xhtml" >
< head runat ="server" >
  
< title > 将 GridView 导出到 Excel 文件中 </ title >
</ head >
< body >
  
< form id ="form1" runat ="server" >
    
< asp:GridView ID ="GridView1" runat ="server" OnRowDataBound ="GridView1_RowDataBound"
       AutoGenerateColumns
="false" >
      
< Columns >
        
< asp:BoundField HeaderText ="序号" DataField ="id" />
        
< asp:BoundField HeaderText ="身份证号" DataField ="PkID" />
        
< asp:BoundField HeaderText ="网址" DataField ="Title" ReadOnly ="true" HtmlEncode ="false" />
      
</ Columns >
    
</ asp:GridView >
    
< asp:Literal ID ="HiddenOut" runat ="server" />
    
< asp:Button ID ="Button1" runat ="server" Text ="导出" OnClick ="Button1_Click" />
  
</ form >
</ body >
</ html >

 

另一个简单的方法:

导出Excel按钮的点击事件:

private void btnMIME_CLick(object sender,System.Targetargs e)
{
Response.ContentType="application/vnd.ms-excel");
Response.Charset="";
this.EnableViewState=false;
System.IO.StringWriter sw=new StringWriter();
System.Web.UI.HtmlTextWriter hw=new HtmlTextWriter(sw);
dsShow.RenderControl(hw);
Response.Write(sw.ToString());
Response.End();
}

ASP.NET 2.0中将 GridView 导出到 Excel 文件中


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论