调整csv阅读器以读取unicode字符

时间:2012-06-18 10:41:06

标签: c# unicode

我遇到的问题是csv文件中的字符是黑色的钻石吗?在中间。

我已经编写了解析csv的代码,但我不明白为什么字符串没有正确读取unicode字符。这可能与我的实施有关:

StreamReader readFile = new StreamReader(path)

try {
  while ((line = readFile.ReadLine()) != null) {
    string[] row = { "", "", "" };
    int currentItem = 0;
    bool inQuotes = false;
    if (skippedFirst && currentItem != 3) {
      for (int i = 0; i < line.Length; i++) {
        if (!inQuotes) {
          if (line[i] == '\"')
            inQuotes = true;
          else {
            if (line[i] == ',')
              currentItem++;
            else
              row[currentItem] += line[i];
          }
        } else {
          if (line[i] == '\"')
            inQuotes = false;
          else
            row[currentItem] += line[i];
        }
      }
      parsedFile.Add(row);
    }
    skippedFirst = true;
  }

1 个答案:

答案 0 :(得分:5)

打开文件时指定编码。

using (var sr = new StreamReader(@"c:\Temp\csvfile.csv", Encoding.UTF8)) {
}

您可能还想查看Filehelpers以进行CSV解析:

http://www.filehelpers.com/quick_start.html