Gridview导出到excel

直接上代码:

protected void btnExport_Click(object sender, EventArgs e)
        {
            toExcel(this.GridView1);
        }

        void toExcel(GridView gv)
        {
            Response.Charset = "GB2312";
            Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");

            string fileName = "export.xls";
            string style = @"<style> .text { mso-number-format:\@; } </script> ";
            Response.ClearContent();
            Response.AddHeader("content-disposition", "attachment; filename=" + fileName);
            Response.ContentType = "application/excel";
            StringWriter sw = new StringWriter();
            HtmlTextWriter htw = new HtmlTextWriter(sw);
            gv.RenderControl(htw);
            Response.Write(style);
            Response.Write(sw.ToString());
            Response.End();
        }

        /// <summary>
        /// 这个重写貌似是必须的
        /// </summary>
        /// <param name="control"></param>
        public override void VerifyRenderingInServerForm(Control control) { }

其中GridView1是你要导出的到excel的gridview。

运行时可能会报错:”只能在执行 Render() 的过程中调用 RegisterForEventValidation;“这时只需修改前端aspx文件的头部:EnableEventValidation = "false"(有时候不加也不报错,具体原理是什么我也不是很清楚)

<%@ Page Language="C#" AutoEventWireup="true" EnableEventValidation = "false" CodeBehind="webQueueMx.aspx.cs" Inherits="webQueue.webForm.webQueueMx" %>

这样就可以成功导出excel文件了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值