Segmentierungssprache
Pushwoosh bietet eine leistungsstarke Segmentierungs-Engine zum Erstellen granularer Segmente basierend auf Tag-Werten. Die Segmentierungssprache ist eine spezielle Methode zum Schreiben und Kombinieren von Segmentierungskriterien, um eine bestimmte Gruppe von Benutzern zu beschreiben, die diesen Kriterien entsprechen, und sie als ein einziges Zielgruppensegment zu behandeln.
Dieser Artikel beschreibt die grundlegenden Konzepte und die Syntax der Segmentierungssprache und bietet umfassende Beispiele für die Erstellung von Segmentierungskriterien für verschiedene Anwendungsfälle.
Grundlagen
Anchor link toJedes Gerät in Ihrer Benutzerbasis hat spezifische Attribute, die ihm über Tag-Werte zugeordnet sind.
Nehmen wir zum Beispiel an, eine Benutzerin namens Jane lebt in Tokio und ist 28 Jahre alt. Für ihr Gerät werden die folgenden Tags gesetzt:
- Name: Jane
- Stadt: Tokio
- Alter: 28
Um Jane anzusprechen, müssen Sie ein Segment wie folgt beschreiben:
T("Name", eq, "Jane") * T("Age", eq, 28) * T("City", eq, "Tokyo")
Diese Kombination von Bedingungen ist ein Filterausdruck, der in der Segmentierungssprache verwendet wird, um Benutzergruppen, also Zielgruppensegmente, zu beschreiben.
Filterausdrücke
Anchor link toEin Filterausdruck ist eine Zeichenfolge, die eine Bedingung oder eine Kombination von Bedingungen enthält, die das benötigte Segment beschreiben.
Bedingungen
Anchor link toJede Bedingung beschreibt ein Segment von Geräten, die den in dieser Bedingung angegebenen Kriterien entsprechen.
Zum Beispiel erstellt die folgende Bedingung ein Segment von Benutzern, die in Tokio leben:
T("City", e, "Tokyo")
wobei
- T ein Tag ist (Bedingungstyp);
- eq der anzuwendende Operator ist;
- “Tokyo” ein Tag-Wert ist, der den Geräten der Benutzer zugeordnet ist.
Bedingungstypen
Anchor link toDie folgenden Bedingungstypen sind für die Segmentierung verfügbar:
- A (Application) – beschreibt ein Segment von Geräten, auf denen eine bestimmte App installiert ist. Aliase: App, Application;
- T (Tag) – beschreibt ein Segment von Geräten mit den angegebenen Tag-Werten;
- AT (App-scoped tag) – sucht nach einem Tag-Wert innerhalb einer bestimmten Anwendung; der App-Code ist als erstes Argument erforderlich. Alias: Tag;
- Event – beschreibt ein Segment von Geräten, die ein bestimmtes Pushwoosh-Ereignis ausgelöst haben;
- Geo – beschreibt ein Segment von Geräten innerhalb eines bestimmten geografischen Radius;
- BTTS – beschreibt ein Segment von Geräten basierend auf ihrer besten Sendezeit;
- Updated – beschreibt ein Segment von Geräten basierend auf ihrem letzten Aktualisierungszeitstempel;
- Segment – verweist auf einen anderen Filter/ein anderes Segment anhand seines Codes;
Operationen mit Bedingungen
Anchor link toFür die Erstellung komplexer Segmente können die folgenden Operationen auf Bedingungen innerhalb des Filterausdrucks angewendet werden:
Vereinigung (+)
Anchor link toVerbindet die Segmente, d.h. erstellt ein neues Segment von Benutzern, die mindestens eine der angegebenen Bedingungen erfüllen.

Um beispielsweise Benutzer anzusprechen, die in Tokio oder in Osaka leben, müssen Sie das Segment mit den folgenden Bedingungen beschreiben:
T("City", eq, "Tokyo") + T("City", eq, "Osaka")
Schnittmenge (*)
Anchor link toKonstruiert ein Segment von Benutzern, die zu beiden durch die Bedingungen beschriebenen Segmenten gehören. Es werden also nur diejenigen Benutzer eingeschlossen, die jede von Ihnen angegebene Bedingung erfüllen.

Der folgende Ausdruck beschreibt ein Segment von Benutzern, die sowohl in Tokio leben als auch ihre Namen angegeben haben:
T("City", eq, "Tokyo") * T("Name", any)
Differenz (\)
Anchor link toErstellt ein Segment von Benutzern, die zu einem der beschriebenen Segmente gehören und nicht zu einem anderen.

Benutzer, die in Tokio leben, aber ihre Namen nicht angegeben haben, werden wie folgt beschrieben:
T("City", eq, "Tokyo") \ T("Name", any)
Klammern
Anchor link toBestimmen die Reihenfolge der Operationen, die mit den Bedingungen in Ihrem Filterausdruck ausgeführt werden sollen.
Zum Beispiel wird der folgende Filterausdruck zuerst ein Segment der 12345-67890-Abonnenten ermitteln, deren Alter 18 ist, und dann alle Männer dieses Segments abziehen:
( A("12345-67890") * T("Age", eq, 18) ) \ T("Gender", eq, "Male")
Operatoren für Tag-Bedingungen
Anchor link toFür jeden Tag-Typ werden eigene Operatoren angewendet.
Operatoren für Integer-Tags
Anchor link to- eq - gleich einem bestimmten Wert
- noteq - nicht gleich einem bestimmten Wert
- lte - kleiner als oder gleich einem bestimmten Wert
- gte - größer als oder gleich einem bestimmten Wert
- in - einer der angegebenen Werte
- notin - nicht gleich einem der angegebenen Werte
- between - in einem bestimmten Bereich
- any - Geräte mit beliebigen Werten für das Tag
- notset - Geräte ohne Wert für das Tag
Operatoren für String-Tags
Anchor link to- eq - gleich einem bestimmten Wert
- noteq - nicht gleich einem bestimmten Wert
- startswith - beginnt mit einem bestimmten Präfix
- endswith - endet mit einem bestimmten Suffix
- contains - enthält eine bestimmte Teilzeichenfolge
- in - gleich einem der angegebenen Werte
- notin - nicht gleich einem der angegebenen Werte
- any - Geräte mit beliebigen Werten für das Tag
- notset - Geräte ohne Wert für das Tag
Operatoren für Listen-Tags
Anchor link to- in - Geräte mit einem der angegebenen Tag-Werte
- notin - keiner der angegebenen Tag-Werte ist dem Gerät zugeordnet
- any - Geräte mit beliebigen Werten für das Tag
- notset - Geräte ohne Wert für das Tag
Operatoren für Datums-Tags
Anchor link to- eq - gleich dem angegebenen Datum
- noteq - nicht gleich dem angegebenen Datum
- lte - vor oder am angegebenen Datum
- gte - nach oder am angegebenen Datum
- in - gleich einem der angegebenen Daten
- notin - nicht gleich einem der angegebenen Daten
- between - in einem bestimmten Bereich
- any - Geräte mit beliebigen Werten für das Tag
- notset - Geräte ohne Wert für das Tag
- match - stimmt mit einem angegebenen Monat des Jahres und Tag des Monats überein.
- daysago eq - gleich einer bestimmten Anzahl von Tagen vor dem heutigen Tag
- daysago noteq - nicht gleich einer bestimmten Anzahl von Tagen vor dem heutigen Tag
- daysago lte - kleiner als oder gleich einer bestimmten Anzahl von Tagen vor dem heutigen Tag
- daysago gte - größer als oder gleich einer bestimmten Anzahl von Tagen vor dem heutigen Tag
- daysago between - zwischen den angegebenen Anzahlen von Tagen
- minutesago lte - kleiner als oder gleich einer bestimmten Anzahl von Minuten vor dem aktuellen Moment
- minutesago gte - größer als oder gleich einer bestimmten Anzahl von Minuten vor dem aktuellen Moment
- daysahead - in N bis M Tagen ab dem heutigen Tag (UTC), beidseitig einschließlich
Operatoren für Boolesche Tags
Anchor link to- eq - gleich einem bestimmten Wert
- noteq - nicht gleich einem bestimmten Wert
- any - Geräte mit beliebigen Werten für das Tag
- notset - Geräte ohne Wert für das Tag
Operatoren für Preis-Tags
Anchor link to- eq - gleich einem bestimmten Wert
- noteq - nicht gleich einem bestimmten Wert
- lte - kleiner als oder gleich einem bestimmten Wert
- gte - größer als oder gleich einem bestimmten Wert
- in - gleich einem der angegebenen Werte
- notin - nicht gleich einem der angegebenen Werte
- between - in einem bestimmten Bereich
- any - Geräte mit beliebigen Werten für das Tag
- notset - Geräte ohne Wert für das Tag
Operatoren für Versions-Tags
Anchor link to- eq - gleich einem bestimmten Wert
- noteq - nicht gleich einem bestimmten Wert
- lte - kleiner als oder gleich einem bestimmten Wert
- gte - größer als oder gleich einem bestimmten Wert
- in - gleich einem der angegebenen Werte
- notin - nicht gleich einem der angegebenen Werte
- between - in einem bestimmten Bereich
- any - Geräte mit beliebigen Werten für das Tag
- notset - Geräte ohne Wert für das Tag
Operatoren für Ereignisbedingungen
Anchor link toEreignisanzahl
Anchor link to- count gte - Geräte, die das Ereignis mehr als oder genau n-mal ausgelöst haben
- count lte - Geräte, die das Ereignis weniger als oder genau n-mal ausgelöst haben
- count eq - Geräte, die das Ereignis genau n-mal ausgelöst haben
- count noteq - Geräte, die das Ereignis beliebig oft, aber nicht genau n-mal ausgelöst haben
Ereignisdatum
Anchor link to- date gte - Geräte, die das Ereignis später als oder genau am angegebenen Datum ausgelöst haben
- date lte - Geräte, die das Ereignis früher als oder genau am angegebenen Datum ausgelöst haben
- date eq - Geräte, die das Ereignis genau am angegebenen Datum ausgelöst haben
- date noteq - Geräte, die das Ereignis jederzeit, aber nicht am angegebenen Datum ausgelöst haben
- date in - Geräte, die das Ereignis an einem der angegebenen Daten ausgelöst haben
- date notin - Geräte, die das Ereignis jederzeit, aber nicht an einem der angegebenen Daten ausgelöst haben
- date between - Geräte, die das Ereignis innerhalb eines bestimmten Zeitraums ausgelöst haben
- date daysago eq - Auslösedatum des Ereignisses ist gleich einer bestimmten Anzahl von Tagen vor dem heutigen Tag
- date daysago noteq - Auslösedatum des Ereignisses ist nicht gleich einer bestimmten Anzahl von Tagen vor dem heutigen Tag
- date daysago lte - Auslösedatum des Ereignisses ist kleiner als oder gleich einer bestimmten Anzahl von Tagen vor dem heutigen Tag
- date daysago gte - Auslösedatum des Ereignisses ist größer als oder gleich einer bestimmten Anzahl von Tagen vor dem heutigen Tag
- date daysago between - Auslösedatum des Ereignisses liegt zwischen den angegebenen Anzahlen von Tagen
- date daysahead - Auslösedatum des Ereignisses liegt in einer bestimmten Anzahl von Tagen ab dem heutigen Tag (Intervall ist an beiden Enden einschließlich, siehe Operatoren für Datums-Tags oben für die vollständige Semantik)
- date minutesago lte - Auslösedatum des Ereignisses ist kleiner als oder gleich einer bestimmten Anzahl von Minuten vor dem aktuellen Moment
- date minutesago gte - Auslösedatum des Ereignisses ist größer als oder gleich einer bestimmten Anzahl von Minuten vor dem aktuellen Moment
Ereignisplattformen
Anchor link toFiltern Sie Ereignisse nach der Plattform, auf der sie ausgelöst wurden.
- platforms - Liste der Plattformen (z.B. [“ios”, “android”])
Ereignisattribute
Anchor link toEreignisbedingungen können basierend auf den Werten von Ereignisattributen filtern. Attribute unterstützen verschiedene Datentypen mit ihren entsprechenden Operatoren.
Integer-Ereignisattribute
Anchor link to- attribute “name” eq - Attribut ist gleich einem bestimmten Wert
- attribute “name” noteq - Attribut ist nicht gleich einem bestimmten Wert
- attribute “name” gte - Attribut ist größer als oder gleich einem bestimmten Wert
- attribute “name” lte - Attribut ist kleiner als oder gleich einem bestimmten Wert
- attribute “name” between - Attribut liegt in einem bestimmten Bereich
- attribute “name” in - Attribut ist gleich einem der angegebenen Werte
- attribute “name” notin - Attribut ist nicht gleich einem der angegebenen Werte
- attribute “name” any - ein beliebiger Wert für das Attribut gesetzt
- attribute “name” notset - kein Wert für das Attribut gesetzt
String-Ereignisattribute
Anchor link to- attribute “name” eq - Attribut ist gleich einem bestimmten Wert
- attribute “name” noteq - Attribut ist nicht gleich einem bestimmten Wert
- attribute “name” startswith - Attribut beginnt mit einem bestimmten Präfix
- attribute “name” endswith - Attribut endet mit einem bestimmten Suffix
- attribute “name” contains - Attribut enthält eine bestimmte Teilzeichenfolge
- attribute “name” in - Attribut ist gleich einem der angegebenen Werte
- attribute “name” notin - Attribut ist nicht gleich einem der angegebenen Werte
- attribute “name” any - ein beliebiger Wert für das Attribut gesetzt
- attribute “name” notset - kein Wert für das Attribut gesetzt
Boolesche Ereignisattribute
Anchor link to- attribute “name” eq - Attribut ist gleich true oder false
- attribute “name” noteq - Attribut ist nicht gleich true oder false
Datums-Ereignisattribute
Anchor link to- attribute “name” eq - Attribut ist gleich einem bestimmten Datum
- attribute “name” noteq - Attribut ist nicht gleich einem bestimmten Datum
- attribute “name” gte - Attribut nach oder an einem bestimmten Datum
- attribute “name” lte - Attribut vor oder an einem bestimmten Datum
- attribute “name” between - Attribut innerhalb eines bestimmten Datumsbereichs
- attribute “name” in - Attribut ist gleich einem der angegebenen Daten
- attribute “name” notin - Attribut ist nicht gleich einem der angegebenen Daten
- attribute “name” daysago eq/noteq/gte/lte/between - Attribut relativ zu Tagen zuvor
- attribute “name” daysahead from to - Attribut in einem bestimmten Intervall von Tagen ab dem heutigen Tag (Intervall ist an beiden Enden einschließlich, siehe Operatoren für Datums-Tags oben für die vollständige Semantik)
- attribute “name” minutesago gte/lte - Attribut relativ zu Minuten zuvor
- attribute “name” any - ein beliebiger Wert für das Attribut gesetzt
- attribute “name” notset - kein Wert für das Attribut gesetzt
Preis-Ereignisattribute
Anchor link to- attribute “name” eq - Attribut ist gleich einem bestimmten Preiswert
- attribute “name” noteq - Attribut ist nicht gleich einem bestimmten Preiswert
- attribute “name” gte - Attribut ist größer als oder gleich einem bestimmten Preis
- attribute “name” lte - Attribut ist kleiner als oder gleich einem bestimmten Preis
- attribute “name” between - Attribut liegt in einem bestimmten Preisbereich
- attribute “name” in - Attribut ist gleich einem der angegebenen Preise
- attribute “name” notin - Attribut ist nicht gleich einem der angegebenen Preise
- attribute “name” any - ein beliebiger Wert für das Attribut gesetzt
- attribute “name” notset - kein Wert für das Attribut gesetzt
Listen-Ereignisattribute
Anchor link to- attribute “name” in - Attribut enthält einen der angegebenen Werte
- attribute “name” notin - Attribut enthält keinen der angegebenen Werte
- attribute “name” any - ein beliebiger Wert für das Attribut gesetzt
- attribute “name” notset - kein Wert für das Attribut gesetzt
Zusätzliche Bedingungstypen
Anchor link toGeo-Bedingung
Anchor link toZielt auf Geräte basierend auf dem geografischen Standort innerhalb eines bestimmten Radius.
Syntax: Geo("<app-code>", <latitude>, <longitude>, <range-in-km>)
BTTS-Bedingung
Anchor link toZielt auf Geräte nach ihrer besten Sendezeit für Benachrichtigungen (Stunde des Tages, 0-23).
Operatoren:
- any - ein beliebiger Wert für die beste Sendezeit gesetzt
- eq - exakte Stundenübereinstimmung
- noteq - nicht gleich der Stunde
- gte - Stunde größer als oder gleich
- lte - Stunde kleiner als oder gleich
Updated-Bedingung
Anchor link toFiltert Geräte nach ihrem letzten Aktualisierungszeitstempel.
Operatoren:
- gte - aktualisiert nach oder am angegebenen Datum
- lte - aktualisiert vor oder am angegebenen Datum
- between - aktualisiert innerhalb des Datumsbereichs
Segment-Bedingung
Anchor link toVerweist auf einen anderen Filter/ein anderes Segment anhand seines Codes.
Anwendungsbedingung Gerätepräsenz-Flags
Anchor link toAnwendungsbedingungen unterstützen zusätzliche Flags zur Steuerung der Geräte- und Token-Filterung:
- with_tokens - Geräte mit Push-Benachrichtigungs-Tokens
- without_tokens - Geräte ohne Push-Benachrichtigungs-Tokens
- with_devices - Benutzer mit registrierten Geräten
- without_devices - Benutzer/Profile ohne registrierte Geräte
Beispiele für Filterausdrücke
Anchor link toGrundlegende Beispiele
Anchor link to- iOS- und Android-Geräte, auf denen die App installiert ist und die Push-Tokens haben:
A("11111-11111", ["ios","android"], [with_tokens])- iOS- und Android-Geräte, auf denen die App installiert ist, aber ohne Push-Tokens:
A("11111-11111", ["ios","android"], [without_tokens])- iOS- und Android-Geräte, auf denen die App installiert ist, unabhängig davon, ob sie Push-Tokens haben oder nicht:
A("11111-11111", ["ios","android"], [with_tokens, without_tokens])- Alle App-Abonnenten, die etwas in der App gekauft haben:
AT("11111-11111", "In-App Purchase", gte, 1)Fortgeschrittene Beispiele
Anchor link to- Benutzer in Tokio, die die App in den letzten 7 Tagen geöffnet haben:
T("City", eq, "Tokyo") * Event("11111-11111", "App Open", date daysago lte 7)- Benutzer, die in den letzten 30 Tagen einen Kauf über 50 $ getätigt haben:
Event("11111-11111", "Purchase", attribute "total_price" gte 50.00, date daysago lte 30)- Benutzer, deren Namen mit “J” beginnen oder mit “e” enden:
T("Name", startswith, "J") + T("Name", endswith, "e")- Aktive iOS-Benutzer innerhalb von 100 km von New York, die in letzter Zeit nichts gekauft haben:
A("11111-11111", ["ios"], [with_tokens]) * Geo("11111-11111", 40.7128, -74.0060, 100) \ Event("11111-11111", "Purchase", date daysago lte 30)- Benutzer mit der besten Sendezeit zwischen 9 und 17 Uhr:
BTTS("11111-11111", gte 9) * BTTS("11111-11111", lte 17)- Benutzer, die in der letzten Stunde ein bestimmtes Ereignis auf Android oder iOS ausgelöst haben:
Event("11111-11111", "Button Click", platforms ["android", "ios"], date minutesago lte 60)- Geräte, die in den letzten 3 Monaten aktualisiert wurden, mit App-Version 4.2 oder höher:
Updated("11111-11111", gte "2024-07-01 00:00:00") * AT("11111-11111", "App Version", gte, "4.2")