2011-11-28 10 views
5

私はグリッドビューを持っています。これにはいくつかの列が含まれます。それは10個のカラムを持ち、8個のカラムだけがヘッダを持ち、2 カラムのヘッダは空であると仮定します。今、私はこのグリッドビューをexcelにエクスポートしています。これには、名前のない2つの列を持つ10個の列がすべて含まれています。 GridViewをexcelにエクスポートしているときに、2つの空のヘッダー列を除外するにはどうすればいいですか?ときに、ユーザー表をあなたがそれらを必要としない場合は、ちょうどあなたのHTMLの表に、これらの2つの列を含めることができませんでした....またはあなたは再書き込みができExcelでグリッドビューをエクスポート中に列をスキップするにはどうすればいいですか?

 protected void btnExportToExcel_Click(object sender, EventArgs e) 
     { 
      Export("Customers.xls", this.gdvMessages); 
     } 

     private void Export(string fileName, GridView gv) 
     { 
      HttpContext.Current.Response.Clear(); 
      HttpContext.Current.Response.AddHeader(
      "content-disposition", string.Format("attachment; filename={0}", fileName)); 
      HttpContext.Current.Response.ContentType = "application/ms-excel"; 

      using (StringWriter sw = new StringWriter()) 
      { 
       using (HtmlTextWriter htw = new HtmlTextWriter(sw)) 
       { 
        // Create a form to contain the grid 
        Table table = new Table(); 

        // add the header row to the table 
        if (gv.HeaderRow != null) 
        { 
         PrepareControlForExport(gv.HeaderRow); 
         table.Rows.Add(gv.HeaderRow); 
        } 

        // add each of the data rows to the table 
        foreach (GridViewRow row in gv.Rows) 
        { 
         PrepareControlForExport(row); 
         table.Rows.Add(row); 
        } 

        // add the footer row to the table 
        if (gv.FooterRow != null) 
        { 
         PrepareControlForExport(gv.FooterRow); 
         table.Rows.Add(gv.FooterRow); 
        } 

        // render the table into the htmlwriter 
        table.RenderControl(htw); 

        // render the htmlwriter into the response 
        HttpContext.Current.Response.Write(sw.ToString()); 
        HttpContext.Current.Response.End(); 
       } 
      } 
     } 

答えて

3

:私は同じのために、次のコードを使用しています[Excelにエクスポート]ボタンを押し、列を含めないでください。また、テーブルに加えて、非表示の列を持つ別のテーブルを使用し、ユーザーが[Excelにエクスポート]ボタンをクリックしたときにそのテーブルからデータを取得することもできます。さらに、データを表示することはできませんでした。ユーザーがページをロードするか、ボタンをクリックして列なしでデータをダウンロードします。がんばろう!

EDITED:この排他的なシナリオでは、次の方法でコードを編集することもできます。

// add the header row to the table 
      if (gv.HeaderRow != null) 
      { 
       TableRow tr = new TableRow(); 

       foreach (DataControlFieldHeaderCell c in gv.HeaderRow.Cells) 
       { 
        if (c.Text != " ") { 
         tr.Cells.Add(new TableCell() { Text = c.Text}); 
        } 
       } 

       PrepareControlForExport(tr); 
       table.Rows.Add(tr); 
      } 

何のコードのその部分がないことは、ヘッダー行の各セルをループしている場合、およびそれは空で、それを含んでいません。その後、htmlテーブルに追加します。これは、テーブルの残りの部分がこれらの列が属するセルパンパンを追加するように、必要に応じて調整することができます。これがあなたの実際のGridviewと2つのスクリーンショットを必要とするものではない場合、望ましい出力が理想的でしょう。

幸運を祈る!以下のコードを使用してExcelにエクスポート中

+0

「HTMLテーブルに2つの列を含めない」という例を教えてください。 – Sandy

2

代わりに、あなたはそれらの列を非表示にすることができます

this.myGridview.Columns [0] .Visible = falseは、

ここで、 '0'は非表示にする列のインデックスです。

+0

Sandyと同じ必要がありました。以前のvb.netコードを使用しているDataGridコントロールを使用していました。 user2508258アイデアが私の問題を解決しました。私のvb.netコード:DataGrid1.Columns(0).Visible = False(Excelへのエクスポート中も第1列も削除したかったのですが)。 – Doreen

関連する問題