2011-12-29 223 views
0

在我的應用程序,也要求出口的datagridview到Excel中。如何C#的datagridview導出到Excel中

我使用下面的源代碼。我想要就以下問題提供專家建議。

  1. 是我的代碼是否正確?因爲我沒有得到保存在所選擇的路徑中的任何文件。

  2. 是否有出口的同時由網格數據的任何性能問題,因爲有可能會提供網格多達數據?

  3. 我使用的命名空間「的Microsoft.Office.Interop.Excel」,不知道這是正確的?
private void btnSaveResult_Click(object sender, EventArgs e) 
     { 
      try 
      { 
       if (this.saveFileDialog.ShowDialog() == DialogResult.OK) 
       { 
        saveFileDialog.Filter = "Execl files (*.xls)|*.xls"; 
        saveFileDialog.FilterIndex = 0; 
        saveFileDialog.RestoreDirectory = true; 
        saveFileDialog.CreatePrompt = true; 
        saveFileDialog.Title = "Export Excel File To"; 
        Microsoft.Office.Interop.Excel.ApplicationClass ExcelApp = new Microsoft.Office.Interop.Excel.ApplicationClass(); 
        ExcelApp.Application.Workbooks.Add(Type.Missing); 
        ExcelApp.Columns.ColumnWidth = 30; 
        for (int i = 0; i < grdResult.Rows.Count; i++) 
        { 
         DataGridViewRow row = grdResult.Rows[i]; 
         for (int j = 0; j < row.Cells.Count; j++) 
         { 
          ExcelApp.Cells[i + 1, j + 1] = row.Cells[j].ToString(); 
         } 
        }      
        ExcelApp.ActiveWorkbook.Saved = true; 
        ExcelApp.Quit(); 
        MessageBox.Show("The Save button was clicked or the Enter key was pressed" + "\nThe file would have been saved as " + this.saveFileDialog.FileName); 

       } 
       else MessageBox.Show("The Cancel button was clicked or Esc was pressed"); 

      } 
      catch (Exception ex) 
      { 
       MessageBox.Show("Cancelled Save Operation"); 
       this.Close(); 
      } 


     } 

回答

1

得到處理對工作簿磨片添加,並調用Workbook.SaveCopyAs(文件路徑);

0

實現弱點: - 你不免費resouces您使用; - 您導出項目一個一個地(這是非常緩慢),有一系列專爲,在這裏你可以設置對象[,](裝箱的int,字符串,...的); - 你不處理的文本格式(Excel的有關格式的決定是不對的), - 你混合視圖和出口邏輯。

1

嘗試下面的類

using System; 
    using System.Data; 
    using System.Configuration; 
    using System.IO; 
    using System.Web; 
    using System.Web.Security; 
    using System.Web.UI; 
    using System.Web.UI.WebControls; 
    using System.Web.UI.WebControls.WebParts; 
    using System.Web.UI.HtmlControls; 

    /// <summary> 
    /// Summary description for GridViewExportUtil 
    /// </summary> 
    public class GridViewExportUtil 
    { 
public GridViewExportUtil() 
{ 
    // 
    // TODO: Add constructor logic here 
    // 
} 
    public static void ExportGridView(string fileName, GridView gv, Label header, Label date) 
     { 
      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)) 
       { 
        gv.AllowPaging = false; 
        // Create a table to contain the grid 
        Table table = new Table(); 

        // include the gridline settings 
        table.GridLines = gv.GridLines; 

        gv.Style["font-family"] = "Tahoma"; 
        // add the header row to the table 

        if (gv.HeaderRow != null) 
        { 
         GridViewExportUtil.PrepareControlForExport(gv.HeaderRow); 
         gv.HeaderRow.BackColor = System.Drawing.Color.Lavender; 
         gv.HeaderRow.ForeColor = System.Drawing.Color.Green; 

         table.Rows.Add(gv.HeaderRow); 
        } 
        // add each of the data rows to the table 
        foreach (GridViewRow row in gv.Rows) 
        { 
         GridViewExportUtil.PrepareControlForExport(row); 
         table.Rows.Add(row); 
        } 
        // add the footer row to the table 
        if (gv.FooterRow != null) 
        { 
         GridViewExportUtil.PrepareControlForExport(gv.FooterRow); 
         table.Rows.Add(gv.FooterRow); 
        } 
        htw.WriteLine("<br>"); 
        // htw.WriteLine("&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;"); 
        if (header.Text != null) 
        { 
         header.Font.Size = 15; 
         header.Font.Bold = true; 
         header.ForeColor = System.Drawing.Color.Blue; 
         header.RenderControl(htw); 
        } 
        htw.WriteLine("</p>"); 
        // render the table into the htmlwriter 
        table.RenderControl(htw); 
        htw.WriteLine("<br>"); 
        htw.WriteLine("Report taken on :", System.Drawing.FontStyle.Bold); 
        if (date.Text != null) 
        { 
         date.ForeColor = System.Drawing.Color.Blue; 
         date.RenderControl(htw); 
        } 
        // render the htmlwriter into the response 
        HttpContext.Current.Response.Write(sw.ToString()); 
        HttpContext.Current.Response.End(); 
       } 
      } 
     } 

    /// <summary> 
    /// Replace any of the contained controls with literals 
    /// </summary> 
    /// <param name="control"></param> 
    private static void PrepareControlForExport(Control control) 
     { 
      for (int i = 0; i < control.Controls.Count; i++) 
      { 
       Control current = control.Controls[i]; 
       if (current is LinkButton) 
       { 
        control.Controls.Remove(current); 
        control.Controls.AddAt(i, new LiteralControl((current as LinkButton).Text)); 
       } 
       else if (current is ImageButton) 
       { 
        control.Controls.Remove(current); 
        control.Controls.AddAt(i, new LiteralControl((current as ImageButton).AlternateText)); 
       } 
       else if (current is HyperLink) 
       { 
        control.Controls.Remove(current); 
        control.Controls.AddAt(i, new LiteralControl((current as HyperLink).Text)); 
       } 
       else if (current is DropDownList) 
       { 
        control.Controls.Remove(current); 
        control.Controls.AddAt(i, new LiteralControl((current as DropDownList).SelectedItem.Text)); 
       } 
       else if (current is CheckBox) 
       { 
        control.Controls.Remove(current); 
        control.Controls.AddAt(i, new LiteralControl((current as CheckBox).Checked ? "True" : "False")); 
       } 
       else if (current is Label) 
       { 
        control.Controls.Remove(current); 
        control.Controls.AddAt(i, new LiteralControl((current as Label).Text)); 
       } 

       if (current.HasControls()) 
       { 
        GridViewExportUtil.PrepareControlForExport(current); 
       } 
      } 
     } 
    } 

並以此爲下面

protected void Button1_Click(object sender, EventArgs e) 
     { 
    Label1.Visible = true; 
    Label2.Visible = true; 

    Label1.Text = "Login Information Data"; 
    Label2.Text = Convert.ToString(System.DateTime.Now); 

    if (GridView1.Visible == true) 
    { 
     // GridViewExportUtil.Export("StateReport.xls", GridView1); 
     GridViewExportUtil.ExportGridView("LoginInformation.xls", GridView1, Label1, Label2); 
    } 

     } 

刪除標籤,如果你不希望他們..修改根據自己的需要。