我知道这个主题很无聊,但我也是一筹莫展。
我需要解析一个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.
我正在考虑扔掉所有的代码,从头开始。有什么明显的我做错了吗?
6条答案
按热度按时间fcg9iug31#
尝试连接字符串:
ttvkxqim2#
mi7gmzs63#
通过这篇文章,我发现在MS Access中,您还可以
hpcdzsge4#
您应该在连接字符串中只指定目录名。文件名将用于查询:
你可以使用decent CSV parser(或another one)来代替OleDB。
kjthegm65#
另一种解决方案是使用TextFieldParser类(.Net框架本身的一部分)https://learn.microsoft.com/en-us/dotnet/api/microsoft.visualbasic.fileio.textfieldparser
这样你就不用依赖其他去度假的开发商了,我用了这么多次,没有遇到任何障碍。
我已经从工作中发布了这个(因此我不能发布一个示例片段。我会在今晚回家时这样做)。
nzk0hqpo6#
看起来你的第一行包含列名,所以你需要包括HDR=YES属性,像这样: