將DataSet數據表導入到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、付费专栏及课程。

余额充值