Parser / pembaca CSV untuk C #? [Tutup]

89

is there a good and free implementation of CSV parser available under some liberal licence? Some counterpart of SuperCSV for Java, perhaps a port?

Bartosz Radaczyński
sumber
5
menggunakan Microsoft.VisualBasic.FileIO.TextFieldParser;
1
Tidak konstruktif? SO admin sangat gila. Ini adalah pertanyaan yang SANGAT membantu.
richard

Jawaban:

70

FileHelpers Open Source Library .

Keltex
sumber
24
FileHelpers (untuk CSV setidaknya) mengharuskan Anda "menentukan kelas yang memetakan ke catatan dalam sumber (file)", "Anda harus mendeklarasikan Kelas Pemetaan Rekaman" dll. Dan ini tidak terlalu panas. Saya ingin mengubah CSV menjadi DataTable, tanpa mengetahui sebelumnya berapa banyak kolom yang diharapkan.
Konrad Morawski
53

Ada implementasi yang bagus di CodeProject :

Untuk memberikan lebih banyak angka yang membumi, dengan file CSV 45 MB yang berisi 145 bidang dan 50.000 catatan, pembaca memproses sekitar 30 MB / detik. Jadi secara keseluruhan, butuh 1,5 detik! Spesifikasi mesin adalah P4 3.0 GHz, 1024 MB.

Anton Gogolev
sumber
(mengambil kembali +1 saya): Saya baru saja merusak pembaca CSV Cepat lumenworks pada file 53Mb. Sepertinya cache baris gagal setelah 43.000 baris dan buffer diacak. Microsoft.VisualBasic.FileIO.TextFieldParseSudah mencoba dan berhasil.
Gone Coding
11

Anda dapat memuat file CSV ke DataTable.

Kode sampel -

static DataTable CsvToDataTable(string strFileName)
{
    DataTable dataTable = new DataTable("DataTable Name");

    using (OleDbConnection conn = new OleDbConnection("Provider=Microsoft.Jet.OleDb.4.0; Data Source = " + Directory.GetCurrentDirectory() + "; Extended Properties = \"Text;HDR=YES;FMT=Delimited\""))
    {
        conn.Open();
        string strQuery = "SELECT * FROM [" + strFileName + "]";
        OleDbDataAdapter adapter = 
            new System.Data.OleDb.OleDbDataAdapter(strQuery, conn);
        adapter.Fill(dataTable);
    }
    return dataTable;
}

Pastikan Anda mengkompilasi proyek Anda ke prosesor x86. Tidak berfungsi untuk x64.

Pepatah
sumber
1
ini bekerja cukup baik untuk saya karena saya ingin tetap menggunakan pustaka ODBC atau OLEDB bawaan. Btw, berikut ini memiliki contoh kode tambahan untuk OLEDB dan ODBC: csvreader.com/csv_benchmarks.php
Meringros
5
Sayangnya, ini tidak berfungsi pada 64 bit.
DenNukem
7

try filehelpers Work amazingly well. I am using it to parse a 100 MB file every day.

no_one
sumber
3

I've started using CSV Parser that is part of the CommonLibrary.NET.

It uses .NET 3.5, has an easy API, and convenient overloads/methods & lamda's for iterations.

I don't have any benchmarks for this one like above, but nice thing about this is that it's just one component of a library similar to Java Commons. So I also get a Command-line parser, Repository implementation among other things.

zhao
sumber