Juv*_*uve 4 sql linq nested-lists
是否可以在不使用 foreach 循环的情况下为以下问题定义 LINQ 语句?
public class GroupObject
{
public String name;
public List<String> letters;
public void test()
{
List<GroupObject> myGroups = new List<GroupObject> {
new GroupObject {
name="test1",
letters=new List<String>{"x","y","z"}
},
new GroupObject {
name="test2",
letters=new List<String>{"l","m","n"}
},
new GroupObject {
name="test3",
letters=new List<String>{"m","x","z"}
}
};
// LINQ problem 1: how to get a list of all 9 letters
// List<string> allLetters = (from ...).ToList();
// LINQ problem 2: how to get a list of all 6 DISTINCT letters
// List<string> allDistictLetters = (from ...).ToList();
}
}
Run Code Online (Sandbox Code Playgroud)
在写这个问题时,我找到了解决问题的方法。我仍然会发布(并回答)这个问题,因为这个问题对我来说是一个真正的问题。我在这里没有找到合适的现有问题。
乔,尤文
我相信这个问题可以通过SelectMany
和来解决Distinct
!
var allLetters = myGroups.SelectMany(go => go.letters);
var allUniqueLetters = allLetters.Distinct();
Run Code Online (Sandbox Code Playgroud)
第二个变量名称具有误导性。除了其他字母外,它将返回 的一个实例"m"
,这在原始集合中不是唯一的 ;)
归档时间: |
|
查看次数: |
3518 次 |
最近记录: |