Zu Hauptinhalt springen Zu ergänzendem Inhalt springen

Window – Skriptfunktion

Window() führt Berechnungen für mehrere Zeilen durch und gibt einen getrennten Wert für jede Zeile zurück.

Sie können die Window-Funktionen verwenden, um Vorgänge wie die Folgenden durchzuführen:

  • Vergleichen eines einzelnen Zahlenwerts in einer Zeile mit dem Durchschnitt, Maximum oder Minimum in der Spalte.

  • Den Rang eines einzelnen Werts entweder in der Spalte oder in der ganzen Tabelle berechnen.

Die Window-Funktion ändert nicht die Anzahl der Datensätze in der Tabelle, kann jedoch ähnliche Aufgaben als Aggregierung, relationale und Bereichsfunktionen durchführen.

Zum Hinzufügen zur Tabelle muss die Window-Funktion einen Cache innerhalb des LOAD-Befehls der Tabelle enthalten, mit der Sie arbeiten. Zum Beispiel:

[Transactions]: Load *, Window(avg(Expression1),[Num]); LOAD TransLineID, TransID, "Num", Dim1, Dim2, Dim3, Expression1, Expression2, Expression3 FROM [lib://DataFiles/transactions.qvd] (qvd);FROM [lib://AttachedFiles/transactions.qvd] (qvd);

Window unterstützt allgemeine Funktionen wie Rundungen oder grundlegende numerische Operationen. Zum Beispiel:

Load *, Round(Window(Sum(Salary),Department)) as SumSalary
Load *, Window(Sum(Salary),Department) + 5 as SumSalary

Sie können ein gleitendes Fenster für die Window-Funktion definieren. Damit wird die Anzahl der Zeilen festgelegt, die beim Anwenden der Window-Funktion auf die aktuelle Zeile verwendet werden. Beispielsweise können Sie das Intervall auf die 3 vorherigen und die 3 darauffolgenden Zeilen festlegen.

Window(avg(Salary), Department, 'NONE' -3, 3) as AvgDepSalary

Syntax:  

Window (input_expr, [partition1, partition2, ...], [sort_type, [sort_expr]],[filter_expr], [start_expr,end_expr])

Datentyp zurückgeben: Ein neues Feld, das der durch den LOAD-Befehl erstellten Tabelle hinzugefügt wurde.

Argumente:  

Argumente
ArgumentBeschreibung
input_expr

Die Eingabeformel wird von der Funktion berechnet und zurückgegeben. Es muss sich um eine Formel handeln, die auf einer Aggregierung basiert, z. B. Median(Salary). Hier ein Beispiel:

Window(Median(Salary)) as MedianSalary

Die Eingabe kann auch ein Feldname ohne angewendete Aggregierung sein. In diesem Fall behandelt Window sie so, als würde die Funktion Only() auf dieses Feld angewendet. Hier ein Beispiel:

Window(Salary,Department) as WSalary

 

Optional können Sie Partitionierung mit der Eingabeformel definieren. Partitionierung ist das Gleiche wie die Gruppierung, die durch die group by-Bedingung erzielt wird, mit dem Unterschied, dass das Ergebnis als neue Spalte zur Eingabetabelle hinzugefügt wird. Partitionierung reduziert die Anzahl der Datensätze der Eingabetabelle nicht. Es können mehrere Partitionsfelder definiert werden.

Beispiel: 

LOAD Window(Max(Sales), City, 'ASC', OrderDate, Sales > 300)
+ AddMonths(OrderDate,-6) as MAX_Sales_City_Last_6_Mos, Window(Avg(Sales), City, 'ASC', OrderDate, City = 'Portland')
+ AddMonths(OrderDate,-6) as Avg_Sales_Portland_Last_6_Mos, Window(Max(Sales), City, 'ASC', OrderDate, Sales > 300)
+ AddMonths(OrderDate,-12) as MAX_Sales_City_Last_12_Mos; LOAD City, Sales, OrderDate FROM [lib://:DataFiles/Sales Data.xlsx]FROM [lib://AttachedFiles/Sales Data.xlsx] (ooxml, embedded labels, table is [Sales Data]);

partition1, partition2

Nach input_expr können Sie eine beliebige Anzahl Partitionen definieren. Partitionen sind Felder, die definieren, in welchen Kombinationen die Aggregierungen angewendet werden sollen. Die Aggregierung wird für jede Partition einzeln angewendet. Hier ein Beispiel:

Window(Avg(Salary), Unit, Department, Country) as AvgSalary

Im obigen Beispiel sind die Partitionen Unit, Department und Country.

Partitionen sind nicht obligatorisch, aber für die ordnungsgemäße Fenstereinteilung der Felder erforderlich.

sort_type, [sort_expr]]

Geben Sie optional den Sortiertyp und die Sortierformel an. sort_type kann einen von zwei Werten haben:

  • ASC Aufsteigende Sortierung.

  • DESC Absteigende Sortierung.

Wenn Sie „sort_type“ definieren, müssen Sie eine Sortierformel definieren. Dies ist eine Formel, die über die Reihenfolge der Zeilen innerhalb einer Partition entscheidet.

Hier ein Beispiel:

Window(RecNo(), Department, 'ASC', Year)

Im obigen Beispiel werden die Ergebnisse innerhalb der Partition aufsteigend durch das Feld Year sortiert.

InformationshinweisDer Sortiertyp und die Sortierformel sind hauptsächlich nur für die Funktionen RecNo und WRank erforderlich.
filter_expr

Fügen Sie optional eine Filterformel hinzu. Dies ist eine Boolesche Formel, die entscheidet, ob ein Datensatz in die Berechnung eingeschlossen werden soll oder nicht.

Der Parameter kann vollständig ausgelassen werden, und das Ergebnis sollte sein, dass kein Filter vorhanden ist.

Hier ein Beispiel:

Window(avg(Salary), Department, 'ASC', Age, EmployeeID=3 Or EmployeeID=7)
as wAvgSalary) as wAvgSalaryIfEmpIs3or7
[start_expr,end_expr]

Legen Sie optional das Argument für die gleitende Fensterfunktion fest. Ein Sliding Window erfordert zwei Argumente:

  • Startformel: Die Anzahl der Zeilen vor der aktuellen Zeile, die in das Fenster eingeschlossen werden sollen.

  • Endformel: Die Anzahl der Zeilen nach der aktuellen Zeile, die in das Fenster eingeschlossen werden sollen.

Wenn Sie beispielsweise die 3 vorherigen Zeilen, die aktuelle Zeile und die nachfolgende Zeile einschließen möchten:

Window(concat(Text(Salary),'-'), Department, 'ASC', Age, Year>0, -3, 1)
as WSalaryDepartment

Um alle vorangehenden oder alle nachfolgenden Zeilen anzugeben, können Sie die Funktion Unbounded() verwenden. Wenn Sie zum Beispiel alle vorangehenden Zeilen, die aktuelle Zeile und die nachfolgende Zeile einschließen möchten:

Window(concat(Text(Salary),'-'), Department, 'ASC', Age, Year>0, UNBOUNDED(), 1)
as WSlidingSalaryDepartment

Wenn Sie zum Beispiel die dritte Zeile ab der aktuellen Zeile und alle nachfolgenden Zeilen einschließen möchten:

Window(concat(Text(Salary),'-'), Department, 'ASC', Age, Year>0, 3, UNBOUNDED())
as WSlidingSalaryDepartment

Beispiel: Hinzufügen eines Felds, das eine Aggregierung enthält

Beispiel:– Hinzufügen eines Felds, das eine nach bestimmten Werten gefilterte Aggregierung enthält

Beispiel: Hinzufügen eines Felds mit einem Sliding Window

Beschränkungen

Window weist die folgenden Beschränkungen auf:

  • Window ist eine ressourcenintensive Funktion, vor allem hinsichtlich der Arbeitsspeichernutzung.

  • Window wird in Qlik Sense Mobile nicht unterstützt.

  • Diagrammformeln unterstützen Window nicht.

  • Sie können Window-Funktionen nicht in anderen Window-Funktionen verschachteln.

  • Window kann nicht innerhalb einer Aggregierungsfunktion verwendet werden.

  • Window muss die ganze Tabelle scannen können.

  • WRank(), RecNo() und RowNo() können nicht mit Window verwendet werden, wenn die Funktionalität der gleitenden Fenster verwendet wird.

Hat diese Seite Ihnen geholfen?

Wenn Sie ein Problem mit dieser Seite oder ihrem Inhalt feststellen, sei es ein Tippfehler, ein ausgelassener Schritt oder ein technischer Fehler, informieren Sie uns bitte!

Nehmen Sie am Analyse-Modernisierungsprogramm teil

Remove banner from view

Modernisieren Sie mit dem Analyse-Modernisierungsprogramm, ohne Ihre wertvollen QlikView-Apps zu gefährden. Klicken Sie hier für weitere Informationen oder kontaktieren Sie uns: ampquestions@qlik.com