Разбор CSV с использованием OleDb с использованием C # - PullRequest
21 голосов
/ 25 июля 2011

Я знаю, что эта тема сделана до смерти, но я нахожусь в тупике.

Мне нужно разобрать CSV.Это довольно обычный CSV, и логика синтаксического анализа была написана с использованием OleDB другим разработчиком, который поклялся, что он работает до того, как уйти в отпускя пытаюсь установить строку подключения.

, когда пытаюсь установить строку подключения:

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.

Я собираюсь выбросить весь код и начать с нуля.Есть что-то очевидное, что я делаю не так?

Ответы [ 5 ]

39 голосов
/ 25 июля 2011

Вы должны указать только имя каталога в строке подключения.Имя файла будет использоваться для запроса:

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-парсер (или другой ).

1 голос
/ 25 июля 2011

Альтернативным решением является использование класса TextFieldParser (часть самой .Net framework.) https://docs.microsoft.com/en-us/dotnet/api/microsoft.visualbasic.fileio.textfieldparser

Таким образом, вам не нужно полагаться на другого разработчика, который уехал в отпуск. Я использовал его так много раз и ни разу не наткнулся.

Я отправил это с работы (поэтому я не могу опубликовать пример фрагмента. Я сделаю это, когда вернусь домой этим вечером).

0 голосов
/ 25 июля 2011

Попробуйте строку подключения:

"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D:\TEST.csv;Extended Properties=\"Excel 8.0;IMEX=1\""
0 голосов
/ 25 июля 2011
 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\"";
0 голосов
/ 25 июля 2011

Кажется, ваша первая строка содержит имена столбцов, поэтому вам нужно включить свойство HDR = YES, например:

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