将 foreach 循环更改为 LINQ 查询

本文关键字:LINQ 查询 foreach 循环 | 更新日期: 2023-09-27 18:35:10

我陷入了一个简单的场景。我有一个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);
          }
      }
  }

将 foreach 循环更改为 LINQ 查询

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,但我不确定。

它的作用是:

  • 删除第一项(即其子字符串)。在您的示例中,它应该是"1_2_3_4_5_generatedGUID"
  • 检查字符串是否以预期内容开头。在您的示例中:1_2_

已编辑:在第一个"位置"添加了任何内容的模式

var result = items.Where(i => Regex.IsMatch(i, "^[^_]_1_2_"));