Parameter definieren, referenzieren, festlegen und abrufen
Es gibt vier allgemeine Arten der Verwendung von Parametern:
- Während der Entwicklung definieren: Während der Entwicklung verwenden Sie die Konsole oder die API, um Parameter zu definieren. Sie können beispielsweise einen Intent-Parameter definieren und in einer Trainingsformulierung verwenden, um die Endnutzereingabe zu bestimmen, die extrahiert werden soll.
- Bei der Entwicklung referenzieren: Parameterverweise sind Variablen, die zur Laufzeit extrahierte Parameterwerte enthalten. Während der Entwicklung verwenden Sie die Konsole oder die API, um auf Parameter in verschiedenen Datentypen zu verweisen. Sie können beispielsweise auf einen Sitzungsparameter in einer statischen Auftragserfüllungsantwort für eine Route verweisen.
- Zur Laufzeit festgelegt: Zur Laufzeit können der Dienst „Konversations-Agents (Dialogflow CX)“, der die API aufruft, und Ihr Webhook-Dienst alle Parameterwerte festlegen. Beispiel: Der Dienst „Conversational Agents (Dialogflow CX)“ legt den Wert eines Intent-Parameters fest, wenn eine Endnutzereingabe dem Intent entspricht und die Eingabe Parameterdaten enthält.
- Zur Laufzeit abrufen: Zur Laufzeit verweist Ihr Parameter auf die festgelegten Parameterwerte. Sie können die Parameterwerte mit der API oder einem Webhook abrufen. Wenn beispielsweise ein Intent zugeordnet und Ihr Webhook aufgerufen wird, empfängt Ihr Webhook-Dienst die Parameterwerte für den Intent.
Parameter benennen
Für die Benennung von Parametern gelten die folgenden Regeln:
- Verwenden Sie die folgenden Zeichen:
[A-Z]
,[a-z]
,[0-9]
,.
,-
,_
- Bei Parameternamen wird nicht zwischen Groß- und Kleinschreibung unterschieden. Daher behandelt Conversational Agents (Dialogflow CX)
Apple
undapple
als denselben Parameter. Der Webhook und der API-Clientcode sollten auch Parameternamen als nicht Groß- und Kleinschreibung behandeln, da es für Parameternamen, die von Conversational Agents (Dialogflow CX) zurückgegeben werden, keine Garantie gibt. - Wenn Sie Parameter mit derselben ID oder demselben Anzeigenamen in verschiedenen Intents oder Formularen erstellen, müssen der Einheitstyp und andere Einstellungen für alle Definitionen identisch sein. Wenn sich der Entitätstyp oder andere Parametereinstellungen unterscheiden, verwenden Sie für jede Definition eine eindeutige Parameter-ID oder einen eindeutigen Anzeigenamen.
Parameterwerttypen
Parameterwerte unterstützen mehrere Wertetypen. Im Abschnitt zu Sitzungen unten wird beschrieben, wie Sie auf die einzelnen Parameterwerttypen verweisen. Die folgenden Typen werden unterstützt:
Typ | Beschreibung |
---|---|
Skalar | Ein einzelner numerischer Wert oder Stringwert. |
Zusammengesetzt | Ein JSON-Objekt, das durch den Abgleich einer zusammengesetzten Einheit oder durch das Ausfüllen eines Intent-Parameters mit den Feldern original und resolved erstellt wird. |
Liste | Eine Liste mit skalaren oder zusammengesetzten Werten, die für einen als Liste konfigurierten Parameter eingefügt werden. Weitere Informationen finden Sie unter Is List. |
Leere Parameterstrings und Nullwerte
Sie können String-Parameterwerte auf ""
festlegen. Dadurch wird der Parameter auf den leeren String gesetzt.
Sie können jeden Parameterwert auf null
setzen. Das bedeutet, dass der Parameter nicht festgelegt wurde.
Ursprüngliche Parameterwerte
Wird einer bestimmten Entität während der Laufzeit ein Text zugeordnet, wird dieser oft für eine einfachere Verarbeitung in einen Wert aufgelöst. Beispielsweise kann das Wort „Äpfel“ in der Endnutzereingabe für eine Obstentität als „Apfel“ aufgelöst werden.
Alle Werttypen für Intent-Parameterverweise können entweder auf den ursprünglichen oder den aufgelösten Wert verweisen.
Nur zusammengesetzte Werttypen für Sitzungsparameterverweise können auf den ursprünglichen Wert verweisen.
Intent-Parameter
Intents verwenden Parameter, um beim Abgleich von Intents von Endnutzern angegebene Daten zu extrahieren. Zum Definieren von Intent-Parametern werden folgende Daten verwendet:
- Name (auch als ID oder Anzeigename bezeichnet): Ein Name zur Bezeichnung des Parameters.
- Entitätstyp: der Entitätstyp, der dem Parameter zugeordnet ist
- Ist-Liste: Wenn "true", wird der Parameter als Liste von Werten behandelt.
- Im Log entfernen: Wenn der Wert "true" ist, werden vom Endnutzer bereitgestellte Parameterdaten entfernt.
Intent-Parameter definieren
Intent-Parameter werden während der Erstellung definiert, wenn Intent-Daten erstellt oder Trainingsformulierungen annotiert werden.
Intent-Parameter referenzieren
Intent-Parameterverweise können in statischen Antwortnachrichten der Auftragsausführung von Intent-Routen verwendet werden.
Sie können entweder auf den Originalwert oder auf den aufgelösten Wert verweisen.
Verwenden Sie eines der folgenden Formate, um für den aktuell zugeordneten Intent auf einen Parameter zu verweisen:
$intent.params.parameter-id.original $intent.params.parameter-id.resolved
Wenn die Parameter-ID beispielsweise date
lautet, können Sie auf den aufgelösten Wert als $intent.params.date.resolved
verweisen.
Intent-Parameter festlegen
Wenn eine Endnutzereingabe zur Laufzeit einem Intent zugeordnet wird, wird jeder von einer Annotation verwendete Parameter für die zugehörige Trainingsformulierung von Conversational Agents (Dialogflow CX) festgelegt.
Die Auftragsausführung für eine Intent-Route kann mit einer Voreinstellung für den Auftragsausführungsparameter einen Intent-Parameterwert zur Laufzeit festlegen.
Intent-Parameter abrufen
Während der Unterhaltungsrunde, in der ein Intent zugeordnet wird, kann Ihr Code auf die Werte des Intent-Parameters zugreifen.
Interaktionen mit der API geben Intent-Parameterwerte zurück.
Weitere Informationen finden Sie im Feld queryResult.parameters
der Methode detectIntent
für den Typ Session
.
Wählen Sie ein Protokoll und eine Version für die Sitzungsreferenz aus:
Protokoll | V3 | V3beta1 |
---|---|---|
REST | Sitzungsressource | Sitzungsressource |
RPC | Sitzungsoberfläche | Sitzungsoberfläche |
C++ | SessionsClient | Nicht verfügbar |
C# | SessionsClient | Nicht verfügbar |
Go | SessionsClient | Nicht verfügbar |
Java | SessionsClient | SessionsClient |
Node.js | SessionsClient | SessionsClient |
PHP | Nicht verfügbar | Nicht verfügbar |
Python | SessionsClient | SessionsClient |
Ruby | Nicht verfügbar | Nicht verfügbar |
Die empfangenden Intent-Parameterwerte von Webhook.
Weitere Informationen finden Sie in der Webhook-Anfrage im Feld intentInfo.parameters
.
Formularparameter
Für jede Seite können Sie ein Formular definieren. Dies ist eine Liste von Parametern, die vom Endnutzer für die Seite erfasst werden sollen. Der Agent interagiert mit dem Endnutzer mehrere Unterhaltungsrunden lang, bis er alle erforderlichen Formularparameter, auch Seitenparameter genannt, erfasst hat. Der Agent erfasst diese Parameter in der auf der Seite definierten Reihenfolge. Für jeden Formularparameter geben Sie auch Aufforderungen an, mit denen der Agent diese Informationen vom Endnutzer anfordert. Dieser Vorgang wird als Ausfüllen von Formularen bezeichnet.
Sie können beispielsweise ein Formular erstellen, in dem der Name und die Telefonnummer des Endnutzers für eine Collect Customer Info
-Seite erfasst werden.
Folgende Daten werden verwendet, um Formularparameter zu definieren:
Name der Konsolenoption | API-Feldkette | Beschreibung |
---|---|---|
Anzeigename | Page.form.parameters[].displayName |
Ein Name zur Identifizierung des Parameters. |
Entitätstyp | Page.form.parameters[].entityType |
Entity (Entität): Der Entitätstyp für den Parameter. |
Erforderlich | Page.form.parameters[].required |
Gibt an, ob der Parameter erforderlich ist. Erforderliche Parameter müssen ausgefüllt werden, bevor das Ausfüllen des Formulars abgeschlossen ist. Der Agent fordert den Endnutzer auf, Werte einzugeben. Weitere Informationen finden Sie unten im Abschnitt Formularparameter festlegen. |
Standardwert (nur sichtbar, wenn Erforderlich deaktiviert ist) | Page.form.parameters[].defaultValue |
Der Standardwert eines optionalen Parameters. Weitere Informationen finden Sie unten im Abschnitt Formularparameter festlegen. |
Is list | Page.form.parameters[].isList |
Wenn "true", wird der Parameter als Liste von Werten behandelt. |
Im Log entfernen | Page.form.parameters[].redact |
Bei Einstellung auf "true" werden vom Endnutzer bereitgestellte Parameterdaten entfernt. |
Erstauftragsausführung | Page.form.parameters[].fillBehavior.initialPromptFulfillment |
Erste Aufforderungen in Form von Auftragsausführung, um einen erforderlichen Parameterwert vom Endnutzer anzufordern. Weitere Informationen finden Sie unten im Abschnitt Formularparameter festlegen. |
Event-Handler für erneute Eingabeaufforderungen | Page.form.parameters[].fillBehavior.repromptEventHandlers |
Handler für erneute Eingabeaufforderungen: Diese werden verwendet, wenn der Agent den Endnutzer nach einem fehlgeschlagenen Versuch zur erneuten Eingabe zum Ausfüllen des Parameters hinweisen muss. Weitere Informationen finden Sie unter Handler für die erneute Eingabeaufforderung zum Ausfüllen von Formularen. Wenn keine Handler für erneute Eingabeaufforderungen definiert sind, wird der Agent nach einem fehlgeschlagenen Versuch mit den ursprünglichen Eingabeaufforderungen noch einmal auffordern. |
DTMF | Nicht verfügbar | Weitere Informationen finden Sie im folgenden Abschnitt DTMF. |
Formularparameter definieren und verwalten
Formularparameter werden bei der Erstellung einer Seite zur Entwurfszeit definiert.
Um die Reihenfolge der Formularparameter mit der Konsole zu ändern, klicken Sie auf der Seite auf den Abschnitt Parameter und ziehen Sie die Parameterzeilen in der Parametertabelle per Drag-and-drop.
Wenn Sie einen Formularparameter löschen möchten, klicken Sie auf der Seite auf den Abschnitt Parameter, bewegen Sie den Mauszeiger auf einen Parameter und klicken Sie dann auf die Schaltfläche „Löschen“ delete.
Formularparameter referenzieren
Formularparameterreferenzen werden nicht direkt verwendet. Sie können nur den Ausfüllstatus einzelner Formularparameter oder des gesamten Formulars prüfen. Sie können diese Formularstatusreferenzen in einer Bedingungsanforderung einer Bedingungsroute verwenden.
Verwenden Sie die folgende Bedingung, um zu prüfen, ob das vollständige Formular der aktuellen Seite ausgefüllt ist:
$page.params.status = "FINAL"
Mit der folgenden Bedingung können Sie prüfen, ob ein bestimmter Formularparameter in der letzten Runde ausgefüllt wurde:
$page.params.parameter-id.status = "UPDATED"
Formularparameter festlegen
Formularparameterwerte können auf verschiedene Arten festgelegt werden. In den folgenden Unterabschnitten werden die einzelnen Mechanismen zum Festlegen von Formularparameterwerten beschrieben.
Standardparameterwerte
Sie können Standardwerte für optionale Formularparameter angeben. Wenn das Ausfüllen des Formulars beginnt, werden alle nicht festgelegten optionalen Formularparameter auf ihre Standardwerte gesetzt. Diese Werte können mit einigen der folgenden Mechanismen initialisiert oder überschrieben werden.
Wenn ein Parameter erforderlich ist, wird sein Standardwert ignoriert.
Formular ausfüllen
Bei konversationellen Agents (Dialogflow CX) werden Parameterwerte, die der Endnutzer während des Ausfüllens eines Formulars angegeben hat, automatisch festgelegt. Der Agent erfasst die erforderlichen Parameter in der auf der Seite definierten Reihenfolge. Der Agent fordert den Endnutzer auf, die erforderlichen Werte mithilfe der anfänglichen Eingabeauftragsausführung für jeden erforderlichen Parameter einzugeben. Optionale Parameter lösen keine Aufforderungen aus.
Wenn ein erforderlicher Parameterwert nicht vom Endnutzer nach einer Agent-Eingabeaufforderung bereitgestellt wird, wird die erste Eingabeaufforderung wiederholt, es sei denn, in den Handlern für erneute Eingabeaufforderungen ist ein anderes Verhalten definiert. Wenn mehrere anfängliche Texteingaben definiert sind, entspricht das Agent-Verhalten dem Verhalten von Antworttexten der Auftragsausführung.
Weitergabe von Intent- und Sitzungsparametern
Wenn ein Parameter eines beliebigen Typs zur Laufzeit festgelegt wird, wird er in die Sitzung geschrieben und wird zu einem Sitzungsparameter.
Wenn eine Seite erstmalig aktiv wird und während ihres aktiven Zeitraums, wird jeder Formularparameter mit demselben Namen wie ein Sitzungsparameter automatisch auf den Sitzungsparameterwert gesetzt.
Dies kann mit einem zugeordneten Intent-Parameter in einer Intent-Route oder Parameterverteilung auftreten.
Die Intent- und Sitzungsparameterverteilung ist der einzige Mechanismus, um optionale Formularparameter auf Werte aus der Endnutzereingabe festzulegen. Dieser Mechanismus kann jedoch auch die erforderlichen Formularparameterwerte festlegen oder überschreiben.
Voreinstellungen für Auftragsausführungsparameter
Die Auftragsausführung für eine Route, einen Event-Handler oder eine erneute Aufforderung zur Formulareingabe kann eine Voreinstellung für einen Auftragsausführungsparameter verwenden, um einen Formularparameterwert zur Laufzeit festzulegen. Eine Voreinstellung für einen Auftragsausführungsparameter überschreibt einen Parameterwert, einschließlich der Standardwerte von Parametern.
Webhook-Parametereinstellung
Ihr Webhook kann Formularparameterwerte zur Laufzeit festlegen.
Weitere Informationen finden Sie in der Webhook-Antwort im Feld pageInfo.formInfo.parameterInfo
.
Formularparameter abrufen
Interaktionen mit der API geben Formularparameterwerte zurück.
Weitere Informationen finden Sie im Feld queryResult.parameters
der Methode detectIntent
für den Typ Session
.
Wählen Sie ein Protokoll und eine Version für die Sitzungsreferenz aus:
Protokoll | V3 | V3beta1 |
---|---|---|
REST | Sitzungsressource | Sitzungsressource |
RPC | Sitzungsoberfläche | Sitzungsoberfläche |
C++ | SessionsClient | Nicht verfügbar |
C# | SessionsClient | Nicht verfügbar |
Go | SessionsClient | Nicht verfügbar |
Java | SessionsClient | SessionsClient |
Node.js | SessionsClient | SessionsClient |
PHP | Nicht verfügbar | Nicht verfügbar |
Python | SessionsClient | SessionsClient |
Ruby | Nicht verfügbar | Nicht verfügbar |
Die empfangenden Formularparameterwerte von Webhook.
Weitere Informationen finden Sie in der Webhook-Anfrage im Feld pageInfo.formInfo.parameterInfo
.
Handler für die erneute Eingabeaufforderung zum Ausfüllen von Formularen
Handler für erneute Eingabeaufforderungen, auch als Event-Handler auf Parameterebene bezeichnet, werden verwendet, um das Verhalten von komplexen Parametern für erforderliche Parameter zu definieren. Handler für die erneute Eingabeaufforderung können beispielsweise verwendet werden, um die Eingabeaufforderung zu ändern, wenn der Endnutzer nach der ersten Eingabeaufforderung keinen Wert angibt, und um nach einer fehlgeschlagenen N-Eingabe zu einer anderen Seite zu wechseln.
Wenn keine Handler für die erneute Eingabeaufforderung definiert sind, wird die erste Eingabeaufforderung verwendet, um den Endnutzer nach Bedarf noch einmal aufzufordern.
Macht der Endnutzer unerwartete Eingaben, wird ein Ereignis vom Typ sys.no-match-*
oder sys.no-input-*
aufgerufen und alle für diese Ereignisse definierten Handler für die erneute Eingabeaufforderung werden aufgerufen.
Wie andere Ereignis-Handler ist ein Reprompt-Handler ein Zustands-Handler, der mit einer oder beiden der folgenden Optionen konfiguriert werden kann:
- Eine Auftragsausführung zur Bereitstellung einer Nachricht an den Nutzer mit einer erneuten Eingabeaufforderung und einer Parametervoreinstellung.
- Ein Umstellungsziel zum Ändern der aktuellen Seite.
Sitzungsparameter
Wenn ein Parameter eines beliebigen Typs zur Laufzeit festgelegt wird, wird er in die Sitzung geschrieben und wird zu einem Sitzungsparameter. Diese Parameter werden nicht explizit bei der Entwicklung definiert. Sie können während einer Sitzung jederzeit auf diese Sitzungsparameter verweisen.
Sitzungsparameter referenzieren
Sitzungsparameterverweise können in den statischen Antwortnachrichten für die folgenden Arten von Auftragsausführungen verwendet werden:
- Auftragsausführung für Seiteneingaben
- Auftragsausführung für Routen
- Auftragsausführung für Event-Handler
- Auftragsausführung für Eingabeaufforderungen für Formulare
- Auftragsausführungen für erneute Eingabeaufforderungen für Formulare
Die Referenzen können auch in folgenden Produkten verwendet werden:
- Webhook-Headerwerte für die Authentifizierung.
- Flexible Webhook-Anfragen zum Senden von Parameterwerten an einen Webhook.
Verwenden Sie folgende Formate, um auf einen Sitzungsparameter zu verweisen:
Skalar
So greifen Sie auf einen Parameter mit dem Entitätstyp "Skalar" zu:
$session.params.parameter-id
Wenn die Parameter-ID beispielsweise date
lautet, können Sie auf den Wert als $session.params.date
verweisen.
Composite
So greifen Sie auf ein Mitglied eines Parameters mit dem Entitätstyp "Composite" zu:
$session.params.parameter-id.member-name
Beispiel: Lautet die Parameter-ID
location
, können Sie auf denzip-code
-Mitgliedswert als$session.params.location.zip-code
verweisen.So greifen Sie auf den Originalwert eines Parameters mit dem Entitätstyp „Composite“ zu:
$session.params.parameter-id.original
Wenn Sie auf das vollständige Objekt eines Parameters mit dem Entitätstyp „Composite“ zugreifen möchten, verwenden Sie die Systemfunktion IDENTITY.
Liste
So greifen Sie auf eine vollständige Liste der Elemente zu:
$session.params.parameter-id
Beispiel: Wenn die Listenparameter-ID
colors
lautet und die aus einer Nutzerabfrage extrahierten Werte["red", "blue", "yellow"]
sind, können Sie mit$session.params.colors
auf alle Werte verweisen.So greifen Sie auf das x-te Element eines Listenparameters zu:
$session.params.parameter-id[i]
Beispiel: Wenn die Listenparameter-ID
colors
lautet, verweist$session.params.colors[0]
auf den ersten Wert.
Sitzungsparameter festlegen
Wenn das Ausfüllen des Formulars abgeschlossen ist, werden die ausgefüllten Parameter von konversationellen Agents (Dialogflow CX) in die Sitzung geschrieben.
Die Auftragsausführung für eine Route, einen Event-Handler oder eine erneute Eingabeaufforderung für Formulare kann mit einer Voreinstellung für Auftragsausführungsparameter einen Sitzungsparameterwert zur Laufzeit festlegen.
Ihr Webhook kann Sitzungsparameterwerte zur Laufzeit festlegen.
Weitere Informationen finden Sie in der Standard-Webhook-Antwort im Feld sessionInfo.parameters
oder in der flexiblen Webhook-Antwort.
Durch Interaktion mit der API können Sitzungsparameterwerte festgelegt werden.
Weitere Informationen finden Sie im Feld queryParams.parameters
der Anfragemethode detectIntent
für den Typ Session
.
Wählen Sie ein Protokoll und eine Version für die Sitzungsreferenz aus:
Protokoll | V3 | V3beta1 |
---|---|---|
REST | Sitzungsressource | Sitzungsressource |
RPC | Sitzungsoberfläche | Sitzungsoberfläche |
C++ | SessionsClient | Nicht verfügbar |
C# | SessionsClient | Nicht verfügbar |
Go | SessionsClient | Nicht verfügbar |
Java | SessionsClient | SessionsClient |
Node.js | SessionsClient | SessionsClient |
PHP | Nicht verfügbar | Nicht verfügbar |
Python | SessionsClient | SessionsClient |
Ruby | Nicht verfügbar | Nicht verfügbar |
Sitzungsparameter abrufen
Interaktionen mit der API geben Sitzungsparameterwerte zurück
Weitere Informationen finden Sie im Feld queryResult.parameters
der Methode detectIntent
für den Typ Session
.
Wählen Sie ein Protokoll und eine Version für die Sitzungsreferenz aus:
Protokoll | V3 | V3beta1 |
---|---|---|
REST | Sitzungsressource | Sitzungsressource |
RPC | Sitzungsoberfläche | Sitzungsoberfläche |
C++ | SessionsClient | Nicht verfügbar |
C# | SessionsClient | Nicht verfügbar |
Go | SessionsClient | Nicht verfügbar |
Java | SessionsClient | SessionsClient |
Node.js | SessionsClient | SessionsClient |
PHP | Nicht verfügbar | Nicht verfügbar |
Python | SessionsClient | SessionsClient |
Ruby | Nicht verfügbar | Nicht verfügbar |
Die empfangenden Sitzungsparameterwerte von Webhook.
Weitere Informationen finden Sie in der Webhook-Anfrage im Feld sessionInfo.parameters
.
Parameterverteilung
Wenn eine Endnutzereingabe einen Parameterwert bereitstellt, kann der Parameter an andere Ebenen weitergegeben werden:
- Wenn ein Intent-Parameter durch eine Intent-Übereinstimmung festgelegt wird, werden ähnliche Formularparameter für die aktive Seite auf denselben Wert gesetzt. Der Entitätstyp des Parameters wird durch die Intent-Parameterdefinition festgelegt.
- Wenn ein Intent-Parameter durch einen Intent-Abgleich festgelegt wird oder ein Formularparameter beim Ausfüllen eines Formulars festgelegt wird, wird der Parameter zu einem Sitzungsparameter.
DTMF für Telefonieintegrationen
Sie können DTMF (Dual-Tone-Multifrequenzsignalisierung) für einen Parameter aktivieren und konfigurieren. Nach der Aktivierung kann ein Endnutzer für einen Agent, der eine Telefonieintegration verwendet, das Telefon-Keypad verwenden, um Parameterwerte bereitzustellen.
Zur Vermeidung von Mehrdeutigkeit kann die DTMF-Eingabe sowohl in normalen als auch in DTMF-spezifischen Formen (empfohlen) interpretiert werden:
- Die normale Form ist einfach die Keypad-Werte, die vom Endnutzer eingegeben werden.
Beispiel:
123#
. - Die DTMF-spezifische Form konvertiert die Eingabe in
dtmf_digits_[digits]
, wobei[digits]
die ursprünglichen DTMF-Ziffern sind, wobei*
durchstar
und#
durchpound
ersetzt wird. Beispiel:123#
wird alsdtmf_digits_123pound
interpretiert.
Beim Abgleich von Entitätstypen für einen Parameter versucht Conversational Agents (Dialogflow CX), sowohl die normalen als auch die DTMF-spezifischen Formen abzugleichen.
Wenn ein Entitätstyp für die DTMF-Eingabe verwendet wird, sollten Sie Synonyme wie dtmf_digits_123
definieren, um den NLU-Abgleich zu verbessern.
Wenn die DTMF-Eingabe nicht die Beendigungsbedingung erfüllt (entweder hat sie die maximale Ziffernlänge nicht erreicht oder wurde sie nicht durch die Ziffer beendet wurde), wartet der Conversational Agents (Dialogflow CX)-Agent auf weitere Eingabe. Wenn in diesem Zeitraum das Zeitlimit ohne Sprache ausgelöst wird, ruft der Agent stattdessen ein Ereignis ohne Eingabe auf. Wenn nur eine Sprachäußerung erkannt wird, stimmt der Agent mit der Spracheingabe überein. Wenn sowohl die Sprach- als auch die DTMF-Eingabe erkannt werden, wird die Spracheingabe verworfen und nur die DTMF-Eingabe berücksichtigt.
So aktivieren und passen Sie DTMF für einen Parameter an:
Console
- Aktivieren Sie Erweiterte Einstellungen in den Agent-Sprach- und IVR-Einstellungen, falls Sie diese noch nicht aktiviert haben.
- Erstellen Sie einen Seitenparameter.
- Wählen Sie im Parameterbereich die Option DTMF aktivieren aus.
- Legen Sie für Maximale Ziffern die maximale Anzahl von Ziffern fest, die der Endnutzer für diesen Parameter angeben kann.
- Setzen Sie Ziffer beenden auf den Keypad-Wert, der die DTMF-Eingabe für den Parameter beendet.
Für diese Einstellung ist die Verwendung von
#
üblich. Die Ziffer wird nicht zur Conversational Agents-Abfrage (Dialogflow CX) im Agent hinzugefügt. Wenn die Ziffer also # ist und die Eingabe 123# ist, lautet die tatsächliche Abfrageeingabe „123“.
Beim Erstellen Ihres Agents können Sie DTMF-Eingaben im Simulator testen.
Smart Endpointing
Wenn Smart Endpointing für den Agent aktiviert ist, können Sie das Verhalten von Smart Endpointing für einen numerischen Parameter anpassen.
- Legen Sie Mindestanzahl an Ziffern fest, damit der Smart Endpointer wartet, bis alle Ziffern erfasst wurden.
- Wenn Sie Transkripte korrigieren festlegen, wird die Spracherkennung von Ziffern verbessert, indem häufige Fehler bei der Transkription von Ziffern korrigiert werden. Dies wird nur für Anfragen mit dem Sprachcode „en“ oder „en-*“ unterstützt.
- Legen Sie mit Wartezeitüberschreitung die zusätzliche Zeit fest, die konversationelle Agents (Dialogflow CX) auf weitere Eingaben des Nutzers warten.
Parameter mit Datenflussbereich
Flow-bezogene Parameter können als Voreinstellungen für Auftragsausführungsparameter oder Formularparameter definiert werden. Auf diese Parameter kann nur verwiesen werden, wenn der Flow, in dem sie definiert sind, aktiv ist. Sie werden nicht in den Sitzungsparametern gespeichert.
Verwenden Sie die folgende Syntax, um einen Parameter mit Flow-Bereich zu definieren oder darauf zu verweisen:
$flow.parameter-name
Beispiel: Wenn der Parametername date
lautet, können Sie den Parameter als $flow.date
definieren oder darauf verweisen.
Die Verwendung des Präfixes $
beim Definieren von Parametern unterscheidet sich von anderen Parametertypen, bei denen $
nicht für Parameterdefinitionen verwendet wird.
Beispiel für eine Parameterdefinition auf Flussebene:
Lebensdauer von Parameterwerten auf Flow-Ebene
In bestimmten komplexen Fällen müssen Sie möglicherweise wissen, wie Parameterwerte mit Flow-Bereich beibehalten (oder verworfen) werden, wenn ein Flow inaktiv und dann wieder aktiv wird.
Ob Parameterwerte mit Flow-Bereich beibehalten werden, wenn ein Flow inaktiv und dann wieder aktiv wird, hängt vom Flow-Stack und den Flow-Instanzen im Stack ab.
- Wenn Fluss A mit einem bestimmten Übergangsziel zu Fluss B wechselt, bleibt Fluss A (übergeordneter Fluss) im Stack, behält seine Parameterwerte auf Flussebene bei und eine neue Instanz von Fluss B (untergeordneter Fluss) wird dem Stack hinzugefügt.
- Wenn ein untergeordneter Ablauf über ein symbolisches Übergangsziel (z. B. END_FLOW) zum übergeordneten Ablauf zurückkehrt, wird der untergeordnete Ablauf aus dem Stapel entfernt, alle Parameterwerte mit dem Bereich des untergeordneten Ablaufs werden verworfen und alle Parameterwerte mit dem Bereich des übergeordneten Ablaufs werden beibehalten.
- Durch die Verwendung einer Reihe von Übergängen mit bestimmten Übergangszielen kann der Flow-Stack mehrere Instanzen eines Flow-Typs enthalten. Jede Instanz des Flusstyps hat eindeutige Parameterwerte auf Flussebene. Beispiel: A1 –> B1 –> C1 –> B2, wobei A, B und C Ablaufarten sind und die Zahlen Instanzen dieser Ablaufarten bezeichnen. In diesem Beispiel sind B1 und B2 verschiedene Instanzen von Ablauf B mit eindeutigen Parametern auf Ablaufebene.
Beispiele:
Übergänge | Ergebnis |
---|---|
Ablauf A (A1) wird aktiviert. Ablauf B (B1) wird mit einem bestimmten Umstellungsziel aktiviert. In Flow B wird mit einem symbolischen Umstellungsziel zurück zu Flow A (A1) gewechselt, der ihn initiiert hat. |
In Flow A bleiben die Parameterwerte erhalten. |
Ablauf A (A1) wird aktiviert. Ablauf B (B1) wird mit einem bestimmten Umstellungsziel aktiviert. Ablauf B wird mithilfe eines bestimmten Umstellungsziels in eine neue Instanz von Ablauf A (A2) umgestellt. |
Die neue Instanz von Flow A (A2) oben im Stapel hat keinen Zugriff auf die Parameterwerte von Flow A (A1) unten im Stapel. |
Ablauf A (A1) wird aktiviert. Ablauf B (B1) wird mit einem bestimmten Umstellungsziel aktiviert. Flow A (A1) wird über ein symbolisches Umstellungsziel aktiviert. Ablauf B (B2) wird mit einem bestimmten Umstellungsziel aktiviert. |
In Flow B (B2) werden Parameterwerte, die während der Aktivierung nach dem zweiten Übergang (B1) festgelegt wurden, nicht beibehalten. |
Parameter mit Anfragescope
Anfragebezogene Parameter sind kurzlebige Parameter, die von Conversational Agents (Dialogflow CX) erstellt werden. Sie können nur während des Lebenszyklus der aktuellen Anfrage referenziert werden und werden nicht in den Sitzungsparametern gespeichert.
Anfragebezogene Parameter werden von Konversations-Agents (Dialogflow CX) für die folgenden Funktionen generiert.
Integrierte Parameter
Sie können mit folgenden Methoden auf die verschiedenen Daten zugreifen, die mit der Anfrage verknüpft sind:
Referenz | Beschreibung |
---|---|
$request.agent-id | Die Kennung des Agents. |
$request.session-id | Die Kennung der Sitzung. |
$request.project-id | Die Kennung des Projekts. |
$request.location-id | Die ID des Agent-Standorts. |
$request.language | In QueryInput.language_code angegebener Sprachcode. |
$request.resolved-language | Der tatsächliche Sprachcode, der vom Agent während der Verarbeitung verwendet wird. Die ermittelte Sprache kann sich von der in der Anfrage angegebenen Sprache unterscheiden. Wenn der Agent beispielsweise nur „en“ unterstützt, die in der Anfrage angegebene Sprache aber „en-US“ ist, wäre die aufgelöste Sprache „en“. |
$request.user-utterance | Die Äußerung des aktuellen Nutzers, die in der Anfrage angegeben ist. |
$request.last-agent-utterance | Die letzte Äußerung, die vom Agent gesendet wurde. |
$request.nlu-confidence-score | Der aktuelle Konfidenzwert für die NLU-Klassifizierung. |
Benutzerdefinierte Nutzlast
Wenn QueryParameters.payload
festgelegt ist, können Sie mit $request.payload.param-id
auf den entsprechenden Parameter zugreifen.
Sentimentanalyse
Wenn die Sentimentanalyse aktiviert ist, sind die folgenden Sentimentreferenzen verfügbar:
Referenz | Typ | Beschreibung |
---|---|---|
$request.sentiment.score | Zahl | Stimmungswert zwischen -1,0 (negative Stimmung) und 1,0 (positive Stimmung). |
$request.sentiment.magnitude | Zahl | Gibt die allgemeine Stärke der (sowohl positiven als auch negativen) Stimmung zwischen 0,0 und +inf an. Anders als der „Score“-Wert ist dieser Wert nicht normalisiert. Jeder Ausdruck von Stimmung in der Endnutzereingabe, ob positiv oder negativ, trägt zum Magnitude-Wert bei. Längere Eingaben können höhere Werte haben. |
$request.sentiment.succeeded | Boolesch | „True“, wenn die Stimmungsanalyse erfolgreich war, andernfalls „false“. |
Entfernen von Parametern
Für jeden Intent- oder Formularparameter können Sie die Parameterentfernung aktivieren, um Endnutzer-Laufzeitparameterdaten aus Logs und dem internen Speicher von Conversational Agents (Dialogflow CX) zu entfernen.
Entfernende Parameter werden in Logs als $parameter-name_redacted
angezeigt.
Beispiel: Der Endnutzer gibt "My address is 1600 Amphitheatre Parkway" ein. Dies führt dazu, dass ein Address-Parameter an "1600 Amphitheatre Parkway" gesendet wird. Der protokollierte Text lautet "My address is $address_redacted".
So aktivieren Sie die Parameterentfernung:
Console
Klicken Sie beim Erstellen oder Aktualisieren eines Parameters das Kästchen Redlog im Log entfernen an.
API
Setzen Sie das Feld parameters[].redact
für den Typ Intent
auf "true".
Wählen Sie ein Protokoll und eine Version für die Intent-Referenz aus:
Protokoll | V3 | V3beta1 |
---|---|---|
REST | Intent-Ressource | Intent-Ressource |
RPC | Intent-Schnittstelle | Intent-Schnittstelle |
C++ | IntentsClient | Nicht verfügbar |
C# | IntentsClient | Nicht verfügbar |
Go | IntentsClient | Nicht verfügbar |
Java | IntentsClient | IntentsClient |
Node.js | IntentsClient | IntentsClient |
PHP | Nicht verfügbar | Nicht verfügbar |
Python | IntentsClient | IntentsClient |
Ruby | Nicht verfügbar | Nicht verfügbar |
Setzen Sie das Feld form.parameters[].redact
für den Typ Page
auf "true".
Wählen Sie ein Protokoll und eine Version für die Seitenreferenz aus:
Protokoll | V3 | V3beta1 |
---|---|---|
REST | Seitenressource | Seitenressource |
RPC | Seitenoberfläche | Seitenoberfläche |
C++ | PagesClient | Nicht verfügbar |
C# | PagesClient | Nicht verfügbar |
Go | PagesClient | Nicht verfügbar |
Java | PagesClient | PagesClient |
Node.js | PagesClient | PagesClient |
PHP | Nicht verfügbar | Nicht verfügbar |
Python | PagesClient | PagesClient |
Ruby | Nicht verfügbar | Nicht verfügbar |
Alternativ können Sie alle Parameter eines bestimmten Entitätstyps unkenntlich machen.