2

次のシナリオがあります。GridViewにデータを入力する方法は2つあります。これらは次のとおりです。

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

これらは両方とも、適切なデータセットをグリッドビューに入力する際に​​正常に機能します。

グリッドビューのコンテンツを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へのエクスポートは、最初の状況(つまり、if / else ifシナリオ)では完全に機能しますが、2番目のシナリオでは、見出しのみが抽出されます。

では、ここで何が起こっているのでしょうか。いくつかの休憩を追加しましたが、csvコードへのエクスポートが実行されているようですが、実際のGridViewコンテンツは同じcsvファイルに配置されていません。

何か案は?

4

3 に答える 3

1

追加する必要のあるjavascript関数があります。それを説明するこのブログ投稿をチェックしてください:

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

ありがとう

ジョン

于 2011-03-14T15:35:56.100 に答える
0

エクスポートを行う前に、データを再バインドしていることを確認してください。しばらく前にプロジェクトで同じ問題が発生しました。GridViewでVIEWSTATEがオフになっていたため、グリッドにデータが入力される前に、ポストバックでデータをエクスポートしようとしていました。

于 2009-11-25T09:59:26.303 に答える
0

GridView1.AllowPaging = false;を削除することで、この問題を実際に解決しました。GridView1.DataBind(); エクスポートスクリプトから。

なぜそれが機能するのかわかりません...しかし、それは機能します!

于 2009-11-25T15:32:16.237 に答える