


Wie kann LINQ das Pivotieren und Umstrukturieren von Daten vereinfachen?
Jan 05, 2025 pm 03:33 PMPivotieren von Daten mit LINQ
In bestimmten Szenarien ist die Umstrukturierung von Daten in ein anderes Format erforderlich. Eine häufige Aufgabe besteht darin, Daten zu schwenken und sie von einer tabellarischen Struktur in ein komprimierteres Layout umzuwandeln. Herkömmliche iterative Ansätze wie foreach-Schleifen können dies zwar erreichen, sie bringen jedoch Herausforderungen mit sich, wenn es um Sammlungsänderungen während der Iteration geht. Hier kommt LINQ zum Einsatz, eine leistungsstarke Abfragesprache, die die Datenmanipulation vereinfacht und eine sauberere und effizientere Lösung für die Pivotierung von Daten bietet.
Stellen Sie sich eine Sammlung von Objekten vor, die eine Aufzählung (TypeCode) und eine Benutzerinstanz enthält. Das Ziel besteht darin, diese Sammlung in eine gitterartige Struktur zu verflachen, in der jeder TypeCode einer Spalte entspricht und die Benutzernamen in Zeilen angeordnet sind.
LINQ bietet eine einfache Möglichkeit, diesen Pivot-Vorgang durchzuführen. Indem wir die Sammlung nach TypeCode gruppieren und dann die Benutzernamen als Array für jede Gruppe auswählen, können wir effektiv Spalten erstellen. Der folgende Codeausschnitt demonstriert diesen Ansatz:
// Sample data var data = new[] { new { TypeCode = 1, User = "Don Smith" }, new { TypeCode = 1, User = "Mike Jones" }, new { TypeCode = 1, User = "James Ray" }, new { TypeCode = 2, User = "Tom Rizzo" }, new { TypeCode = 2, User = "Alex Homes" }, new { TypeCode = 3, User = "Andy Bates" } }; // Group by TypeCode and select User name arrays var groups = from d in data group d by d.TypeCode into grp select new { TypeCode = grp.Key, Users = grp.Select(d2 => d2.User).ToArray() };
Nachdem wir die Spalten erstellt haben, müssen wir die Gesamtzahl der Zeilen bestimmen, also die maximale Länge eines beliebigen Benutzerarrays in den Gruppen. Mit diesen Informationen können wir jede Gruppe durchlaufen und die entsprechenden Benutzernamen anzeigen und bei Bedarf mit Nullwerten auffüllen.
// Find total number of rows int rows = groups.Max(grp => grp.Users.Length); // Output columns foreach (var grp in groups) { Console.Write(grp.TypeCode + "\t"); } Console.WriteLine(); // Output rows for (int i = 0; i < rows; i++) { foreach (var grp in groups) { Console.Write((i < grp.Users.Length ? grp.Users[i] : null) + "\t"); } Console.WriteLine(); }
Durch die Nutzung der Gruppierungs- und Auswahlfunktionen von LINQ ermöglicht uns dieser Code, die zu schwenken Daten und generieren Sie die gewünschte Ausgabe auf prägnante und effiziente Weise.
Das obige ist der detaillierte Inhalt vonWie kann LINQ das Pivotieren und Umstrukturieren von Daten vereinfachen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heißer Artikel

Hot-Tools-Tags

Heißer Artikel

Heiße Artikel -Tags

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

C Sprachfunktionsformat -Buchstaben -Fall -Konvertierungsschritte

GULC: C -Bibliothek von Grund auf neu gebaut

Welche Werte sind von C -Sprachfunktionen zurückgegeben? Was bestimmt den Rückgabewert?

Wie funktioniert die C -Standard -Vorlagenbibliothek (STL)?

Was sind die Definitionen und Aufrufregeln von C -Sprachfunktionen und was sind die?

Wo ist der Rückgabewert der C -Sprachfunktion im Speicher?

eindeutiger Gebrauch und Phrasenfreigabe

Wie benutze ich Algorithmen aus der STL (sortieren, finden, transformieren usw.) effizient?
