如何使用LINQ查找第一个匹配项

4th*_*ace 8 .net c# linq

使用.NET LINQ,我想找到以PID等于0或1开头的条目(Name).但如果Name同时包含两者,我只想要0.在下面:

PID Name
 0  P1
 1  P1
 1  P3
 0  P4
 0  P5
 1  P5
Run Code Online (Sandbox Code Playgroud)

我会找回行:

 0 P1
 1 P3
 0 P4
 0 P5
Run Code Online (Sandbox Code Playgroud)

PID值可以达到10.任何建议如何做到这一点?

Ree*_*sey 12

您可以使用:

var results = collection
               .Where(item => item.PID == 0 || item.PID == 1)
               .GroupBy(item => item.Name)
               .Select(g => g.OrderBy(item => item.PID).First());
Run Code Online (Sandbox Code Playgroud)

  • @Reed Copsey我认为你需要按item.Name分组,但否则这看起来像答案. (2认同)