首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在CsvReader中使用c#读取双引号(")?

如何在CsvReader中使用c#读取双引号(")?
EN

Stack Overflow用户
提问于 2022-05-16 20:19:01
回答 1查看 349关注 0票数 -1

我正在尝试使用以下代码读取csv文件。如果数据中有双引号("),它会抛出一个异常。我想在阅读时处理所有特殊字符。

代码语言:javascript
复制
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在line# 3上失败了

代码语言:javascript
复制
Name;Location;State;Country
Keka1;Lansing; MI; USA
Keka2;"Ohio"; OH; USA  // Error at this line 
Keka3;Lansing; MI; USA

我不想转义引号,但想包括它。请指点。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-05-16 20:28:21

您使用的是哪个CsvReader类?(我编写了一个这样的类,名为SoftCircuits.CsvParser。)

不管怎样,你没有正确地使用它。您所拥有的代码只需使用一个常规的输入流,因为您似乎一次读取一行,然后解析它。CSV阅读器将为您解析它,并使用双引号处理字段。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72265138

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档