Gridview:导出为csv问题

问题描述:

我有以下情况。我有两种用数据填充GridView的方法。这些如下:Gridview:导出为csv问题

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(); 

这些都工作得不错的填充与他们approrpiate数据集GridView的。

我也有下面的代码,出口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(); 

} 

到CSV的出口工作得很好在第一种情况下(即如果/否则,如果情况),但是当它涉及到第二种情况,只有标题被提取。

这是怎么回事?我已经加入了几个休息时间,它看起来像是正在执行csv代码的输出,但实际的GridView内容不会放在同一个csv文件中。

任何想法?

+0

是否有可能在GridView是不实际尚未在你试图导出时限(因而没有行)? – 2009-11-25 09:46:11

确保您在重新导入数据之前执行导出操作。我在项目中遇到了同样的问题,因为我们在GridView上关闭了VIEWSTATE,所以在回发时我们试图导出数据,之后网格被填充数据。

+0

Hello Mattruma - 感谢您对此进行调查。对于我的无知抱歉,但我应该如何重新整理数据,即我应该在哪里放置数据绑定? 我觉得像这样一个工具问这些问题,因为我知道它们很可能,可笑容易。 – MrDean 2009-11-25 10:39:04

+0

不是问题!我们通常在我们的代码中有一个名为BindData()的方法,它将数据绑定到网格,并进行任何过滤。在我们的导出方法中,我们总是先调用BindData(),然后执行导出。 – mattruma 2009-11-25 10:45:56

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

不知道它为什么可行......但它确实!

您需要添加一个javascript函数。看看这个博客帖子这也解释了它:

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

感谢

乔恩