string tags = "9,3,12,43,2"

List<int> TagIds = tags.Split(',');

这行不通,因为split方法返回一个字符串[]


当前回答

这里有一种方法:

List<int> TagIds = tags.Split(',').Select(int.Parse).ToList();

其他回答

如果没有LINQ Query,你可以选择这个方法,

string tags = "9,3,12,43,2";
List<string> numbers = nos.Split(',').ToList<string>();

然后你可以把这个List转换成整数类型…

string tags = "9,3,12,43,2";
List<int> TagIds = tags.Split(',').Select(int.Parse).ToList();

如果你想包含一些简单的验证并跳过无效值(而不是抛出异常),这里有一些使用TryParse的东西:

string csv = "1,2,3,4,a,5";
int mos = 0;
var intList = csv.Split(',')
                    .Select(m => { int.TryParse(m, out mos); return mos; })
                    .Where(m => m != 0)
                    .ToList();

//returns a list with integers: 1, 2, 3, 4, 5

编辑:以下是根据Antoine的反馈更新的查询。它首先调用TryParse来过滤掉任何错误的值,然后再调用Parse来进行实际的转换。

string csv = "1,2,3,4,a,5,0,3,r,5";
int mos = 0;
var intList = csv.Split(',')
                    .Where(m => int.TryParse(m, out mos))
                    .Select(m => int.Parse(m))
                    .ToList();

//returns a list with integers: 1, 2, 3, 4, 5, 0, 3, 5

编辑2:c# 7.0的更新查询,感谢Charles Burns的反馈。注意,我们用这种方法去掉了额外的mos变量,所以它更简洁一些。

string csv = "1,2,3,4,a,5,0,3,r,5";
var intList = csv.Split(',')
                 .Where(m => int.TryParse(m, out _))
                 .Select(m => int.Parse(m))
                 .ToList();

如果你正在使用c# 3.5,你可以使用Linq来实现这一点

string tags = "9,3,12,43,2";
List<int> tagIds = tags.Split(',').Select(s=>int.Parse(s)).ToList();

还是短的那个

string tags = "9,3,12,43,2";
List<int> tagIds = tags.Split(',').Select(int.Parse).ToList();

这很简单。首先拆分字符串。 修改逗号(,)后的空格。 然后使用系统定义的ToList()

string inputText = "text1, text2"

删除','后的空格,并将此逗号分隔的文本转换为List

List<string> resultList = (inputText.Split(',')).Select(t => t).ToList();