jzh-314

生活<>生存

导航

在ASP.NET 2.0中将GridView中的数据全部导出到Excel中

在ASP.NET 2.0中将GridView中的数据全部导出到Excel中,请参考下述代码(以手动绑定数据源为例):
Defualt.aspx中,添加一个GridView控件
  <form id="form1" runat="server">
    <div>
        <asp:GridView ID="GridView1" runat="server" AllowPaging="true" OnPageIndexChanging="paging">
        </asp:GridView>
    </div>
    <asp:Button ID="Button1" runat="server" OnClick="Button1_Click" Text="导出到excel" />
    </form>
 
Default.aspx后台代码:
  protected void Page_Load(object sender, EventArgs e)
    {
        if (!Page.IsPostBack)
        {
            BindData();
        }
    }
  
    private void BindData()
    {
        // make the query
        string query = "SELECT * FROM customers";
        SqlConnection myConnection = new SqlConnection(ConnectionString);
        SqlDataAdapter ad = new SqlDataAdapter(query, myConnection);
        DataSet ds = new DataSet();
        ad.Fill(ds, "customers");
        GridView1.DataSource = ds;
        GridView1.DataBind();
  }
 
    public override void VerifyRenderingInServerForm(Control control)
    {
        // Confirms that an HtmlForm control is rendered for
    }
 
    protected void Button1_Click(object sender, EventArgs e)
    {
        Response.Clear();
 
        Response.AddHeader("content-disposition",
        "attachment;filename=FileName.xls");
 
        Response.Charset = "gb2312";
        Response.ContentType = "application/vnd.xls";
 
        System.IO.StringWriter stringWrite = new System.IO.StringWriter();
 
        System.Web.UI.HtmlTextWriter htmlWrite =
        new HtmlTextWriter(stringWrite);
 
        GridView1.AllowPaging = false;
        BindData();
        GridView1.RenderControl(htmlWrite);
        Response.Write(stringWrite.ToString());
        Response.End();
        GridView1.AllowPaging = true;
        BindData();
    }
    protected void paging(object sender,GridViewPageEventArgs e)
    {
        GridView1.PageIndex = e.NewPageIndex;
        BindData();
    }

posted on 2007-09-19 18:43  jizh  阅读(394)  评论(0编辑  收藏  举报