- Posts: 6
- Thank you received: 0
Welcome to the LimeSurvey Community Forum
Ask the community, share ideas, and connect with other LimeSurvey users!
Offene numerische Antworten automatisch kategorisieren
- skofield
- Topic Author
- Offline
- New Member
habe eine kurze Frage. Ist es möglich, dass ich das Alter offen numerisch abfrage und dann gleich in Alterskategorien einteile? Ich würde dieses Workaround "brauchen", da ich mit einem Panelanbieter zusammenarbeite und ich daher Quoten setzen muss. Natürlich könnte ich das Alter gleich in Kategorien abfragen aber wenn es irgendwie möglich ist würde ich es gern offen machen, um bei der Analyse flexibel mit den Altersgruppen arbeiten zu können.
Danke
Bernd
- holch
- Offline
- LimeSurvey Community Team
- Posts: 11660
- Thank you received: 2742
Einmal eine Frage mit den Alterskategorien Typ "List (Radio)" und dann noch eine "Equation" (auf Deutsch Formel?").
In der Equation fragst du dann das Alter aus der offenen numerischen Abfrage ab und checkst in welche Alterskategorie die Person gehört und "markierst" mit der Equation quasi die Alterskategorie in der Frage "List (Radio)".
Ich kenne deine Fragencodes nicht. Aber nehmen wir mal an, dass die erste Frage mit dem Alter den Fragencode "alter" hat.
Die zweite Frage mit den Kategorien nenne ich mal alter2 mit den Antwortoptionen mit den jeweiligen Codes: 0-18 (1), 19-30 (2), 31-50 (3), 51+ (4),
In der Equation steht dann irgend sowas (nicht getestet, nur eine Basisidee):
{if(alter > 50, alter2=4,if(alter > 30, alter2=3,if(alter > 18, alter2=2,1)))}
Dieser Code fragt eben ab, welches Alter angegeben wurde und checkt dann ob die Person älter als 50 ist, wenn ja dann markiert er die Kategorie 4, wenn nicht checkt er ob die Person älter als 30 ist, wenn ja, dann markiert er Kategorie 3, usw. bis zur letzten Abfrage, ob die Person älter als 18 ist. Wenn sie das auch nicht ist, dann brauchen wir nicht weiter fragen, die Person muss unter 18 sein, weil alles darüber haben wir ja schon abgefragt.
Die Equation und die List (Radio) versteckst du über die entsprechende Einstellung in den Fragenoptionen (aber erst nachdem du ausführlich getestet hast und gesehen hast, dass alles ordentlich funktioniert. Manche verstecken die Fragen sofort und finden dann ihre Fehler natürlich nie.
Auf diese List (Radio) kannst du dann mit Quoten zugreifen.
I answer at the LimeSurvey forum in my spare time, I'm not a LimeSurvey GmbH employee.
No support via private message.
- skofield
- Topic Author
- Offline
- New Member
- Posts: 6
- Thank you received: 0
- Joffm
- Offline
- LimeSurvey Community Team
- Posts: 12940
- Thank you received: 3979
Du willst die Klasseneinteilung des Alters ja nicht noch einmal anzeigen.
Dann benötigst Du die Einfachnennungsfrage nicht.
Eine Frage vom Typ "Gleichung" genügt.
Nenne sie - wie gesagt - "alter2" mit Folgendem:
{if(alter > 50, 4,if(alter > 30, 3,if(alter > 18, 2,1)))}
Dann:
1. Ist in der Antwort-Tabelle eine Spalte "alter2" mit dem berechneten Wert
2. Kannst Du Deine Quote auf die Frage "alter2" setzen.
Joffm
Volunteers are not paid.
Not because they are worthless, but because they are priceless
- skofield
- Topic Author
- Offline
- New Member
- Posts: 6
- Thank you received: 0
- holch
- Offline
- LimeSurvey Community Team
- Posts: 11660
- Thank you received: 2742
Du willst die Klasseneinteilung des Alters ja nicht noch einmal anzeigen.
Dann benötigst Du die Einfachnennungsfrage nicht.
Eine Frage vom Typ "Gleichung" genügt.
Kann man Quoten jetzt auch auf Equation / Gleichungen anwenden? Ging zumindest früher nicht. Falls das jetzt geht, weisst du seit welcher Version?
I answer at the LimeSurvey forum in my spare time, I'm not a LimeSurvey GmbH employee.
No support via private message.
- holch
- Offline
- LimeSurvey Community Team
- Posts: 11660
- Thank you received: 2742
Das funktioniert soweit, nur müsst ich in die Gleichung noch einbauen, dass wenn alter noch leer ist, nicht eine 1 gesetzt wird. Sonst leitet mir bei Start die Quote alter = 1 zu meinem Panelanbieter zurück, da ich hier eine Quote von 0 hab.
Deine Altersfrage ist doch sicher eine Pflichtfrage? D.h. wenn die Frage angezeigt wurde und man im Fragebogen weiter gegangen ist, dann muss da zwingend was drin stehen. Also sollte dein Fall gar nicht auftauchen. Also beschreibe doch mal, in welchem Szenario es passieren kann, dass die Frage leer ist und die Quote das dann als Null nimmt.
Es kann also eigentlich nur passieren, wenn die Gleichung auf der gleichen "Seite" gesetzt ist wie deine Altersfrage. Aber da sollte meiner Meinung nach eigentlich erst die Fehlermeldung für die leere Altersfrage kommen, bevor die Quote getriggert wird. Oder?
I answer at the LimeSurvey forum in my spare time, I'm not a LimeSurvey GmbH employee.
No support via private message.
- Joffm
- Offline
- LimeSurvey Community Team
- Posts: 12940
- Thank you received: 3979
Kann man Quoten jetzt auch auf Equation / Gleichungen anwenden? Ging zumindest früher nicht. Falls das jetzt geht, weisst du seit welcher Version?
Gerade ausprobiert.
In 2.50/2.73 ging es nicht, aber in 3.x
Joffm
Volunteers are not paid.
Not because they are worthless, but because they are priceless
- holch
- Offline
- LimeSurvey Community Team
- Posts: 11660
- Thank you received: 2742
In 2.50/2.73 ging es nicht, aber in 3.x
Cool, muss irgendwie an mir vorbei gegangen sein. Ist ja auch sehr sinnvoll, dass man die Quote direkt auf die Gleichung setzen kann, ohne den Umweg über eine weitere versteckte Frage.
I answer at the LimeSurvey forum in my spare time, I'm not a LimeSurvey GmbH employee.
No support via private message.
- skofield
- Topic Author
- Offline
- New Member
- Posts: 6
- Thank you received: 0
- Joffm
- Offline
- LimeSurvey Community Team
- Posts: 12940
- Thank you received: 3979
Aus irgendeinem Grund wurde das gleich beim Aufruf des Surveys "getriggert" und man wurde gleich zurückgeschickt. Hab die Formel dann weggelassen und das Problem anders gelöst.
Nein, nicht aus "irgendeinem Grund". Das ist der normale Lauf der Dinge.
Daher ja auch das {if(is_empty(random),rand(1,10),random)}, damit es falls diese Gleichung mit mehreren Fragen in einer Gruppe ist, diese nicht jedesmal geändert wird.
In Deinem Fall war es dann z.B. so, dass bei
{if(alter > 50, 4,if(alter > 30, 3,if(alter > 18, 2,1)))} die "1" getriggert wird, obwohl noch kein Alter eingegeben war.
Klar, dass muss man berücksichtigen.
Aber gut, dass Du eine Lösung gefunden hast.
Joffm
Volunteers are not paid.
Not because they are worthless, but because they are priceless
- skofield
- Topic Author
- Offline
- New Member
- Posts: 6
- Thank you received: 0
Nein, nicht aus "irgendeinem Grund". Das ist der normale Lauf der Dinge.
Aus einem Grund, den ich nicht kannte.
Danke für die Hilfe.