LINQ를 사용하여 데이터 피벗
데이터 과학에서 피벗은 데이터를 와이드 형식에서 Tall 형식으로 또는 그 반대로 변환합니다. Enum 및 User 개체가 포함된 항목이 포함된 데이터세트가 있고 그리드 표시를 위해 이를 평면화해야 한다고 가정해 보겠습니다. 간단한 방법에는 중첩된 foreach 루프가 포함되지만 이 접근 방식은 컬렉션 크기 변경으로 인해 오류가 발생할 수 있습니다.
LINQ Pivot 접근 방식
LINQ는 더 깔끔하고 효율적인 방법을 제공합니다. 데이터를 피벗하려면:
var grps = from d in data group d by d.Foo into grp select new { Foo = grp.Key, Bars = grp.Select(d2 => d2.Bar).ToArray() };
int rows = grps.Max(grp => grp.Bars.Length);
foreach (var grp in grps) { Console.Write(grp.Foo + "\t"); }
for (int i = 0; i < rows; i++) { foreach (var grp in grps) { Console.Write((i < grp.Bars.Length ? grp.Bars[i] : null) + "\t"); } Console.WriteLine(); }
이 코드는 데이터 피벗을 우아하게 수행하여 복잡한 데이터 세트를 그리드 형식으로 평면화하기 위한 깔끔하고 효율적인 솔루션을 제공합니다.
위 내용은 LINQ는 그리드 표시를 위해 어떻게 데이터를 넓은 형식에서 긴 형식으로 효율적으로 전환할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!