linq 표현식을 사용하여 중첩 된 객체를 병합하는 방법


125

다음과 같이 중첩 된 개체를 병합하려고합니다.

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"

이것을 어떻게 할 수 있습니까? 나는 새로운 선택으로 할 수 있지만 SelectMany로 충분할 것이라고 들었습니다.

답변:


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

대박!!! FlatBook {BookName, ChapterName, PageName}과 같은 새 개체가 생성되면 어떻게됩니까?
abx78

2
@ abx78 : 마지막 선택 만 변경합니다..Select(p => new FlatBook(b.Name, c.Name, p.Name))
user7116 2011-06-21

감사합니다. 이것이 제가 필요한 것입니다!
abx78 2011-06-21

1
이것은 동일한 결과를 생성합니까? myBooks.SelectMany(b => b.Chapters).SelectMany(c => c.Pages).Select(p => b.Name + ", " + c.Name + ", " + p.Name);
호머

1
@Mastro 어때요myBooks.SelectMany(b => b.Chapters == null || !b.Chapters.Any()? new []{b.Name + " has no Chapters"} : b.SelectMany(c => c.Pages.Select(p => b.Name + ", " + c.Name + ", " + p.Name)));
Yuriy

50

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};

2
+1 IEnumerable<Book>은 할 수 있지만 List<Book>.
user7116

2
myBooks.SelectMany(b => b.Chapters
    .SelectMany(c => c.Pages
        .Select(p => new 
                {
                    BookName = b.Name ,
                    ChapterName = c.Name , 
                    PageName = p.Name
                });

7
이 코드 샘플은 질문에 답할 수 있지만 설명이 부족합니다. 현재 상태에서는 아무 가치도 추가하지 않고 비추천 / 삭제 변경을 의미합니다. 무엇이하고 왜 OP 문제에 대한 해결책인지 설명을 추가하십시오.
oɔɯǝɹ

0

나도 이렇게하려고했는데 Yuriy의 댓글과 linqPad를 엉망으로 만들었 기 때문에 ..

책, 장, 페이지가 없으며 사람 (책), companyPerson (장) 및 회사 (페이지)가 있습니다.

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
         }
   )

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

당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.