简体   繁体   English

我的代码读取Excel文件错误

[英]my code reading Excel file error

I am using VSTS 2008 + C# + .Net 3.5 to read Excel file created by Excel 2007 (but saved as Excel 2003 xls format). 我正在使用VSTS 2008 + C#+ .Net 3.5读取由Excel 2007创建的Excel文件(但另存为Excel 2003 xls格式)。 Here is my code, when executing code adapter.Fill(cities), there is exception -- "OldDbException Could not find installable ISAM". 这是我的代码,执行代码adapter.Fill(cities)时出现异常-“ OldDbException无法找到可安装的ISAM”。 Any ideas what is wrong? 任何想法有什么问题吗?

static void Main(string[] args)
{
    string connectionString = @"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\temp\data.xls;ExtendedProperties=""Excel 8.0;HDR=YES;""";

    DbProviderFactory factory = DbProviderFactories.GetFactory("System.Data.OleDb");

    DbDataAdapter adapter = factory.CreateDataAdapter();

    DbCommand selectCommand = factory.CreateCommand();
    selectCommand.CommandText = "SELECT ID FROM [Sheet1$]";

    DbConnection connection = factory.CreateConnection();
    connection.ConnectionString = connectionString;

    selectCommand.Connection = connection;

    adapter.SelectCommand = selectCommand;

    DataSet cities = new DataSet();

    adapter.Fill(cities); // OldDbException Could not find installable ISAM

    return;
}

thanks in advance, George 预先感谢乔治

I replicated your issue, replace your code with the following and it should work 我复制了您的问题,用以下代码替换了您的代码,它应该可以正常工作

static void Main ( string [] args )
    {
        string connectionString = @"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\temp\Data.xls;Extended Properties=""Excel 8.0;HDR=YES;""";
        DbProviderFactory factory = DbProviderFactories.GetFactory ( "System.Data.OleDb" );

        using ( DbConnection connection = factory.CreateConnection ( ) )
        {
            connection.ConnectionString = connectionString;

            using ( DbCommand command = connection.CreateCommand ( ) )
            {
                // Cities$ comes from the name of the worksheet
                command.CommandText = "SELECT ID  FROM [Sheet1$]";

                connection.Open ( );

                using ( DbDataReader dr = command.ExecuteReader ( ) )
                {
                    DataSet cities = new DataSet ( );
                    cities.Load ( dr, LoadOption.OverwriteChanges, new [] { "Sheet1" } );
                }
            }
        }

        return;
    }

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM