string tags = "9,3,12,43,2"
List<int> TagIds = tags.Split(',');
这行不通,因为split方法返回一个字符串[]
string tags = "9,3,12,43,2"
List<int> TagIds = tags.Split(',');
这行不通,因为split方法返回一个字符串[]
当前回答
如果你想包含一些简单的验证并跳过无效值(而不是抛出异常),这里有一些使用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();
其他回答
这很简单。首先拆分字符串。 修改逗号(,)后的空格。 然后使用系统定义的ToList()
string inputText = "text1, text2"
删除','后的空格,并将此逗号分隔的文本转换为List
List<string> resultList = (inputText.Split(',')).Select(t => t).ToList();
这里有一种方法:
List<int> TagIds = tags.Split(',').Select(int.Parse).ToList();
我偶然发现了这个,我只是想分享我自己的解决方案没有linq。这是一种原始方法。非整数值也不会被添加到列表中。
List<int> TagIds = new List<int>();
string[] split = tags.Split(',');
foreach (string item in split)
{
int val = 0;
if (int.TryParse(item, out val) == true)
{
TagIds.Add(val);
}
}
希望这能有所帮助。
你可以使用LINQ w/ int. parse()将字符串[]转换为IEnumerable<int>,然后将结果传递给List<T>构造函数:
var tagIds = new List<int>(tags.Split(',').Select(s => int.Parse(s)));
如果没有LINQ Query,你可以选择这个方法,
string tags = "9,3,12,43,2";
List<string> numbers = nos.Split(',').ToList<string>();
然后你可以把这个List转换成整数类型…