我希望找到一种更好的方法(可能有一个很好的linq表达式)将像“41,42x,43”这样的字符串列表转换为有效long的列表。以下代码有效,但感觉很难看。
string addressBookEntryIds = "41,42x,43";
var ids = addressBookEntryIds.Split(new[] {',', ';'}, StringSplitOptions.RemoveEmptyEntries);
var addressBookEntryIdList =new List<long>();
foreach (var rec in ids)
{
long val;
if (Int64.TryParse(rec, out val))
{
addressBookEntryIdList.Add(val);
}
}
答案 0 :(得分:4)
string addressBookEntryIds = "41,42x,43";
Func<string, long?> safeParse = (s) => {
long val;
if (Int64.TryParse(s, out val))
{
return val;
}
return null;
};
var longs = (from s in addressBookEntryIds.Split(new[] {',', ';'}, StringSplitOptions.RemoveEmptyEntries)
let cand = safeParse(s)
where cand.HasValue
select cand.Value).ToList();
答案 1 :(得分:3)
使用正则表达式
var list = Regex.Matches(@"41,42x,43", @"\d+").Cast<Match>().Select(x => Convert.ToInt64(x.Value)).ToList();
答案 2 :(得分:1)
嗯,这是一个LINQ版本,但它并不是那么难看!
string addressBookEntryIds = "41,42x,43";
var ids = addressBookEntryIds.Split(new[] { ',', ';' }, StringSplitOptions.RemoveEmptyEntries);
Int64 converted; // Working value used within the select
IEnumerable<Int64> values = ids.Select(x => new
{
Success = Int64.TryParse(x, out converted),
Value = converted
}).Where(x => x.Success)
.Select(x => x.Value);
此解决方案与安德森之间的区别在于TryParse
每个条目只调用一次。
答案 3 :(得分:1)
这是另一个LINQ版本:
String addressBookEntryIds = "41,42x,43";
Int64 val = 0;
addressBookEntryIds
.Split(new[] {',', ';'}, StringSplitOptions.RemoveEmptyEntries)
.Where(id => Int64.TryParse(id, out val))
.Select(id => val)
.ToList()
如果您更喜欢查询表达式,可以使用:
from id in addressBookEntryIds.Split(new[] {',', ';'}, StringSplitOptions.RemoveEmptyEntries)
where Int64.TryParse(id, out val)
select val
答案 4 :(得分:0)
只是你的代码的推导,非常多余(使用TryParse然后再次解析),但我认为它有效:
addressBookEntryIds.Split(new[] { ',', ';' }, StringSplitOptions.RemoveEmptyEntries)
.Where(id =>
{
long val;
return Int64.TryParse(id, out val);
})
.Select(id => Int64.Parse(id));