Ähnlich wie LINQ-Abfragen in .NET ist es möglich, In-Memory-Abfragen für Strukturen in Golang durchzuführen. In diesem Artikel wird gezeigt, wie man ein Segment von Strukturen nach mehreren Feldern gruppiert und anschließend ein bestimmtes ganzzahliges Feld summiert.
Gegeben sei ein Segment von Strukturen mit Feldern mit den Namen id1 bis id8 und einem ganzzahligen Feld „money“. Das Ziel besteht darin, Strukturen nach den ID-Feldern zu gruppieren und das Geldfeld zu summieren.
Ein Ansatz besteht darin, eine Equal-Funktion zu definieren, um Strukturen basierend auf den acht ID-Feldern zu vergleichen. Anschließend iterieren Sie über das Eingabe-Slice und prüfen, ob jede Struktur in einer Hash-Tabelle vorhanden ist. Wenn es bereits vorhanden ist, wird das Geldfeld erhöht; Andernfalls wird der Hash-Tabelle ein neuer Eintrag hinzugefügt.
Es gibt jedoch eine effizientere und elegantere Lösung, die die integrierten Funktionen von Golang nutzt.
Das Schlüsselkonzept besteht darin, die Registerstruktur so umzustrukturieren, dass sie nur die Gruppierungsfelder in einer separaten Struktur namens „Key“ enthält. Da Strukturen in Golang vergleichbar sind, können Sie den Schlüssel als Schlüssel für eine Karte verwenden. Auf das Geldfeld kann dann über den Wert der Karte zugegriffen werden.
Hier sind die aktualisierten Strukturdefinitionen:
<code class="go">type Key struct { id1 int id2 int id3 int id4 int id5 int id6 int id7 int id8 int } type Register struct { key Key money int }</code>
Zur Gruppe Um die Register zu summieren und zu summieren, wird eine Karte vom Typ „map[Key]int“ mit Register.key als Schlüssel verwendet. Dieser Ansatz stellt sicher, dass Register mit denselben ID-Feldern gruppiert werden und das Geldfeld für jede Gruppe akkumuliert wird.
<code class="go">m := map[Key]int{} for _, v := range regs { m[v.key] += v.money }</code>
Die Karte m enthält jetzt die gruppierten und summierten Werte, die zur Analyse ausgedruckt werden können .
Die beschriebene Lösung bietet einen robusten und effizienten Mechanismus zum Gruppieren und Summieren von Strukturabschnitten in Golang. Durch die Nutzung der integrierten Funktionen der Sprache werden benutzerdefinierte Vergleichsfunktionen oder Hash-Tabellen überflüssig, was zu präzisem und wartbarem Code führt.
Das obige ist der detaillierte Inhalt vonWie gruppiert und summiert man Strukturabschnitte nach mehreren Feldern in Golang?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!