上传excel并导入到datatable

时间:2011-08-28 15:36:03

标签: c# excel upload datatable

我试着这样做,用户从uploadcontrol中选择excel文件并上传或显示文件的完整路径/目录,因为我将解析文件并更新到数据表。

我在下面导入到数据代码,我是如何解决这种情况的

使用asp.net 4.0开发项目,c#

public DataTable Import(String path){

Microsoft.Office.Interop.Excel.ApplicationClass app = new Microsoft.Office.Interop.Excel.ApplicationClass();
    Microsoft.Office.Interop.Excel.Workbook workBook = app.Workbooks.Open(path, 0, true, 5, "", "", true, Microsoft.Office.Interop.Excel.XlPlatform.xlWindows, "\t", false, false, 0, true, 1, 0);

    Microsoft.Office.Interop.Excel.Worksheet workSheet = (Microsoft.Office.Interop.Excel.Worksheet)workBook.ActiveSheet;

    int index = 0;
    object rowIndex = 2;

    DataTable dt = new DataTable();
    dt.Columns.Add("FirstName");
    dt.Columns.Add("LastName");
    dt.Columns.Add("Mobile");
    dt.Columns.Add("Landline");



    DataRow row;

    while (((Microsoft.Office.Interop.Excel.Range)workSheet.Cells[rowIndex, 1]).Value2 != null)
    {
        rowIndex = 2 + index;
        row = dt.NewRow();
        row[0] = Convert.ToString(((Microsoft.Office.Interop.Excel.Range)workSheet.Cells[rowIndex, 1]).Value2);
        row[1] = Convert.ToString(((Microsoft.Office.Interop.Excel.Range)workSheet.Cells[rowIndex, 2]).Value2);
        row[2] = Convert.ToString(((Microsoft.Office.Interop.Excel.Range)workSheet.Cells[rowIndex, 3]).Value2);
        row[3] = Convert.ToString(((Microsoft.Office.Interop.Excel.Range)workSheet.Cells[rowIndex, 4]).Value2);

        index++;
        dt.Rows.Add(row);
    }
    app.Workbooks.Close();
    return dt;
}

2 个答案:

答案 0 :(得分:0)

正如Svick所说,你并没有真正提出问题,但与此同时你可能想要调查reading from Excel using ADO.Net,这将让你只需几步即可从Excel表格中创建数据集。或者也许其中一个读/写Excel表格的第三方组件适合您(Flexcel和Gembox在我脑海中浮现)。所有这些都具有以下优点:您无需在运行应用程序的计算机上安装Excel。 (参见Mathias的评论)。

答案 1 :(得分:0)

使用GemBox.Spreadsheet,您可以轻松完成此任务。

以下是Excel C#代码示例:

ExcelFile ef = new ExcelFile();

ef.LoadXls(path);

DataTable dt = ef.Worksheets[0].CreateDataTable(ColumnTypeResolution.Auto);

return dt;