我有string s = "158,141,90,86";
如何将它们转换为int []?
答案 0 :(得分:28)
int[] result = "158,141,90,86".Split(',').Select(int.Parse).ToArray();
答案 1 :(得分:17)
像这样,使用LINQ:
int[] array = s.Split(',')
.Select(x => int.Parse(x))
.ToArray();
请注意,如果文本的任何元素不是整数,则会抛出异常。如果您想使其更具弹性(例如,如果这是用户输入的数据),则需要使用int.TryParse
;在那一点上,就LINQ查询而言,生活变得有点复杂。
编辑:要使其解析为int?[]
(对应于每个无效子字符串的空值),您可以执行以下操作:
int?[] array = s.Split(',')
.Select(x => {
int value;
return int.TryParse(x, out value) ? value : (int?)null;
})
.ToArray();
正如我所说,这并不是非常好:(
编辑:Dan在评论中评论了对上述方法的“痴迷”,而不是(可能)更为迫切的方法。在我看来,即使是不太令人愉快的第二版仍然比必要的替代版本更容易阅读。丑陋只是由于int.TryParse
的丑陋性质,在命令式代码中使用时也同样难看。
如果int.TryParse
返回int?
或Tuple<bool, int>
,那么它就像第一个版本一样简单。即使从元组形式转换为可空形式也很简单,只需要一个额外的投影:
int[] array = s.Split(',')
.Select(x => int.TryParseTuple(x))
.Select(tuple => tuple.First ? tuple.Second : (int?) null)
.ToArray();
答案 2 :(得分:1)
当然,必要的解决方案是:
string[] sa = s.Split(',');
int?[] array = new int?[sa.Length];
int value;
for (int i = 0; i < sa.Length; i++)
if (int.TryParse(sa[i], out value))
array[i] = value;
else
array[i] = null;
答案 3 :(得分:1)
使用LINQ / int?[]的另一个解决方案是:
return source.Split(',')
.Select(x => {
int? value = null;
int parsed;
if (int.TryParse(x, out parsed)) {
value = parsed;
}
return value;
})
.ToArray();