如何将分隔的字符串split()分割为List <string> </string>

时间:2012-02-13 16:03:28

标签: c# .net list arraylist

我有这段代码:

    String[] lineElements;       
    . . .
    try
    {
        using (StreamReader sr = new StreamReader("TestFile.txt"))
        {
            String line;
            while ((line = sr.ReadLine()) != null)
            {
                lineElements = line.Split(',');
                . . .

但后来认为我应该选择List。但是这段代码:

    List<String> listStrLineElements;
    . . .
    try
    {
        using (StreamReader sr = new StreamReader("TestFile.txt"))
        {
            String line;
            while ((line = sr.ReadLine()) != null)
            {
                listStrLineElements = line.Split(',');
. . .

...给我,“无法将类型'string []'隐式转换为'System.Collections.Generic.List'

7 个答案:

答案 0 :(得分:257)

string.Split()返回一个数组 - 您可以使用ToList()将其转换为列表:

listStrLineElements = line.Split(',').ToList();

您需要导入System.Linq才能访问.ToList()函数。

答案 1 :(得分:56)

使用:

List<string> list = new List<string>(array);

或来自LINQ:

List<string> list = array.ToList();

或者将代码更改为不依赖于特定的实现:

IList<string> list = array; // string[] implements IList<string>

答案 2 :(得分:10)

包含使用名称空间System.Linq

List<string> stringList = line.Split(',').ToList();

您可以轻松地使用它来迭代每个项目。

foreach(string str in stringList)
{

}

String.Split()返回一个数组,因此使用ToList()

将其转换为列表

答案 3 :(得分:5)

您可以使用using System.Linq;

List<string> stringList = line.Split(',')     // this is array
 .ToList();     // this is a list which you can loop in all split string

答案 4 :(得分:3)

这将读取一个csv文件,它包含一个处理双引号的csv换行符,即使excel打开它也能读取。

    public List<Dictionary<string, string>> LoadCsvAsDictionary(string path)
    {
        var result = new List<Dictionary<string, string>>();

        var fs = new FileStream(path, FileMode.Open, FileAccess.Read, FileShare.ReadWrite);
        System.IO.StreamReader file = new System.IO.StreamReader(fs);

        string line;

        int n = 0;
        List<string> columns = null;
        while ((line = file.ReadLine()) != null)
        {
            var values = SplitCsv(line);
            if (n == 0)
            {
                columns = values;
            }
            else
            {
                var dict = new Dictionary<string, string>();
                for (int i = 0; i < columns.Count; i++)
                    if (i < values.Count)
                        dict.Add(columns[i], values[i]);
                result.Add(dict);
            }
            n++;
        }

        file.Close();
        return result;
    }

    private List<string> SplitCsv(string csv)
    {
        var values = new List<string>();

        int last = -1;
        bool inQuotes = false;

        int n = 0;
        while (n < csv.Length)
        {
            switch (csv[n])
            {
                case '"':
                    inQuotes = !inQuotes;
                    break;
                case ',':
                    if (!inQuotes)
                    {
                        values.Add(csv.Substring(last + 1, (n - last)).Trim(' ', ','));
                        last = n;
                    }
                    break;
            }
            n++;
        }

        if (last != csv.Length - 1)
            values.Add(csv.Substring(last + 1).Trim());

        return values;
    }

答案 5 :(得分:3)

试试这个 List stringList = line.Split(&#39;,&#39;)。ToList();

答案 6 :(得分:2)

我使用这种扩展方法来处理 null 输入并删除多余的空格

public static List<string> CsvToList(this string csv)
{
    if (string.IsNullOrEmpty(csv))
    {
        return new List<string>();
    }

    return csv.Split(',').Select(item => item.Trim()).ToList();
}

请注意,如果输入的 CSV 是:“Apple、Orange、Pear”,我们希望去掉逗号后的空格。