Как читать двойные кавычки ("") в CsvReader с помощью С#?

Я пытаюсь прочитать файл csv, используя следующий код. Это исключение, если в данных есть двойные кавычки (""). Я хочу обрабатывать все специальные символы во время чтения.

using (TextReader reader = new StreamReader("C:\\test\test.csv"))
{
    using (CsvReader csv = new CsvReader(reader, CultureInfo.InvariantCulture))
    {
        csv.Read();
        csv.ReadHeader();
        while (csv.Read())
        {
           var result= csv[0].Split(';');
        }
     }
}

Мой файл CSV: строка csv.Read не работает в строке № 3

Name;Location;State;Country
Keka1;Lansing; MI; USA
Keka2;"Ohio"; OH; USA  // Error at this line 
Keka3;Lansing; MI; USA

Я не хочу избегать кавычек, но хочу включить их. Пожалуйста посоветуй.

TextFieldParser Класс
GSerg 16.05.2022 22:30

С библиотекой CSV вам не понадобится Split(';').

Henk Holterman 16.05.2022 22:46

Вам нужно установить CsvConfiguration.Delimiter = ";", как показано в этот ответ, на Как мы можем написать разделитель, например, sep=, используя библиотеку CsvHelper?. Тогда все должно быть готово. Вам не нужно будет делать csv[0].Split(';');, так как библиотека разделит строки на ячейки, используя указанный разделитель. На самом деле я думаю, что это дубликат этого вопроса, согласны?

dbc 16.05.2022 22:59

Да, var config = new CsvConfiguration(CultureInfo.CurrentCulture) { Delimiter = ";" }; и тогда using (var csv = new CsvReader(reader, config)) работает, см. dotnetfiddle.net/SnBQAg. Закрытие как дубликат.

dbc 16.05.2022 23:57
Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
1
4
51
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Какой CsvReader класс вы используете? (Я создал такой класс под названием SoftCircuits.CsvParser.)

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

Я использую класс CsvHelper. Я хочу читать построчно

aka baka 16.05.2022 22:38

Я протестировал класс SoftCircuits.CsvParser, и он прекрасно обрабатывает кавычки.

aka baka 16.05.2022 22:56

Другие вопросы по теме