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

本文介绍了一个使用ASP.NET的GridView控件将数据导出至Excel文件的方法。通过C#和VB.NET示例代码展示了如何设置响应头、编码及内容类型,并利用HtmlTextWriter进行数据渲染。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

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

C# 代码

&lt;%@ Page Language=&quot;C#&quot; EnableEventValidation=&quot;false&quot; %&gt;
&lt;!DOCTYPE html PUBLIC &quot;-//W3C//DTD XHTML 1.0 Transitional//EN&quot;
&quot;http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd&quot;&gt;
&lt;script runat=&quot;server&quot;&gt;
ICollection CreateDataSource( )
{
System.Data.DataTable dt = new System.Data.DataTable();
System.Data.DataRow dr;
dt.Columns.Add(new System.Data.DataColumn(&quot;id&quot;, typeof(Int32)));
dt.Columns.Add(new System.Data.DataColumn(&quot;PkID&quot;, typeof(string)));
dt.Columns.Add(new System.Data.DataColumn(&quot;Title&quot;, typeof(string)));
for (int i = 0; i &lt; 6; i++)
{
dr = dt.NewRow();
dr[0] = i;
dr[1] = &quot;123456789123456789123456789&quot;;
dr[2] = &quot;&lt;a href='http://dotnet.aspx.cc/'&gt;欢迎光临【孟宪会之精彩世界】&lt;/a&gt;&quot;;
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 = &quot;GB2312&quot;;
Response.AppendHeader(&quot;Content-Disposition&quot;, &quot;attachment;filename=FileName.xls&quot;);
// 如果设置为 GetEncoding(&quot;GB2312&quot;);导出的文件将会出现乱码!!!
Response.ContentEncoding = System.Text.Encoding.UTF7;
Response.ContentType = &quot;application/ms-excel&quot;;//设置输出文件类型为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(&quot;style&quot;, &quot;vnd.ms-excel.numberformat:@;&quot;);
}
}
&lt;/script&gt;
&lt;html xmlns=&quot;http://www.w3.org/1999/xhtml&quot;&gt;
&lt;head runat=&quot;server&quot;&gt;
&lt;title&gt;将 GridView 导出到 Excel 文件中&lt;/title&gt;
&lt;/head&gt;
&lt;body&gt;
&lt;form id=&quot;form1&quot; runat=&quot;server&quot;&gt;
&lt;asp:GridView ID=&quot;GridView1&quot; runat=&quot;server&quot; OnRowDataBound=&quot;GridView1_RowDataBound&quot;
AutoGenerateColumns=&quot;false&quot;&gt;
&lt;Columns&gt;
&lt;asp:BoundField HeaderText=&quot;序号&quot; DataField=&quot;id&quot; /&gt;
&lt;asp:BoundField HeaderText=&quot;身份证号&quot; DataField=&quot;PkID&quot; /&gt;
&lt;asp:BoundField HeaderText=&quot;网址&quot; DataField=&quot;Title&quot; ReadOnly=&quot;true&quot; HtmlEncode=&quot;false&quot; /&gt;
&lt;/Columns&gt;
&lt;/asp:GridView&gt;
&lt;asp:Literal ID=&quot;HiddenOut&quot; runat=&quot;server&quot; /&gt;
&lt;asp:Button ID=&quot;Button1&quot; runat=&quot;server&quot; Text=&quot;导出&quot; OnClick=&quot;Button1_Click&quot; /&gt;
&lt;/form&gt;
&lt;/body&gt;
&lt;/html&gt;

VB.NET 代码

&lt;%@ Page Language=&quot;VB&quot; %&gt;
&lt;!DOCTYPE html PUBLIC &quot;-//W3C//DTD XHTML 1.0 Transitional//EN&quot;
&quot;http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd&quot;&gt;
&lt;script runat=&quot;server&quot;&gt;
Function CreateDataSource() As ICollection
Dim dt As System.Data.DataTable = New System.Data.DataTable
Dim dr As System.Data.DataRow
dt.Columns.Add(New System.Data.DataColumn(&quot;id&quot;, GetType(Int32)))
dt.Columns.Add(New System.Data.DataColumn(&quot;PkID&quot;, GetType(String)))
dt.Columns.Add(New System.Data.DataColumn(&quot;Title&quot;, GetType(String)))
Dim i As Integer = 0
While i &lt; 6
dr = dt.NewRow
dr(0) = i
dr(1) = &quot;123456789123456789123456789&quot;
dr(2) = &quot;&lt;a href='http://dotnet.aspx.cc/'&gt;欢迎光临【孟宪会之精彩世界】&lt;/a&gt;&quot;
dt.Rows.Add(dr)
System.Math.Min(System.Threading.Interlocked.Increment(i),i-1)
End While
Dim dv As System.Data.DataView = New System.Data.DataView(dt)
Return dv
End Function
Protected Sub Page_Load(ByVal sender As Object, ByVal e As EventArgs)
If Not IsPostBack Then
GridView1.BorderWidth = Unit.Pixel(2)
GridView1.BorderColor = System.Drawing.Color.DarkOrange
GridView1.DataSource = CreateDataSource
GridView1.DataBind
End If
End Sub
Protected Sub Button1_Click(ByVal sender As Object, ByVal e As System.EventArgs)
Response.Clear
Response.Buffer = True
Response.Charset = &quot;GB2312&quot;
Response.AppendHeader(&quot;Content-Disposition&quot;, &quot;attachment;filename=FileName.xls&quot;)
Response.ContentEncoding = System.Text.Encoding.UTF7
Response.ContentType = &quot;application/ms-excel&quot;
Dim oStringWriter As System.IO.StringWriter = New System.IO.StringWriter
Dim oHtmlTextWriter As System.Web.UI.HtmlTextWriter = New System.Web.UI.HtmlTextWriter(oStringWriter)
Me.GridView1.RenderControl(oHtmlTextWriter)
Response.Output.Write(oStringWriter.ToString)
Response.Flush
Response.End
End Sub
Public Overloads Overrides Sub VerifyRenderingInServerForm(ByVal control As Control)
End Sub
Protected Sub GridView1_RowDataBound(ByVal sender As Object, ByVal e As GridViewRowEventArgs)
If e.Row.RowType = DataControlRowType.DataRow Then
e.Row.Cells(1).Attributes.Add(&quot;style&quot;, &quot;vnd.ms-excel.numberformat:@;&quot;)
End If
End Sub
&lt;/script&gt;
&lt;html xmlns=&quot;http://www.w3.org/1999/xhtml&quot;&gt;
&lt;head id=&quot;Head1&quot; runat=&quot;server&quot;&gt;
&lt;title&gt;将 GridView 导出到 Excel 文件中&lt;/title&gt;
&lt;/head&gt;
&lt;body&gt;
&lt;form id=&quot;form1&quot; runat=&quot;server&quot;&gt;
&lt;asp:GridView ID=&quot;GridView1&quot; runat=&quot;server&quot; OnRowDataBound=&quot;GridView1_RowDataBound&quot;
AutoGenerateColumns=&quot;false&quot;&gt;
&lt;Columns&gt;
&lt;asp:BoundField HeaderText=&quot;序号&quot; DataField=&quot;id&quot; /&gt;
&lt;asp:BoundField HeaderText=&quot;身份证号&quot; DataField=&quot;PkID&quot; /&gt;
&lt;asp:BoundField HeaderText=&quot;网址&quot; DataField=&quot;Title&quot; ReadOnly=&quot;true&quot; HtmlEncode=&quot;false&quot; /&gt;
&lt;/Columns&gt;
&lt;/asp:GridView&gt;
&lt;asp:Literal ID=&quot;HiddenOut&quot; runat=&quot;server&quot; /&gt;
&lt;asp:Button ID=&quot;Button1&quot; runat=&quot;server&quot; Text=&quot;导出&quot; OnClick=&quot;Button1_Click&quot; /&gt;
&lt;/form&gt;
&lt;/body&gt;
&lt;/html&gt;
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值