2012-09-24 80 views
3

我有一個C#列表,我從Excel電子表格創建,我想將其導出到Excel。我怎樣才能完成這項任務?這只是一個控制檯項目。我不打算在.Net應用程序中顯示數據。我只需要電子表格。如何將C#對象列表導出到Excel電子表格中?

var fileName = string.Format("C:\\Users\\SGurmu\\Desktop\\Data 091510.xls"); 
var connectionString = string.Format("Provider=Microsoft.Jet.OLEDB.4.0; data source={0}; Extended Properties=Excel 8.0;", fileName); 

var fileName2 = string.Format("C:\\Users\\SGurmu\\Desktop\\Copy of Prototype.xls"); 
var connectionString2 = string.Format("Provider=Microsoft.Jet.OLEDB.4.0; data source={0}; Extended Properties=Excel 8.0;", fileName); 

var adapter = new OleDbDataAdapter("SELECT * FROM [Sheet1$]", connectionString); 
var ds = new DataSet(); 

adapter.Fill(ds, "contacts"); 

var data = ds.Tables["contacts"].AsEnumerable(); 

List<EmployeeData> query = data.Where(x => x.Field<string>("First_Name") != string.Empty).Select(x => 

new EmployeeData 
    { 
    empID = x.Field<double>("EMPLOYEE"), 
    firstName = x.Field<string>("First_Name"), 
    lastName = x.Field<string>("Last_Name"), 
    JobCategory = x.Field<string>("Job Title"), 
    StartDate = x.Field<Nullable<DateTime>>("Hire Dt"), 
    EndDate = x.Field<Nullable<DateTime>>("Term Dt"), 
    TermReason = x.Field<string>("Term Reason"), 
    PeggedUID = x.Field<Nullable<double>>("Pegged UserID"), 
    UpdateDate = x.Field<Nullable<DateTime>>("Last Updated") 
    }).ToList(); 
+0

你不能導出到您在預先計算的excel文件導入一個簡單的csv文件或XML文件? –

+0

你試過這個傢伙嗎?轉到標題爲「以下是列入方法列表。列表」的部分「http://www.codeproject.com/Tips/64127/Exporting-a-List-of-any-type-to-Excel –

回答

-1

也許你可以嘗試使用Infodinamica.Framework.Expotable包,在Nuget中託管。

有了它,你可以做這樣的事情

List<EmployeeData> query = data.Where(x => x.Field<string>("First_Name") != string.Empty).Select(x => 

    new EmployeeData 
     { 
     empID = x.Field<double>("EMPLOYEE"), 
     firstName = x.Field<string>("First_Name"), 
     lastName = x.Field<string>("Last_Name"), 
     JobCategory = x.Field<string>("Job Title"), 
     StartDate = x.Field<Nullable<DateTime>>("Hire Dt"), 
     EndDate = x.Field<Nullable<DateTime>>("Term Dt"), 
     TermReason = x.Field<string>("Term Reason"), 
     PeggedUID = x.Field<Nullable<double>>("Pegged UserID"), 
     UpdateDate = x.Field<Nullable<DateTime>>("Last Updated") 
     }).ToList(); 

    IExportEngine engine = new ExcelExportEngine(); 
    engine.AddData(EmployeeData); 
    MemoryStream memory = engine.Export(); 

你可以用的NuGet命令安裝:

Install-Package Infodinamica.Framework.Exportable 

唯一的問題,文檔在西班牙。

該項目頁面here

出口例如(在西班牙語)是here

這也使進口文件(西班牙文)here

0
  1. 右鍵單擊該項目和管理的NuGet包。
  2. 添加ClosedXML nuget包
  3. using ClosedXML.Excel;添加到類文件的頂部。
  4. 將'ToExcelFile'方法添加到您的班級。
  5. 將您的列表轉換爲DataTable。

ToExcelFile方法

public static bool ToExcelFile(this DataTable dt, string filename) 
{ 
    bool Success = false; 
    //try 
    //{ 
     XLWorkbook wb = new XLWorkbook(); 

     wb.Worksheets.Add(dt, "Sheet 1"); 

     if (filename.Contains(".")) 
     { 
      int IndexOfLastFullStop = filename.LastIndexOf('.'); 

      filename = filename.Substring(0, IndexOfLastFullStop) + ".xlsx"; 

     } 

     filename = filename + ".xlsx"; 

     wb.SaveAs(filename); 

     Success = true; 

    //} 
    //catch (Exception ex) 
    //{ 
     //ex.HandleException(); 

    //} 
    return Success; 
} 

轉換列表到DataTable

public static DataTable ToDataTable(List<string> list) 
    { 
     DataTable MethodResult = null; 

     DataTable dt = new DataTable(); 
     dt.Columns.Add("Item",); 

     foreach(string s in list) 
     { 
      DataRow dr = dt.NewRow(); 
      dr[0] = s; 
      dt.Rows.Add(dr); 

     } 

     dt.AcceptChanges(); 

     MethodResult = dt; 

     return MethodResult; 

    } 
相關問題