0

这是我从 csv 得到的字符串:

string input = "Volume,447,\"4,325\",142,144";

我想要在我的数组行中:

447
4,325
142
144

我尝试了什么:

string[] volumes;
if (input.Contains(",\"")) // if they're all double value, it works
     volumes = input.Split(new[] {",\""}, StringSplitOptions.None);
else
     volumes= input.Split(','); // if they're all integer value it works
else
     // what to do if they have both double and integer?
4

1 回答 1

1

您将需要参考 Microsoft.VisualBasic(如果您使用 C# 编码,则为事件)来编译以下代码。

    private string[] ParseCsv(string line)
    {
        var parser = new TextFieldParser(new StringReader(line));
        parser.TextFieldType = FieldType.Delimited;
        parser.SetDelimiters(",");
        while (!parser.EndOfData)
        {
            return parser.ReadFields();
        }
        parser.Close();
        return new string[0];
    }
于 2013-07-20T21:43:17.803 回答