如何导入数据到excel表

问题描述:

我有数据表。我需要导入到Excel Template.How这些数据表中的值来实现这一如何导入数据到excel表

+0

永远记住,谷歌是你的朋友: http://www.codeproject.com/KB/office/ExcelDataTable.aspx http://msmvps.com/blogs/deborahk/archive/2009/07/ 23/write-data-from-a-datatable-to-excel.aspx http://www.dotnetspider.com/resources/29183-Export-DataTable-Excel-using-c-with.aspx – MaQleod 2010-08-30 06:00:48

有许多选项

  1. 写出作为一个CSV文件
  2. 将数据写入数据输出为一个HTML表格
  3. 使用Automation来操作正在运行的Excel实例
  4. 使用OleDB Driver来创建Excel文件。 Another link from Microsoft
  5. 使用图书馆像NPOI写出来的Excel文件
  6. 使用图书馆像ExcelPackage写出来的Excel文件
  7. 使用的Office Open XML

的选项中,我喜欢选择5性能和简单性,特别是在服务器端需要时,如果您需要XLSX文件而不是XLS,选项6是很好的,选项7与5和6相比具有陡峭的学习曲线。

试试这个 -

// TO USE: 
      // 1) include COM reference to Microsoft Excel Object library 
      // add namespace... 
      // 2) using Excel = Microsoft.Office.Interop.Excel; 
      private static void Excel_FromDataTable(DataTable dt) 
      { 
       // Create an Excel object and add workbook... 
       Excel.ApplicationClass excel = new Excel.ApplicationClass(); 
       // true for object template??? 
       Excel.Workbook workbook = excel.Application.Workbooks.Add(true); 


       // Add column headings... 
       int iCol = 0; 
       foreach (DataColumn c in dt.Columns) 
       { 
        iCol++; 
        excel.Cells[1, iCol] = c.ColumnName; 
       } 
       // for each row of data... 
       int iRow = 0; 
       foreach (DataRow r in dt.Rows) 
       { 
        iRow++; 

        // add each row's cell data... 
        iCol = 0; 
        foreach (DataColumn c in dt.Columns) 
        { 
         iCol++; 
         excel.Cells[iRow + 1, iCol] = r[c.ColumnName]; 
        } 
       } 

       // Global missing reference for objects we are not defining... 
       object missing = System.Reflection.Missing.Value; 

       // If wanting to Save the workbook... 
       workbook.SaveAs("MyExcelWorkBook.xls", 
        Excel.XlFileFormat.xlXMLSpreadsheet, missing, missing, 
        false, false, Excel.XlSaveAsAccessMode.xlNoChange, 
        missing, missing, missing, missing, missing); 

       // If wanting to make Excel visible and activate the worksheet... 
       excel.Visible = true; 
       Excel.Worksheet worksheet = (Excel.Worksheet)excel.ActiveSheet; 
       ((Excel._Worksheet)worksheet).Activate(); 

       // If wanting excel to shutdown... 
       ((Excel._Application)excel).Quit(); 
      }