protected void btnOut_Click(object sender, EventArgs e)
    {
        Export("application/ms-excel", "FromGridView.xls");
    }
    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);
        this.gvShow.RenderControl(hw);
        Response.Write(tw.ToString());
        Response.End();
    }
    //如果没有下面方法会报错类型“GridView”的控件“GridView1”必须放在具有 runat=server 的窗体标记内
    public override void VerifyRenderingInServerForm(Control control)
    {
    }
  这是我以前做过了一段代码,就是用来实现导出到EXCEL的
你可以参考下!导出来的数据和在数据控件里显示的一样!

解决方案 »

  1.   

    楼上的代码有问题,只能导出一页的数据,如何导出所有页的数据呀,还有datagrid中如何加上页眉显示一个label
      

  2.   

    可以把EXCEL文件当做ODBC的文件数据源,这样就和往一般的数据库中存数据一样了。
      

  3.   


    ODBC 
      
    标准 
    Driver={Microsoft Excel Driver (*.xls)};DriverId=790;Dbq=C:\MyExcel.xls;DefaultDir=c:\mypath; 
     
    SQL表达式"SELECT * FROM [sheet1$]"。例如:在excel工作表名称后面跟"$"字符并且使用"[" "]"将其括起来。  
       
    OLE DB 
      
    标准 
    Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\MyExcel.xls;Extended Properties="Excel 8.0;HDR=Yes;IMEX=1"; 
     
    "HDR=Yes;" 表示工作表的第一行是表头,没有数据。 "HDR=No;"与之相反。
    "IMEX=1;"告诉驱动程序始终将"intermixed"数据类型(numbers, dates, strings等等)作为文本型读取。
    注意:该选项可能引起Excel工作表写权限的修改。