programing

linq 식으로 중첩된 객체를 평탄화하는 방법

magicmemo 2023. 5. 21. 11:19
반응형

linq 식으로 중첩된 객체를 평탄화하는 방법

다음과 같이 중첩된 개체를 평평하게 만들려고 합니다.

public class Book
{
    public string Name { get; set; }
    public IList<Chapter> Chapters { get; set; }
}

public class Chapter
{
    public string Name { get; set; }
    public IList<Page> Pages { get; set; }
}


public class Page
{
    public string Name { get; set; }
}

예를 들어 보겠습니다.이것은 제가 가지고 있는 자료입니다.

Book: Pro Linq 
{ 
   Chapter 1: Hello Linq 
   {
      Page 1, 
      Page 2, 
      Page 3
   },
   Chapter 2: C# Language enhancements
   {
      Page 4
   },
}

제가 찾고 있는 결과는 다음과 같은 플랫 리스트입니다.

"Pro Linq", "Hello Linq", "Page 1"
"Pro Linq", "Hello Linq", "Page 2"
"Pro Linq", "Hello Linq", "Page 3"
"Pro Linq", "C# Language enhancements", "Page 4"

어떻게 하면 이 일을 해낼 수 있을까요?select new로 가능하지만 select many로 충분하다고 들었습니다.

myBooks.SelectMany(b => b.Chapters
    .SelectMany(c => c.Pages
        .Select(p => b.Name + ", " + c.Name + ", " + p.Name)));

가정하면books책 목록:

var r = from b in books
    from c in b.Chapters
    from p in c.Pages
    select new {BookName = b.Name, ChapterName = c.Name, PageName = p.Name};
myBooks.SelectMany(b => b.Chapters
    .SelectMany(c => c.Pages
        .Select(p => new 
                {
                    BookName = b.Name ,
                    ChapterName = c.Name , 
                    PageName = p.Name
                });

저도 이것을 하려고 했는데 유리의 댓글과 linqPad를 만지작거리는 것을 보니 이것이 있습니다.

참고: 책, 장, 페이지가 없습니다. 사람(책), 회사 사람(장) 및 회사(페이지)가 있습니다.

from person in Person
                           join companyPerson in CompanyPerson on person.Id equals companyPerson.PersonId into companyPersonGroups
                           from companyPerson in companyPersonGroups.DefaultIfEmpty()
                           select new
                           {
                               ContactPerson = person,
                               ContactCompany = companyPerson.Company
                           };

또는

Person
   .GroupJoin (
      CompanyPerson, 
      person => person.Id, 
      companyPerson => companyPerson.PersonId, 
      (person, companyPersonGroups) => 
         new  
         {
            person = person, 
            companyPersonGroups = companyPersonGroups
         }
   )
   .SelectMany (
      temp0 => temp0.companyPersonGroups.DefaultIfEmpty (), 
      (temp0, companyPerson) => 
         new  
         {
            ContactPerson = temp0.person, 
            ContactCompany = companyPerson.Company
         }
   )

내가 사용한 Ref 사이트: http://odetocode.com/blogs/scott/archive/2008/03/25/inner-outer-lets-all-join-together-with-linq.aspx

언급URL : https://stackoverflow.com/questions/6428940/how-to-flatten-nested-objects-with-linq-expression

반응형