Del via


Table.Group

Syntaks

Table.Group(table as table, key as any, aggregatedColumns as list, optional groupKind as nullable number, optional comparer as nullable function) as table

Om

Grupperer rækkerne i table efter de nøglekolonner, der er defineret af key. key kan enten være et enkelt kolonnenavn eller en liste over kolonnenavne. For hver gruppe oprettes en post, der indeholder nøglekolonnerne (og deres værdier) sammen med alle aggregerede kolonner, der er angivet af aggregatedColumns. Eventuelt og groupKindcomparer kan også angives.

Hvis dataene allerede er sorteret efter nøglekolonnerne, kan der angives en groupKind af GroupKind.Local . Dette kan forbedre ydeevnen for gruppering i visse tilfælde, da alle rækker med et bestemt sæt nøgleværdier antages at være sammenhængende.

Når du overfører en comparer, skal du være opmærksom på, at hvis den behandler forskellige nøgler som lige, kan en række placeres i en gruppe, hvis nøgler adskiller sig fra deres egne.

Denne funktion garanterer ikke rækkefølgen af de rækker, den returnerer.

Eksempel 1

Gruppér tabellen ved at tilføje en aggregeringskolonne [total], som indeholder summen af priser ("hver List.Sum([pris])").

Brug

Table.Group(
    Table.FromRecords({
        [CustomerID = 1, price = 20],
        [CustomerID = 2, price = 10],
        [CustomerID = 2, price = 20],
        [CustomerID = 1, price = 10],
        [CustomerID = 3, price = 20],
        [CustomerID = 3, price = 5]
    }),
    "CustomerID",
    {"total", each List.Sum([price])}
)

Output

Table.FromRecords(
    {
        [CustomerID = 1, total = 30],
        [CustomerID = 2, total = 30],
        [CustomerID = 3, total = 25]
    },
    {"CustomerID", "total"}
)

Sammenligningsfunktioner