【问题标题】:Gridview: Export to csv issueGridview:导出到 csv 问题
【发布时间】:2010-12-20 05:26:39
【问题描述】:

我有以下情况。我有两种用数据填充 GridView 的方法。它们如下:

protected void btSearch_Click(object sender, EventArgs e)
{

    lqPackWeights.WhereParameters.Clear();
    ControlParameter cp = new ControlParameter();
    cp.Type = TypeCode.String;


    if (radBuyer.Checked)
    {
        cp.ControlID = "ddlProd";
        cp.PropertyName = "SelectedValue";
        lbRadMiss.Text = "";
    }

    else if (radProd.Checked)
    {
        cp.ControlID = "tbxProdAC";
        cp.PropertyName = "Text";
        lbRadMiss.Text = "";
    }

    else
    {
        cp.ControlID = "lbRadMiss";
        cp.PropertyName = "Text";
        lbRadMiss.Text = "Please check appropriate radio button before you attempt a search";
    }

    cp.Name = "IDDesc";
    lqPackWeights.WhereParameters.Add(cp);
    GridView1.DataSourceID = "lqPackWeights";
    GridView1.DataBind();

}

还有

protected void btnShowPaper_Click(object sender, EventArgs e)
{
    ORWeightsDataClassesDataContext dbPa = new ORWeightsDataClassesDataContext();
    int max = 0;
    if (int.TryParse(txtbxHowMany.Text, out max))
    {
        var queryPa = dbPa.tblOnlineReportingCOMPLETEWeights
                    .Where(x => x.MaterialLevel == "Primary" && x.MaterialText == "Paper" && x.MemberId == "FM00012")
                    .OrderByDescending(x => x.ProductPercentage).Take(max);

        GridView1.DataSource = queryPa;
        GridView1.DataBind();

这些都可以很好地使用其适当的数据集填充网格视图。

我还有以下代码将 gridview 内容导出到 csv:

protected void btnExportCSV_Click(object sender, EventArgs e)
{
    Response.Clear();
    Response.Buffer = true;
    Response.AddHeader("content-disposition", "attachment;filename=GridViewExport.csv");
    Response.Charset = "";
    Response.ContentType = "application/text";

    GridView1.AllowPaging = false;
    GridView1.DataBind();

    StringBuilder sb = new StringBuilder();
    for (int k = 0; k < GridView1.Columns.Count; k++)
    {
        sb.Append(GridView1.Columns[k].HeaderText + ',');
    }

    sb.Append("\r\n");
    for (int i = 0; i < GridView1.Rows.Count; i++)
    {
        for (int k = 0; k < GridView1.Columns.Count; k++)
        {
            sb.Append(GridView1.Rows[i].Cells[k].Text + ',');
        }
        sb.Append("\r\n");
    }
    Response.Output.Write(sb.ToString());
    Response.Flush();
    Response.End();

}

在第一种情况下(即 if/else if 场景)导出到 csv 效果很好,但在第二种情况下,只提取标题。

那么这里发生了什么?!我添加了一些中断,看起来正在执行导出到 csv 代码,但是实际的 GridView 内容没有放在同一个 csv 文件中。

有什么想法吗?

【问题讨论】:

  • 在您尝试导出时是否可能尚未实际绑定 GridView(因此没有行)?

标签: .net excel csv export export-to-excel


【解决方案1】:

确保在导出之前重新绑定数据。不久前我在一个项目中遇到了同样的问题,因为我们在 GridView 上关闭了 VIEWSTATE,所以在回发时我们试图在网格填充数据之前导出数据。

【讨论】:

  • 您好 Mattruma - 感谢您对此进行调查。为我的无知道歉,但我应该如何重新绑定数据,即我应该把我的数据绑定放在哪里?我觉得这样的工具可以问这些问题,因为我知道它们很可能非常简单。
  • 没问题!我们通常在后面的代码中有一个名为 BindData() 的方法,它将数据绑定到网格,也进行任何过滤。在我们的导出方法中,我们总是先调用 BindData(),然后再进行导出。
【解决方案2】:

我实际上是通过删除 GridView1.AllowPaging = false; 解决了这个问题。 GridView1.DataBind();来自导出脚本。

不知道为什么它会起作用......但确实如此!

【讨论】:

    【解决方案3】:

    您需要添加一个 javascript 函数。查看这篇解释它的博客文章:

    http://www.inspiredbytechnology.com/index.php/2011/03/09/export-gridview-to-csv-in-a-sharepoint-2010-webpart/

    谢谢

    乔恩

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2015-07-19
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多