Welcome to the LimeSurvey Community Forum

Ask the community, share ideas, and connect with other LimeSurvey users!

listifop bei Matrix

  • rcn_mstr
  • rcn_mstr's Avatar Topic Author
  • Offline
  • New Member
  • New Member
More
3 years 1 month ago #212738 by rcn_mstr
listifop bei Matrix was created by rcn_mstr
Hallo,
Ich bin ziemliche Anfängerin bei Limesurvey und konnte nach langem Suchen und Ausprobieren keine Antwort auf mein Problem finden. Die Version ist Version 3.24.6+201109

Ich möchte gerne die Optionen einer Matrixfrage, die von Teilnehmenden hoch bewertet wurden, in einem späteren Text auflisten lassen. Also die Teilnehmenden sollen bei der Matrix angeben wie wichtig ihnen verschiedene Werte sind und zu einem späteren Zeitpunkt soll im Text einer Frage alle Werte, die zuvor als "sehr wichtig" bewertet wurden, aufgelistet werden. 
Dafür scheint die listifop Funktion geeignet, die ich hier gefunden habe ( ExpressionScript examples – LimeSurvey Manual ).
Wenn ich sie entsprechend dem Beispiel eingebe 
{listifop( 'value', '==', 'A5', 'question', ',', that.WerteWichtigkeit.sgqa)}
, funktioniert es nicht. Beim Ausprobieren wird mir an dieser Stelle dann nur eine leere Stelle angezeigt. Ich habe auch ausprobiert statt 'A5' '5' oder 'Sehr wichtig' in der Funktion einzusetzen.

Die gleiche Funktion funktioniert aber einwandfrei, wenn ich das Fragenformat der Matrix in eine Matrix mit vorgegebener 5-Punkte Auswahl ändere. Dabei kann ich aber ja die Antwortenoptionen nicht benennen.
Meine Vermutung ist, dass bei der normalen Matrix die Antwortoptionen kein Value haben, da mir in der Fragenlogik folgendes angezeigt wird:
[img][/img]
Nach meiner Überlegung gäbe es folgende Lösungsansätze:
1. Ich müsste den Antwortoptionen der Matrix ein value zuweisen. Ich konnte aber nicht finden, ob oder wie das geht.
2. Ich müsste in der Funktion auf etwas anderes als value prüfen lassen. Im Expression Manager steht an der Stelle cmpProp, leider verstehe ich das nicht und konnte nicht herausfinden was man anstelle von value nutzen könnte. 

Stimmen meine Überlegungen? Kann mir jemand helfen?
Schon mal vielen Dank!
The topic has been locked.
  • holch
  • holch's Avatar
  • Offline
  • LimeSurvey Community Team
  • LimeSurvey Community Team
More
3 years 1 month ago #212740 by holch
Replied by holch on topic listifop bei Matrix
Sorry, aber mit deinem Bild ist irgendwas schief gelaufen...

I answer at the LimeSurvey forum in my spare time, I'm not a LimeSurvey GmbH employee.
No support via private message.

The topic has been locked.
  • Joffm
  • Joffm's Avatar
  • Away
  • LimeSurvey Community Team
  • LimeSurvey Community Team
More
3 years 1 month ago - 3 years 1 month ago #212744 by Joffm
Replied by Joffm on topic listifop bei Matrix
Bild mit Firefox eingebunden?

Okay, ich habe mich noch nie so richtig mit dieser Funktion auseinandergesetzt.
Werde ich also einmal. Aber erst morgen.

Falls es mir nicht gelingt, die Ideen der Entwickler zu ergründen, gebe ich Dir auf jeden Fall eine andere Lösung.
{list(if(Q1_SQ001==5,Q1_SQ001.question,""),if(Q1_SQ002==5,Q1_SQ002.question,""),if(Q1_SQ003==5,Q1_SQ003.question,"")...}
Musst Du noch an die Anzahl der Teilfragen anpassen.

Ich habe hier als Code 5 genommen, nicht "A5".
Wenn ich schon "sehr wichtig" sehe, gehe ich davon aus, dass dies eine Skala ist, dass Du also einemal statistische Test rechnen willst, sei es nur ein Mittelwert, eine Standardabweichung, oder t-Tests und ANOVAs.
Dann benötigst Du also numerische Werte, keine Texte wie "A5". 
Ehrlich: Der Mittelwert von "A1" und "A4" ist nicht "A2,5".

Nur, damit Du es nicht erst bei der Auswertung bemerkst und dann umkodieren musst.

Joffm

Volunteers are not paid.
Not because they are worthless, but because they are priceless
Last edit: 3 years 1 month ago by Joffm. Reason: Falsche Gleichung korrigiert
The topic has been locked.
  • Joffm
  • Joffm's Avatar
  • Away
  • LimeSurvey Community Team
  • LimeSurvey Community Team
More
3 years 1 month ago #212751 by Joffm
Replied by Joffm on topic listifop bei Matrix
Gut ich habe es eruiert.

Zunächst etwas zur Syntax:
{listifop( "code", "==", 5, "question", ", ", that.Q1.sgqa)}

Hierzu sollte man lesen:
[url] manual.limesurvey.org/ExpressionScript_-...#Access_to_variables [/url]

1. "code"
Dies gibt an, welche property einer Frage man zum Vergleich nutzen will.
Zum Beispiel "code" für den Code einer Antwortoption, "value" für den Assessment-Wert.
Theoretisch könnte man auch Sachen wie "qseq" oder "gseq" nehmen - ich weiß allerdings nicht, wozu.

2. "=="
Klar das ist der Vergleichsoperator. Hier sind alle Operatoren möglich "< <= > >= lt le gt ge" und auch "!=" 

3. "question"
Dies ist nun die property, die in der Liste angezeigt wird. In diesem Fall der Text der Frage

4. "that.Q1.sgqa"
Zu guter Letzt gibt es hier die Frage(n), die für die Liste hergenommen werden.

Die obige Gleichung heißt also umgangssprachlich: , 

Erstelle eine komma-separierte Liste aller Texte der Teilfragen von Frage Q1, bei denen der Code der Antwortoption gleich 5 ist.

Und dann gibt es dieses:
 

 

Und ganz wichtig (hat mich viel Zeit gekostet:
Dies Gleichung funktioniert nicht, wenn sie auf derselben Seite wie die Frage ist.

Joffm

 

Volunteers are not paid.
Not because they are worthless, but because they are priceless
The topic has been locked.
  • rcn_mstr
  • rcn_mstr's Avatar Topic Author
  • Offline
  • New Member
  • New Member
More
3 years 1 month ago #212763 by rcn_mstr
Replied by rcn_mstr on topic listifop bei Matrix
Entschuldigt bitte das Bild. Ich habs mit Microsoft Edge eingebunden, passiert das bei manchen Browsern öfter?

Joffm, Vielen lieben Dank, dass du dir die Zeit genommen und es so ausführlich erklärt hast! Mit "code" statt "value" funktioniert es!

Und danke für den Hinweis bzgl. der Codierung der Antwortoptionen. Das hätte ich vermutlich später geändert, aber es von Anfang an anzupassen macht natürlich mehr Sinn.

Liebe Grüße!
The topic has been locked.
  • Joffm
  • Joffm's Avatar
  • Away
  • LimeSurvey Community Team
  • LimeSurvey Community Team
More
3 years 1 month ago #212765 by Joffm
Replied by Joffm on topic listifop bei Matrix
Falls es Dich interessiert.

Assessment-Werte kann man vergeben, wenn man dies vorher aktiviert
 

Dann hat man in den Antwortoptionen diese zusätzliche Spalte.
 

Aber, diese ganze Assessment-Geschichte ist veraltet; heute arbeiten wir mit Expression Manager.
Ein einziger Vorteil bleibt; man kann negative Werte vergeben.
Aber natürlich dann doch mit Expression Manager bearbeiten über die ".value(NAOK)" property.

Zum Bild:
Nachdem es bei mir mit Firefox "in die Hose geht", benutze ich hier im Forum Chrome.
Wenn Du dieses Problem auch bei Edge hast, hm.
Wegen Firefox habe ich bereits einen Bugreport gemacht.

Dieser neue Editor hat aber noch ein  paar Macken mehr.

Joffm

Volunteers are not paid.
Not because they are worthless, but because they are priceless
The topic has been locked.
Moderators: Joffm

Lime-years ahead

Online-surveys for every purse and purpose