Eine Möglichkeit, die Datenqualität sicherzustellen, besteht darin, Einschränkungen (Constraints) für die Datenfelder in Ihrem Formular hinzuzufügen. Einschränkungen helfen, zu verhindern, dass Benutzer ungültige oder unmögliche Antworten eingeben. Wenn Sie beispielsweise nach dem Einkommen einer Person fragen, möchten Sie unrealistische Werte wie negative Zahlen oder extrem hohe Werte vermeiden. Das Hinzufügen von Dateneinschränkungen in Ihrem Formular ist einfach. Folgen Sie einfach den nachstehenden Schritten:

  1. Fügen Sie Ihrem Formular eine neue Spalte namens “constraint” hinzu.
  2. Geben Sie in der Spalte “constraint” eine Formel ein, die die Grenzen für die Antwort festlegt.

Beispiel

Betrachten wir ein Beispiel, bei dem wir eine Einschränkung für das Einkommen einer Person hinzufügen möchten. Die Einschränkung erfordert, dass das Einkommen zwischen 0 $ und 1.000.000 $ liegt. So können Sie die Einschränkung einrichten:

nameconstraint
Income. >= 0 & . <= 1000000

Im obigen Beispiel bezieht sich der Punkt “.” in der Formel auf die Fragevariable, die den vom Benutzer für die Frage “Income” eingegebenen Wert darstellt. Die Einschränkung “. >= 0 && . <= 1000000” stellt sicher, dass das eingegebene Einkommen größer oder gleich 0 und kleiner oder gleich 1.000.000 ist.

Strikte Einschränkung (Hard constraint)

Eine strikte Einschränkung blockiert die Formularübermittlung vollständig, wenn der eingegebene Wert den Ausdruck nicht erfüllt. Der Interviewer kann erst fortfahren, wenn er einen gültigen Wert eingegeben hat.

Um eine strikte Einschränkung hinzuzufügen, geben Sie Ihren Ausdruck in die Spalte constraint ein. Optional können Sie eine lesbare Meldung in constraint_message hinzufügen:

typenamelabelconstraintconstraint_message
integerageAlter des Befragten. > 0 and . <= 120Das Alter muss zwischen 1 und 120 liegen
decimaltemperatureKörpertemperatur (°C). >= 35 and . <= 42Die Temperatur muss zwischen 35°C und 42°C liegen
textphoneTelefonnummerregex(., '^[0-9]{10}$')Geben Sie eine 10-stellige Telefonnummer ein

Mehrere Bedingungen

Kombinieren Sie Bedingungen mit and / or:

  . >= 0 and . <= 100
  
  . = 'yes' or . = 'no'
  

Verwendung von regex() für Mustervalidierung

Die Funktion regex(value, pattern) prüft einen Wert gegen einen regulären Ausdruck:

typenamelabelconstraintconstraint_message
textemailE-Mail-Adresseregex(., '^[^@]+@[^@]+\.[^@]+$')Geben Sie eine gültige E-Mail-Adresse ein
textzip_codePostleitzahlregex(., '^[0-9]{5}$')Geben Sie eine 5-stellige Postleitzahl ein

Referenzierung anderer Felder in einer Einschränkung

Verwenden Sie ${fieldname}, um auf Werte aus anderen Fragen zu verweisen:

typenamelabelconstraintconstraint_message
integerend_yearEndjahr. >= ${start_year}Das Endjahr muss nach dem Startjahr liegen
decimalloan_repaidZurückgezahlter Betrag. <= ${loan_amount}Es kann nicht mehr zurückgezahlt werden als der Darlehensbetrag

Sanfter Hinweis (Soft alert)

Ein sanfter Hinweis (auch Soft Constraint oder Warnung genannt) warnt den Interviewer, dass ein Wert ungewöhnlich erscheint, erlaubt aber dennoch das Fortfahren. Dies ist nützlich, wenn ein Wert technisch gültig, aber statistisch unwahrscheinlich ist.

rtSurvey unterstützt sanfte Hinweise über die Spalte constraint mit einem speziellen constraint_type-Ansatz oder über das Erscheinungsbild soft in Kombination mit einem Notizfeld.

Das häufigste Muster ist die Verwendung einer Notiz mit einem relevant-Ausdruck, der den verdächtigen Wert markiert, gepaart mit einer acknowledge-Frage zur Bestätigung:

typenamelabelrelevant
integerchildrenAnzahl der Kinder
notechildren_warningWarnung: Sie haben ${children} Kinder eingegeben. Bitte bestätigen Sie, dass dies korrekt ist.. > 15
triggerchildren_confirmBestätigen Sie, dass die Anzahl der Kinder korrekt ist${children} > 15

Sanfter Hinweis nur mit constraint_message

Für eine einfachere weiche Warnung können Sie die Einschränkung so formulieren, dass sie bei extremen Werten warnt, aber dennoch einen weiten Bereich zulässt:

typenamelabelconstraintconstraint_message
integerchildrenAnzahl der Kinder. >= 0 and . <= 30Dieser Wert erscheint sehr hoch. Bitte überprüfen Sie ihn.
War diese Seite hilfreich?