LINQ를 사용하여 개체를 계층적 목록 구조로 그룹화
분류 속성이 있는 개체 집합이 있다고 가정해 보겠습니다. 예를 들어, 서로 다른 그룹에 속한 사용자 집합이 있다고 가정해 보겠습니다. 데이터를 효율적으로 구성하고 분석하기 위해 그룹 연결을 기반으로 사용자를 그룹화할 수 있습니다.
이 예에는 User
, UserID
, UserName
등의 속성을 갖는 GroupID
이라는 클래스가 있습니다. 다음과 같은 사용자 목록이 있다고 가정해 보겠습니다.
<code class="language-csharp">List<User> userList = new List<User>(); userList.Add(new User { UserID = 1, UserName = "UserOne", GroupID = 1 }); userList.Add(new User { UserID = 2, UserName = "UserTwo", GroupID = 1 }); userList.Add(new User { UserID = 3, UserName = "UserThree", GroupID = 2 }); userList.Add(new User { UserID = 4, UserName = "UserFour", GroupID = 1 }); userList.Add(new User { UserID = 5, UserName = "UserFive", GroupID = 3 }); userList.Add(new User { UserID = 6, UserName = "UserSix", GroupID = 3 });</code>
우리의 목표는 이 목록을 동일한 그룹에 속한 사용자를 그룹화하는 계층 구조로 변환하는 것입니다. 원하는 출력은 다음과 같습니다.
<code>GroupedUserList UserList UserID = 1, UserName = "UserOne", GroupID = 1 UserID = 2, UserName = "UserTwo", GroupID = 1 UserID = 4, UserName = "UserFour", GroupID = 1 UserList UserID = 3, UserName = "UserThree", GroupID = 2 UserList UserID = 5, UserName = "UserFive", GroupID = 3 UserID = 6, UserName = "UserSix", GroupID = 3</code>
LINQ의 강력한 집계 기능을 사용하면 다음 코드를 사용하여 이러한 그룹화를 달성할 수 있습니다.
<code class="language-csharp">var groupedCustomerList = userList .GroupBy(u => u.GroupID) .Select(grp => grp.ToList()) .ToList();</code>
GroupBy
방법은 GroupID
속성을 기준으로 사용자를 분류합니다. 각 그룹이 고유한 GroupID
을 나타내는 그룹 컬렉션을 생성합니다. Select
메서드는 이러한 그룹을 사용자 목록으로 추가로 변환하여 각 그룹 내에 사용자 목록을 중첩하는 계층 구조를 제공합니다.
이 LINQ 쿼리를 사용하면 데이터를 의미 있는 그룹으로 효과적으로 구성하여 데이터 분석 및 조작 기능을 향상시킬 수 있습니다.
위 내용은 LINQ는 어떻게 개체를 계층적 목록 구조로 그룹화할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!