使用OleDbCommand / OleDbDataAdapter读取CSV文件

时间:2010-11-12 13:57:13

标签: c# .net ado.net csv

我无法弄清楚原因,但是当我使用OleDbDataAdapter或OleDbCommand读取CSV文件时,在这两种情况下,结果数据结构良好(它识别文件头中的列),但行数据全部为空字符串。

我多次成功完成了CSV处理,因此我发现该文件的唯一区别是文件中的所有字段都用引号括起来。
我尝试过使用schema.ini文件,但无济于事。这感觉就像Microsoft Jet 4.0组件的一个问题,但我无法弄清楚问题是什么。

以下是该文件的摘录:

"UNIQUEID","OWNERID","PHONE1","PHONE2","EMERGENCYCONTACT","ADDRESS1","ADDRESS2","ADDRESS3","ADDRESSCITY","ADDRESSSTATE","ADDRESSZIP","UNIONCODE","CUSTOM1","CUSTOM2","CUSTOM3","CUSTOM4","CUSTOM5","CUSTOM6"
"5","33","1235551212","          ","","1914 SANDFLAT ROAD","","","THOMASVILLE","AL","367849215","","contract","7.75","1","N","","A"
"6","34","1235551212","          ","","1407 OLD HWY. 5 SOUTH","","","THOMASVILLE","AL","36784","","contract","7.75","1","N","","B"
"7","35","1235551212","          ","","P.O. BOX 204","","","THOMASVILLE","AL","36784","","substitute","7.75","0","Y","","M"
"8","36","1235551212","          ","","383 UNCLE BEN RD","","","THOMASVILLE","AL","36784","","substitute","0.00","0","","",""

这是我目前的代码:

OleDbConnection conn = new OleDbConnection(
    "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=c:\\payroll;" + 
    "Extended Properties=\"text;HDR=Yes;FMT=CSVDelimited\"");
OleDbDataAdapter adapter = new OleDbDataAdapter("select * from file.txt", conn);
DataTable dt = new DataTable();
adapter.Fill(dt);

以下是schema.ini文件的内容。没有它我就无法读取文件:

[file.txt]
Format=CSVDelimited
ColNameHeader=True
Col1="UNIQUEID" Text
Col2="OWNERID" Text
Col3="PHONE1" Text
Col4="PHONE2" Text
Col5="EMERGENCYCONTACT" Text
Col6="ADDRESS1" Text
Col7="ADDRESS2" Text
Col8="ADDRESS3" Text
Col9="ADDRESSCITY" Text
Col10="ADDRESSSTATE" Text
Col11="ADDRESSZIP" Text
Col12="UNIONCODE" Text
Col13="CUSTOM1" Text
Col14="CUSTOM2" Text
Col15="CUSTOM3" Text
Col16="CUSTOM4" Text
Col17="CUSTOM5" Text
Col18="CUSTOM6" Text
CharacterSet=ANSI

2 个答案:

答案 0 :(得分:2)

我发现了问题所在。 schema.ini文件中的字符集设置为ANSI。文件编码是Unicode。将字符集设置为Unicode解决了这个问题。

答案 1 :(得分:1)

另一个出色的选择是使用FileHelpers库@ www.filehelpers.com

它比喷气引擎更具抽象性和灵活性,允许您执行诸如导入文件之类的操作,以便通过自定义直接构建您的类型的集合。

FileHelperEngine engine = new FileHelperEngine(); 列出customers = engine.ReadFile(“File.csv”);

这只是一个开始,然后你可以通过在你的收藏中使用linq运算符来更清洁。

Sk8tz