导出GridView中的数据到Excel

页面的GridView,导到Excel

aspx页面:
<%@ Page    EnableEventValidation="false"%>
.cs页面
    //导出到excel
    protected void btnexport_Click(object sender, EventArgs e)
    {
/GridView的设置
        GridViewSet();
        Export("application/ms-excel", "*****报表.xls");
    }
    private void GridViewSet()
    {
//将不需要的列设置为不可见,如编辑删除列等
        this.GVcategoryList.Columns["不需要的列的索引号"].Visible = false;
//将允许分页设置为false,在此绑定数据
        this.GVcategoryList.AllowPaging = false;
        this.BindGvList();
    }
    private void Export(string FileType, string FileName)
    {
        Response.Charset = "GB2312";
        Response.ContentEncoding = System.Text.Encoding.UTF7;
        Response.AppendHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(FileName, Encoding.UTF8).ToString());
        Response.ContentType = FileType;
        this.EnableViewState = false;
        StringWriter tw = new StringWriter();
        HtmlTextWriter hw = new HtmlTextWriter(tw);
        GVcategoryList.RenderControl(hw);
        Response.Write(tw.ToString());
        Response.End();
    }
//下面这句很必要,不然会出错,出错信息为: 类型“GridView”的控件“GridView1”必须放在具有 runat=server 的窗体标记内
    public override void VerifyRenderingInServerForm(Control control)
    {
    }

 

 

在导到office2003Excel上时没有问题的,但是导出到2007就会出现问题了?有遇到过这样问题的朋友可以和我交流下。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值