0

我正在使用这种方法使用 vb.net 创建一个 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++)
    {
        //add separator
        sb.Append(GridView1.Columns[k].HeaderText + ',');
    }
    //append new line
    sb.Append("\r\n");
    for (int i = 0; i < GridView1.Rows.Count; i++)
    {
        for (int k = 0; k < GridView1.Columns.Count; k++)
        {
            //add separator
            sb.Append(GridView1.Rows[i].Cells[k].Text + ',');
        }
        //append new line
        sb.Append("\r\n");
    }
    Response.Output.Write(sb.ToString());
    Response.Flush();
    Response.End();
}

此代码正在创建 csv 文件。但我不想在 csv 中有任何额外的列。可能吗?

4

1 回答 1

0

是的当然!

  ...
  for (int k = 0; k < GridView1.Columns.Count - 1; k++)
  {
    //add separator
     sb.Append(GridView1.Rows[i].Cells[k].Text + ',');
  }
  //add final element
  sb.Append(GridView1.Rows[i].Cells[GridView1.Columns.Count - 1].Text );
  //append new line
  sb.Append("\r\n");
  ...
于 2012-05-17T05:56:58.070 回答