C# 如何从列表中查找特定项目及其相关项目

C# How to find specific item and it's related items from list

我有以下class

public class Item
{
    public int Id { get; set; }
    public int ParentId { get; set; }
    public string Content { get; set; }
    public bool IsLastItem { get; set; }
}

假设我有以下型号,我想通过 ID 及其相关项目 ID 查找特定项目。在这种情况下,我想找到 item9 的 ID 及其相关的项目 ID。

结果应包含 9、10、11、12、13、14

我从数据库中获取我的模型列表,并在代码块中像这样模拟它

var items = new List<Item>
{
    new Item
    {
        Id = 1,
        ParentId = 0,
        Content = "item1",
        IsLastItem = false
    },
    new Item
    {
        Id = 2,
        ParentId = 1,
        Content = "item2",
        IsLastItem = false
    },
    new Item
    {
        Id = 3,
        ParentId = 1,
        Content = "item3",
        IsLastItem = true
    },
    new Item
    {
        Id = 4,
        ParentId = 1,
        Content = "item4",
        IsLastItem = true
    },
    new Item
    {
        Id = 5,
        ParentId = 2,
        Content = "item5",
        IsLastItem = false
    },
    new Item
    {
        Id = 6,
        ParentId = 5,
        Content = "item6",
        IsLastItem = false
    },
    new Item
    {
        Id = 7,
        ParentId = 5,
        Content = "item7",
        IsLastItem = false
    },
    new Item
    {
        Id = 8,
        ParentId = 6,
        Content = "item8",
        IsLastItem = true
    },
    new Item
    {
        Id = 9,
        ParentId = 7,
        Content = "item9",
        IsLastItem = false
    },
    new Item
    {
        Id = 10,
        ParentId = 9,
        Content = "item10",
        IsLastItem = true
    },
    new Item
    {
        Id = 11,
        ParentId = 9,
        Content = "item11",
        IsLastItem = false
    },
    new Item
    {
        Id = 12,
        ParentId = 11,
        Content = "item12",
        IsLastItem = true
    },
    new Item
    {
        Id = 13,
        ParentId = 11,
        Content = "item13",
        IsLastItem = true
    },
    new Item
    {
        Id = 14,
        ParentId = 11,
        Content = "item14",
        IsLastItem = true
    }
};

您可以使用 linq,下面的内容应该可以帮助您入门...

var parent = items.First(x => x.Content == "item9");
var children = items.Where(x => x.Id == parent.Id);

你需要一个递归方法

// Start finding the base item to start the recursive search
Item x = items.Where(i => i.Id == 9).FirstOrDefault();
List<Item> found = Search(items, x);

// Insert the starting item at the first position (Add is also good but...)
found.Insert(0, x);



public List<Item> Search(List<Item> list, Item parent)
{
    // Prepare the list to return...
    List<Item> found = new List<Item>();
    if (parent != null)
    {
        // Search all the items that have the parent passed
        List<Item> temp = list.Where(x => x.ParentId == parent.Id).ToList();
        // Add the list to the return variable
        found.AddRange(temp);
        // For each child of this parent look for their childs
        foreach(Item x in temp)
            found.AddRange(Search(list, x));
    }
    return found;
}