23

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

我需要解析一个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.

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

4

5 回答 5

42

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

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);
    }
}

而不是 OleDB,你可以使用一个像样的 CSV 解析器(或另一个)。

于 2011-07-25T09:50:47.087 回答
1

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

这样你就不必依赖其他去度假的开发者了。我已经使用了很多次,并且没有遇到任何障碍。

我已经从工作中发布了这个(因此我不能发布示例片段。我今晚回家时会这样做)。

于 2011-07-25T09:58:17.917 回答
0

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

Provider=Microsoft.ACE.OLEDB.12.0;Data Source=D:\TEST.csv;Extended Properties="Excel 12.0;HDR=YES";
于 2011-07-25T08:57:33.210 回答
0

尝试连接字符串:

"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D:\TEST.csv;Extended Properties=\"Excel 8.0;IMEX=1\""
于 2011-07-25T08:59:23.880 回答
0
 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\"";
于 2011-07-25T09:12:50.247 回答