[英]Change the foreach loop into the LINQ query
我陷入了一个简单的情况。 我有一个List<string>
对象,其所有项目的主体为:
item_1_2_generatedGUID //generatedGUID is Guid.NewGuid()
但可能会有更多的数字item_1_2_3_4_5_generatedGUID
等
现在,我想知道如何将循环更改为LINQ的查询。 有任何想法吗 ?
string one = "1"; //an exaplme
string two = "2"; //an exaplme
foreach (var item in myStringsList)
{
string[] splitted = item.Split(new char[] { '_' },
StringSplitOptions.RemoveEmptyEntries);
if(splitted.Length >= 3)
{
if(splitted[1] == one && splitted[2] == two)
{
resultList.Add(item);
}
}
}
var result = from s in lst
let spl = s.Split('_')
where spl.Length >= 3 && spl[1] = one && spl[2] == two
select s;
尝试这个:
var query = from item in myStringsList
let splitted = item.Split(new[] { '_' }, SSO.RemoveEmptyEntries)
where splitted.Length >= 3
where splitted[1] == one && splitted[2] == two
select item;
var resultList = query.ToList();
这是一种不同的方法:
var items = myStringsList.
Where(x => x.Substring(x.IndexOf("_")).StartsWith(one+"_"+two+"_"));
您可能需要在IndexOf中添加+1,但是我不确定。
它的作用是:
编辑:在第一个“位置”添加了任何内容的模式
var result = items.Where(i => Regex.IsMatch(i, "^[^_]_1_2_"));
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.