导出为CSV时Gridview为空行

时间:2014-12-05 12:31:19

标签: c# asp.net csv gridview

this question进一步讨论了这个问题。

以下是我用于创建CSV文件的例程。 一切都很好,除了我只获得列标题而没有行。

   protected void CSVReport_Click(object sender, EventArgs e)
    {

        Response.Clear();
        Response.Buffer = true;
        Response.AddHeader("content-disposition", "attachment;filename=PeopleReportTest.csv");
        Response.Charset = "";
        Response.ContentType = "text/csv";
        Response.AddHeader("Pragma", "public");

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

        StringBuilder sb = new StringBuilder();
        for (int k = 1; 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 = 1; 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();
    }

在检查时,我可以看到GridView1.Rows[i].Cells[k].Text总是返回一个空值。

所以问题可能在于我的gridview的结构。我知道如果我有TemplateFields代码就行不通,但我只有一个而且它被设置为不可见。

所有其他字段均为DynamicFields。这可能是问题吗?

这是标记:

  <asp:GridView ID="GridView1" runat="server"
            CssClass="table table-condensed borderless"
            HeaderStyle-HorizontalAlign="Left"
            AllowPaging="True" AllowSorting="True"
            DataSourceID="GridDataSource"
            DataKeyNames="PersonID" OnRowCommand="GridView1_RowCommand"
            AutoGenerateColumns="false"
            OnDataBound="GridView1_DataBound" PageSize="15">
            <Columns>
                <asp:templatefield itemstyle-width="0%" visible="false">
                    <itemtemplate>
                        <aspf:dynamichyperlink id="detailshyperlink" runat="server"
                            text="details" />
                    </itemtemplate>

                </asp:templatefield>

                <asp:DynamicField DataField="Name" HeaderText="Name"/>
                <asp:DynamicField DataField="PersonCategory" HeaderText="Category" />
                <asp:DynamicField DataField="PositionDescription" HeaderText="Position" />
                <asp:DynamicField DataField="Description" HeaderText="Topic" />
                <asp:DynamicField DataField="FellowsResponsibility" HeaderText="Responsibility" />
                <asp:DynamicField DataField="PartnerSurname" HeaderText="Partner"/>
            </Columns>

            <PagerStyle CssClass="footer" />
            <PagerTemplate>
                <asp:GridViewPager runat="server" />
            </PagerTemplate>
            <EmptyDataTemplate>
                There are currently no items in this table.
            </EmptyDataTemplate>
</asp:GridView>

1 个答案:

答案 0 :(得分:1)

好的,我发现了问题所在。

我无法找到其他类似的情景,所以我会回答我自己的问题,以防有人发现它有用。

解决方案只是将所有DynamicFields替换为标准BoundFields和BOOM所有数据都在那里。

下次我没有使用DynamicData框架,这是肯定的。

相关问题