將DataSet數據表導入到EXCEL表格中

本文介绍如何使用ASP.NET中的GridView控件将数据导出到Excel文件的方法,并提供了解决导出过程中可能出现的问题的方案,如关闭事件验证及解决分页报错等问题。

 

#region導入EXCLE功能
        protected void Bt_Creat_Click(object sender, EventArgs e)
        {
            Response.Clear();
            Response.Buffer = true;
            Response.Charset = "UTF-8";
            Response.AppendHeader("Content-Disposition", "attachment;filename=FileName.xls");
            Response.ContentEncoding = System.Text.Encoding.UTF8;
 
            //設置輸出文件類型為excel文件
            Response.ContentType = "application/ms-excel";
            StringWriter sw = new StringWriter();
            HtmlTextWriter hw = new HtmlTextWriter(sw);
 
            GVControl.RenderControl(hw);
            Response.Output.Write(sw.ToString());
            Response.Flush();
            Response.End();
 
        }
        #endregion
 
如果出現控件GridView必須放在帶有runat=server的標記表單中
則解決方法是:重載裡面系統自帶的VerifyRenderingInServerForm方法
#region重載VerifyRenderingInServerForm方法
        public override void VerifyRenderingInServerForm(Control control)
        {
            //base.VerifyRenderingInServerForm(control);
        }
        #endregion
 
分頁報錯:
如果再報錯,解決方案如下:
只能在执行 Render() 的过程中调用问题之解决方案
只能在执行 Render() 的过程中调用 RegisterForEventValidation(RegisterForEventValidation can only be called during Render(); )
当用GridView导出Execl的时候,会发生只能在执行 Render() 的过程中调用 RegisterForEventValidation的错误提示。
有两种方法可以解决以上问题:
1.
修改web.config(不推荐)<pages enableEventValidation ="false" ></pages>
2.
直接在导出Execl的页面修改
<%@ Page Language="C#"  
EnableEventValidation = "false"  AutoEventWireup="true"
CodeFile="ExportGridView.aspx.cs"  Inherits="ExportGridView" %>
 
代碼:
#region導入EXCLE功能
        protected void Bt_Creat_Click(object sender, EventArgs e)
        {
 
            GVControl.AllowPaging = false;
            this.GVControl.DataSource = (DataSet)Session["DataView"];
            GVControl.DataBind();
 
            Response.Clear();
            Response.Buffer = true;
 
            Response.Charset = "utf-8";
 
            //設置輸出文件類型為excel文件
            Response.AddHeader("Content-Disposition", "attachment;filename=FileFlow.xls");
            Response.ContentType = "application/ms-excel";
            StringWriter sw = new StringWriter();
            HtmlTextWriter hw = new HtmlTextWriter(sw);
 
 
            GVControl.RenderControl(hw);
            Response.Write(sw.ToString());
            Response.End();
 
            GVControl.AllowPaging = true;
            this.GVControl.DataSource = (DataSet)Session["DataView"];
            GVControl.DataBind();
 
 
        }
        #endregion
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值