c# - gridview数据导出到asp.net中的excel

标签 c# asp.net excel

我试图将 GridView 数据传输到 excel ....但是输出是一个空白的 excel 工作表。如何解决这个问题?是否有任何代码可以将 GridView 值传输到带有数据库的 excel 工作表?

protected void btnexcel_Click1(object sender, EventArgs e)
{
    Response.Clear();
    Response.Buffer = true;
    Response.AddHeader("content-disposition", "attachment;filename=GridViewExport.xls");
    Response.Charset = "";
    Response.ContentType = "application/vnd.ms-excel";

    StringWriter sw = new StringWriter();
    HtmlTextWriter hw = new HtmlTextWriter(sw);

    gvdetails.AllowPaging = false;
    gvdetails.DataBind(); 
    gvdetails.HeaderRow.Style.Add("background-color", "#FFFFFF");
    gvdetails.HeaderRow.Cells[0].Style.Add("background-color", "green");
    gvdetails.HeaderRow.Cells[1].Style.Add("background-color", "green");
    gvdetails.HeaderRow.Cells[2].Style.Add("background-color", "green");
    for (int i = 0; i < gvdetails.Rows.Count;i++ )
    {
        GridViewRow row = gvdetails.Rows[i];
        row.BackColor = System.Drawing.Color.White;
        row.Attributes.Add("class", "textmode");
        if (i % 2 != 0)
        {
            row.Cells[0].Style.Add("background-color", "#C2D69B");
            row.Cells[1].Style.Add("background-color", "#C2D69B");
            row.Cells[2].Style.Add("background-color", "#C2D69B");
        }
    }

    string style = @"<style> .textmode { mso-number-format:\@; } </style>"; 
    Response.Write(style); 

    Response.Output.Write(sw.ToString());
    Response.End();
}

最佳答案

您的工作表是空白的,因为您的字符串编写器为空。 以下是可能有帮助的内容

System.Web.UI.HtmlTextWriter htmlWrite =
    new HtmlTextWriter(stringWrite);

    GridView1.RenderControl(htmlWrite);

完整代码如下

protected void Button1_Click(object sender, EventArgs e)
{
    Response.Clear();

    Response.AddHeader("content-disposition", "attachment;
    filename=FileName.xls");


    Response.ContentType = "application/vnd.xls";

    System.IO.StringWriter stringWrite = new System.IO.StringWriter();

    System.Web.UI.HtmlTextWriter htmlWrite =
    new HtmlTextWriter(stringWrite);

    GridView1.RenderControl(htmlWrite);

    Response.Write(stringWrite.ToString());

    Response.End();

}

关于c# - gridview数据导出到asp.net中的excel,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15832339/

相关文章:

c# - 创建多个任务,不等待它们,而是让它们按顺序运行

c# - 如何为每个请求执行通用代码?

c# - 使用参数和只放置一个变量然后转换它有什么区别

excel - 数据更改时刷新excel电子表格中的所有数据透视表

excel - 如何使用excel vba将excel文件转换为CSV文件(管道分隔)

c# - 使用 LINQ 进行 AnyCase 搜索

javascript - 在 asp.net 中动态添加行项目的最快方法(性能方面)?

c# - 非阻塞并行(TPL)的互锁使用问题

c# - ASP.net 文本框居中文本

html - VBA 代码根据 Excel 工作簿中的值从 webform 下拉列表中选择一个值