C#访问Excel工作表(C# Accessing Excel Worksheet)

2019-10-30 09:45发布

这是访问一个MS Office Excel 2007文件的正确方法是什么?

        String connString = "Provider=Microsoft.Jet.OLEDB.4.0;" + 
    "Data Source=" + file_path + ";Extended Properties=Excel 8.0;";

如果是这样,我怎么访问某个工作表,然后插入行? 链接也受到了欢迎。

Answer 1:

有CodeProject上的一篇文章- http://www.codeproject.com/KB/office/excel_using_oledb.aspx -应该让你开始这



Answer 2:

您可以使用Excel的互操作 (的Microsoft.Office.Interop.Excel):

下面是一些代码片段:

object missing = (object) Type.Missing;

Application app = new Application();

Workbooks books = app.Workbooks;

Workbook book = books.Open("somefile.xls", missing, missing, missing, missing, missing, missing,
            missing, missing, missing, missing, missing, missing, missing, missing);

Worksheet sheet = (Worksheet)book.Worksheets[1];

它有一些weirdnesses(像那些“失踪”的参数),但它的工作原理相当顺利。 如果采取这种方法,请注意Excel.exe进程不会被孤立。



Answer 3:

连接字符串

  connectionString = @"provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + filename + @";Extended Properties=""Excel 12.0;HDR=YES;IMEX=1""";

读取数据

 excelConnection = new System.Data.OleDb.OleDbConnection(connectionString);
        excelConnection.Open();
        dbSchema = excelConnection.GetOleDbSchemaTable(System.Data.OleDb.OleDbSchemaGuid.Tables, null);
        firstSheetName = dbSchema.Rows[0]["TABLE_NAME"].ToString();
        strSQL = "SELECT * FROM [" + firstSheetName + "]";
        da = new OleDbDataAdapter(strSQL, excelConnection);
        da.Fill(dt);

写入数据看到的Excel生成此使用自动化虽然。 它可以帮助。



文章来源: C# Accessing Excel Worksheet