【问题标题】:Parsing CSV using OleDb using C#使用 C# 使用 OleDb 解析 CSV
【发布时间】:2011-10-12 10:03:24
【问题描述】:

我知道这个话题已经结束了,但我束手无策。

我需要解析一个 csv。这是一个相当普通的 CSV,解析逻辑是由另一位开发人员使用 OleDB 编写的,他在度假前发誓它可以工作:)

CSV sample:
Dispatch Date,Master Tape,Master Time Code,Material ID,Channel,Title,Version,Duration,Language,Producer,Edit Date,Packaging,1 st TX,Last TX,Usage,S&P Rating,Comments,Replace,Event TX Date,Alternate Title
,a,b,c,d,e,f,g,h,,i,,j,k,,l,m,,n,

我遇到的问题是根据我尝试的连接字符串出现各种错误。

当我尝试连接字符串时:

Provider=Microsoft.Jet.OLEDB.4.0;Data Source="D:\TEST.csv\";Extended Properties="text;HDR=No;FMT=Delimited"

我得到错误:

'D:\TEST.csv' is not a valid path.  Make sure that the path name is spelled correctly and that you are connected to the server on which the file resides.

当我尝试连接字符串时:

Provider=Microsoft.ACE.OLEDB.12.0;Data Source=D:\TEST.csv;Extended Properties=Excel 12.0;

或连接字符串

Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D:\TEST.csv;Extended Properties=Excel 8.0;

我得到错误:

External table is not in the expected format.

我正在考虑放弃所有代码并从头开始。有什么明显的我做错了吗?

【问题讨论】:

    标签: c# parsing csv oledb oledbconnection


    【解决方案1】:

    替代解决方案是使用 TextFieldParser 类(.Net 框架本身的一部分。)https://docs.microsoft.com/en-us/dotnet/api/microsoft.visualbasic.fileio.textfieldparser

    这样您就不必依赖其他去度假的开发人员。我用了很多次,没有遇到任何问题。

    我已经在工作中发布了这个(因此我无法发布示例 sn-p。我今晚回家时会这样做)。

    【讨论】:

    • 一个简短的例子将是对这个答案的一个很好的补充。
    • @Carol - 我会这样做的。我一定是在工作时发布了答案,因此无法发布示例。我今晚回家时会这样做。
    • @Carol 周围有很多。 This 是我不久前在 SO 上发布的。
    【解决方案2】:

    您应该只在连接字符串中指明目录名称。文件名将用于查询:

    var filename = @"c:\work\test.csv";
    var connString = string.Format(
        @"Provider=Microsoft.Jet.OleDb.4.0; Data Source={0};Extended Properties=""Text;HDR=YES;FMT=Delimited""", 
        Path.GetDirectoryName(filename)
    );
    using (var conn = new OleDbConnection(connString))
    {
        conn.Open();
        var query = "SELECT * FROM [" + Path.GetFileName(filename) + "]";
        using (var adapter = new OleDbDataAdapter(query, conn))
        {
            var ds = new DataSet("CSV File");
            adapter.Fill(ds);
        }
    }
    

    您可以使用decent CSV parser(或another one)代替OleDB。

    【讨论】:

    • 我感激不尽!你能指点我一些像样的csv解析器吗?另外我在哪里可以阅读连接字符串?到目前为止,这对我来说就像巫术一样。
    • @Zulfi Tapia,我已经在我的回答末尾指出了 2 个 decent CSV 解析器。
    • 我建议使用另一个备用 CSV 解析器,它也来自 Microsoft。请参阅下面以“替代解决方案...”开头的我的答案
    • 为我工作,文件名中有一个空格。感谢您提供简单、干净的解决方案!
    【解决方案3】:
     var  s=@"D:\TEST.csv";
     string dir = Path.GetDirectoryName(s);
     string sConnection = "Provider=Microsoft.Jet.OLEDB.4.0;"
                           + "Data Source=\"" + dir + "\\\";"
                           + "Extended Properties=\"text;HDR=YES;FMT=Delimited\"";
    

    【讨论】:

    • 这使我摆脱了上面提到的两个错误,但是由于我们直接查看目录,因此如何指定要拾取的文件?它崩溃并告诉我The Microsoft Jet database engine could not find the object 'TEST$.txt'. Make sure the object exists and that you spell its name and the path name correctly.
    【解决方案4】:

    尝试连接字符串:

    "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D:\TEST.csv;Extended Properties=\"Excel 8.0;IMEX=1\""
    

    【讨论】:

    • 不,External table is not in the expected format. 仍然... :)
    【解决方案5】:

    您的第一行似乎包含列名,因此您需要包含 HDR=YES 属性,如下所示:

    Provider=Microsoft.ACE.OLEDB.12.0;Data Source=D:\TEST.csv;Extended Properties="Excel 12.0;HDR=YES";
    

    【讨论】:

    • 是的,第一列是标题。 External table is not in the expected format.还是
    猜你喜欢
    • 1970-01-01
    • 2011-12-12
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多