반응형
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
반응형
'programing' 카테고리의 다른 글
하위 요소를 추가하기 위한 웹 구성 변환 (0) | 2023.05.21 |
---|---|
C# 웹 API를 호출할 때 지원되지 않는 허가 유형 (0) | 2023.05.21 |
spacy Windows 10 및 Python 3.5.3에서 'en_core_web_sm' 모델을 찾을 수 없음 :: 아나콘다 사용자 지정(64비트) (0) | 2023.05.21 |
Mongoose, 찾기, 특정 속성 반환 (0) | 2023.05.21 |
DBef를 사용하여 mongodb를 쿼리하는 방법 (0) | 2023.05.21 |