2

如何通过 ace.oledb 创建没有标题的命名工作表 - 就像默认工作表一样?

工作表的创建命令必须类似于:

CREATE TABLE [MySheet] (field1 type, field2 type ..., fieldn type )

它创建 MySheet 并始终插入(无论连接字符串中的 HDR 扩展属性或注册表设置 FirstRowHasNames)在 MySheet 中包含 field1、field2...fieldn 的第一行

基本上我不想要一个“表头”,我只需要在一个新创建的命名空表中插入值。

4

1 回答 1

2

这并不漂亮,但这是我发现创建一个没有任何内容的新工作表的唯一方法。我发现的唯一问题是 Oledb 会自动在CREATE命令中指定的标题单元格上创建一个命名范围,但假设您不关心它,那么这应该可以正常工作。

string connectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + fileName +
    ";Mode=ReadWrite;Extended Properties=\"Excel 12.0 XML;HDR=NO\"";

using (OleDbConnection conn = new OleDbConnection(connectionString))
{
    conn.Open();

    using (OleDbCommand cmd = new OleDbCommand())
    {
        cmd.Connection = conn;
        cmd.CommandText = "CREATE TABLE [MySheet] (<colname> <col type>)";  // Doesn't matter what the field is called
        cmd.ExecuteNonQuery();

        cmd.CommandText = "UPDATE [MySheet$] SET F1 = \"\"";
        cmd.ExecuteNonQuery();
    }

    conn.Close();
}
于 2013-02-17T21:36:16.523 回答