2

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

4 回答 4

3
var result = from s in lst 
             let spl = s.Split('_')
             where spl.Length >= 3 && spl[1] = one  && spl[2] == two
             select s;
于 2012-05-22T17:00:44.750 回答
2

这是一种不同的方法:

var items = myStringsList.
            Where(x => x.Substring(x.IndexOf("_")).StartsWith(one+"_"+two+"_"));

您可能需要在 IndexOf 中添加 +1,但我不确定。

它的作用是:

  • 删除第一项(即子字符串)。在您的示例中,它应该是“1_2_3_4_5_generatedGUID”
  • 检查字符串是否以您期望的开头。在你的例子中:1_2_
于 2012-05-22T17:07:13.543 回答
2

尝试这个:

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();
于 2012-05-22T16:56:53.083 回答
0

编辑:在第一个“位置”添加了任何东西的模式

var result = items.Where(i => Regex.IsMatch(i, "^[^_]_1_2_"));
于 2012-05-22T17:09:02.890 回答