LINQ:如何在 ObjectCollection 中加入嵌套列表

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)

在写这个问题时,我找到了解决问题的方法。我仍然会发布(并回答)这个问题,因为这个问题对我来说是一个真正的问题。我在这里没有找到合适的现有问题。

乔,尤文

Dav*_*und 6

我相信这个问题可以通过SelectMany和来解决Distinct

var allLetters = myGroups.SelectMany(go => go.letters);
var allUniqueLetters = allLetters.Distinct();
Run Code Online (Sandbox Code Playgroud)

第二个变量名称具有误导性。除了其他字母外,它将返回 的一个实例"m",这在原始集合中不是唯一的 ;)