Привязка вложенных списков с помощью лямбда (C #) - PullRequest
0 голосов
/ 26 сентября 2011

У меня есть этот кусок кода, который я пытаюсь преобразовать в лямбду -

 foreach (var facet in response.Result.Facets)
            {
                var newFacet = new Facet {Parent = facet.Title};

                foreach (var element in facet.Subelements)
                {
                    newFacet.Items.Add(new Facet
                                           {
                                               Title = element.Title,
                                               TotalResults = element.TotalResults
                                           });
                }

                searchModel.Facets.Add(newFacet);
            }

Вот что у меня есть -

response.Result.Facets.ForEach(x => searchModel.Facets.Add(new Facet
                                                                               {
                                                                                   Parent = x.Title,
                                                                                   Items = ???//x.Subelements.ForEach(y=>)
                                                                               }));

И классы -

public class Facet
{
    public Facet()
    {
        Items = new List<Facet>();
    }

    public string Parent { get; set; }
    public List<Facet> Items { get; set; }
    public int TotalResults { get; set; }
    public string Title { get; set; }
}



    public class SearchElement
    {
        public string Parent { get; set; }
        public string Title { get; set; }
        public int TotalResults { get; set; }
        public IList<ESearchElement> Subelements { get; set; }
    }

Как связать List<SearchElement> с List<Items> путем сопоставления каждого элемента (title = y.Title ..) в одной строке в лямбда-выражении?Возможно ли это?

1 Ответ

0 голосов
/ 26 сентября 2011

Попробуйте что-то вроде этого:

searchModel.Facets.AddRange(
    from facet in response.Result.Facets
    select new Facet
    {
        Parent = facet.Title,
        Items = new List<Facet>(
            from element in facet.Subelements
            select new Facet
            {
                Title = element.Title,
                TotalResults = element.TotalResults
            }),
    });

РЕДАКТИРОВАТЬ: лямбда-версия для запроса в комментарии.

searchModel.Facets.AddRange(
    response.Result.Facets.Select(
        facet => new Facet
        {
            Parent = facet.Title,
            Items = new List<Facet>(
                facet.Subelements.Select(
                    element => new Facet
                    {
                        Title = element.Title,
                        TotalResults = element.TotalResults
                    })),
        }));

Почти так же, как с LINQ.Это то, что вы были после?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...