寻找一种简洁的方法将字符串列表转换为C#</long>中的有效List <long>

时间:2012-11-23 16:22:23

标签: c# c#-4.0

我希望找到一种更好的方法(可能有一个很好的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);
    }
}

5 个答案:

答案 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));