6

「41,42x、43」のような文字列リストを有効なlongのリストに変換するためのより良い方法(おそらく素敵なlinq式を使用)を見つけたいと思っています。以下のコードは機能しますが、醜い感じがします。

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エントリごとに1回だけ呼び出されることです。

于 2012-11-23T16:34:11.140 に答える
0

コードの派生であり、非常に冗長です(TryParseを使用してから、もう一度Parseを使用します)が、機能すると思います。

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 に答える