6

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

5 回答 5

5
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();
于 2012-11-23T16:37:02.070 回答
3

使用正则表达式

var list = Regex.Matches(@"41,42x,43", @"\d+").Cast<Match>().Select(x => Convert.ToInt64(x.Value)).ToList();
于 2012-11-23T16:25:50.247 回答
2

这是另一个 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
于 2012-11-25T00:31:03.673 回答
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每个条目仅调用一次。

于 2012-11-23T16:34:11.140 回答
0

只是您的代码的派生,非常多余(使用 TryParse 然后再次解析),但我认为它有效:

addressBookEntryIds.Split(new[] { ',', ';' }, StringSplitOptions.RemoveEmptyEntries)
                   .Where(id => 
                   {
                       long val;
                       return Int64.TryParse(id, out val);
                   })
                   .Select(id => Int64.Parse(id));
于 2012-11-23T16:31:37.663 回答