Actions

Ví dụ về ExpressionScript

From LimeSurvey Manual

Revision as of 18:49, 15 January 2024 by Maren.fritz (talk | contribs) (Created page with "==Ẩn câu hỏi nếu câu trả lời ở câu hỏi trước trống==")

Template:Lưu ý


Cấu trúc

Phần đầu tiên của bài viết sẽ mô tả Biểu thức có thể được sử dụng để làm gì và nơi tìm/thêm Biểu thức. Phần thứ hai cung cấp các ví dụ về cách sử dụng Biểu thức.


Các loại biểu thức

LimeSurvey sử dụng Biểu thức cho các mục đích sau:


Mức độ liên quan

Mục đích: Ẩn nhóm câu hỏi/câu hỏi

Mức độ liên quan kiểm soát việc một nhóm câu hỏi hoặc câu hỏi được hiển thị hay ẩn. Nếu kết quả của Biểu thức là "true" (tức là 1) thì phần tử sẽ được hiển thị. Ngược lại (nếu kết quả của Biểu thức là "false" (tức là 0)), phần tử sẽ bị ẩn.

Type Hiển thị/ẩn Tìm ở đâu Ảnh chụp màn hình
Mức độ liên quan của nhóm câu hỏi nhóm câu hỏi Tạo/Chỉnh sửa nhóm câu hỏi -> "Phương trình liên quan:" 30px
Câu hỏi Mức độ liên quan câu hỏi Tạo/Chỉnh sửa câu hỏi -> "Phương trình liên quan:" 30px
Độ liên quan của câu hỏi con câu hỏi phụ Chỉnh sửa câu hỏi phụ -> "Phương trình liên quan:" 30px


Xác thực

Mục đích: Xác thực dữ liệu đầu vào/hành động đối với câu hỏi/câu hỏi phụ/câu trả lời

Xác thực kiểm soát xem thông tin đầu vào của người trả lời vào câu hỏi hoặc hành động có hợp lệ hay không. Nếu kết quả của biểu thức là "true" (tức là 1), lớp "tốt" sẽ được áp dụng cho phần tử và thông báo xác thực. Mặt khác, nếu kết quả của biểu thức là "false" (tức là 0)), lớp "lỗi" sẽ được áp dụng cho phần tử và thông báo xác thực. Bạn có thể khai báo kiểu cho các lớp này trong template.css.

Type Xác thực Tìm ở đâu Ảnh chụp màn hình
Xác thực câu hỏi câu hỏi Tạo/Chỉnh sửa câu hỏi -> "tab logic" - > "Phương trình xác thực câu hỏi" 30px
Xác thực câu hỏi con câu hỏi con Tạo/Chỉnh sửa câu hỏi -> "tab Logic" -> " Phương trình xác thực câu hỏi con"

Xuất văn bản

Mục đích: (Làm gì đó) và viết ra một số văn bản

Một biểu thức có thể được sử dụng để viết ra một số văn bản. Ví dụ: bạn có thể kiểm tra hoặc tính toán một cái gì đó và chỉ định kết quả đầu ra tùy thuộc vào kết quả kiểm tra hoặc tính toán. Nó cũng có thể được sử dụng để chèn nội dung câu hỏi, câu trả lời, loại câu hỏi, ... của câu hỏi được sử dụng trước khi sử dụng Biểu thức. Đầu ra văn bản có thể được sử dụng ở mọi nơi có văn bản được hiển thị và có thể trả về mọi loại kết quả.

Trường hợp sử dụng Description
Micro may đo Điều chỉnh văn bản, ví dụ: viết "Mr" hoặc "Mrs" tùy theo câu hỏi về giới tính được hỏi trước đó
Tính toán Tính một giá trị và viết nó ra, ví dụ: "Thu nhập của gia đình bạn là xxx"
Reference Chèn văn bản từ một phần tử, ví dụ: "Tên bạn là xxx. Bạn bao nhiêu tuổi?"


Lưu trữ câu trả lời

Mục đích: (Làm gì đó,) (viết một số văn bản) và lưu trữ một cái gì đó trong cơ sở dữ liệu

Loại câu hỏi phương trình có thể được sử dụng để lưu trữ nội dung nào đó trong cơ sở dữ liệu. Bạn có thể làm điều gì đó với Biểu thức, hiển thị câu hỏi Phương trình (tương tự như hiển thị văn bản) và lưu trữ kết quả của Biểu thức trong cơ sở dữ liệu. Nó lưu trữ câu trả lời vào bảng phản hồi. Sau đó, kết quả có thể được sử dụng trong tính năng thống kê hoặc cũng có thể được nhập vào một trong các định dạng do chức năng xuất LimeSurvey cung cấp.

Ví dụ về biểu thức

Chèn câu trả lời từ câu hỏi trước

Purpose Chèn câu trả lời từ câu hỏi trước
Type Reference
Ví dụ Câu hỏi một (mã câu hỏi " Q00"): Bạn sống ở thành phố nào?
Câu hỏi thứ hai (mã câu hỏi "Q01") Bạn đã sống ở THÀNH PHỐ bao lâu rồi?
Việc cần làm: Nên sử dụng câu trả lời của câu hỏi một thay vì "THÀNH PHỐ" trong câu hỏi thứ hai.
Expression {QOO}
Description Câu trả lời được cung cấp trong Q00 thay thế trường Q00 từ câu hỏi thứ hai
Các bước Tạo/Chỉnh sửa câu hỏi thứ hai
Chèn "Bạn đã sống ở {QOO} (năm) được bao lâu?" vào trường văn bản câu hỏi
File:Biểu thức đơn giản tên thành phố.png

Sử dụng câu hỏi phương trình ẩn để tự động điền câu trả lời

Vấn đề: Hãy tưởng tượng bạn có hai câu hỏi Q1 và Q2. Q1 hỏi người trả lời về độ tuổi của họ. Q2 chia người trả lời thành 3 nhóm: tuổi dưới 20, tuổi 20, tuổi lớn hơn 20. Vì vậy, Q2 nên sử dụng các giá trị “1”, “2”, “3” tương ứng với các điều kiện trên. Ngoài ra, chúng ta không nên quên ẩn Q2 (câu hỏi sẽ không được hiển thị trong khảo sát nhưng các giá trị sẽ thông qua "quy trình nền" trong bảng phản hồi).

Để điền vào cơ sở dữ liệu bằng loại câu hỏi Phương trình:

  • Đầu tiên, tạo một câu hỏi có mã Q1 làm câu hỏi nhập số.
  • Sau đó tạo một câu hỏi khác có mã Q2 làm câu hỏi phương trình .
  • Trong chương tab "Cài đặt hiển thị" của Q2:
    • đặt trường "Luôn ẩn câu hỏi này" là "Bật"
    • nhập vào trường "Phương trình" biểu thức:
 {if(Q1.NAOK < 20, "1", if(Q1.NAOK > 20, "3", "2"))}

Tạo trang tóm tắt bằng cách sử dụng trình giữ chỗ

Hướng dẫn này trình bày cách bạn có thể tạo một cái nhìn tổng quan ở cuối cuộc khảo sát, liệt kê tất cả các câu hỏi và câu trả lời thông qua phần giữ chỗ ExpressionScript. Nó cũng chỉ ra cách thực hiện giới hạn cái nhìn tổng quan như vậy chỉ ở những câu hỏi đã được trả lời.

Bạn có thể tải xuống ví dụ của chúng tôi từ đây: Ví dụ khảo sát về người giữ chỗ khảo sát.


Các loại câu hỏi đang được sử dụng ở đây:

1. Câu hỏi một lựa chọn / văn bản đơn/câu hỏi số

  • Danh sách (thả xuống)
  • Danh sách (radio) [L]
  • Có/Không [Y]
  • Văn bản dài tự do [T ]
  • Văn bản tự do ngắn [S]
  • Nhập số [N]
  • Phương trình [*]


2. Câu hỏi với câu hỏi phụ

  • Nhiều văn bản ngắn [Q]
  • Trắc nghiệm [M]
  • Array [F]
  • Array (Có/Không/Không chắc chắn) [C]!N !*Array (lựa chọn 10 điểm) [B]


3. Câu hỏi có 2 thang đo

  • Array thang đo kép [1]


4. Câu hỏi với thang đo X và Y

  • Array (Số) [:]


5. Mặt nạ câu hỏi

  • Hiển thị văn bản [X]


Trong ví dụ đơn giản này, tổng quan của chúng tôi sẽ là một danh sách đơn giản với:

- Nội dung câu hỏi: Câu trả lời của người dùng


Câu hỏi một lựa chọn/văn bản đơn/câu hỏi số

Đối với tất cả các loại câu hỏi này, Limesurvey sẽ lưu trữ một câu trả lời duy nhất:

  • Danh sách (thả xuống)
  • Danh sách (radio)
  • Danh sách có nhận xét
  • 5 điểm lựa chọn
  • Có/Không
  • Văn bản ngắn tự do
  • Văn bản dài tự do!N !*Văn bản miễn phí rất lớn
  • Nhập số
  • Phương trình
  • Ngày
  • Giới tính

Giả sử mã câu hỏi của câu hỏi là q1, chúng ta có thể tham khảo nội dung câu hỏi và câu trả lời bằng cách sử dụng:

- {q1.question}: {q1.shown}

Ví dụ:

- Bạn bao nhiêu tuổi?: 25


Nếu bạn muốn kiểm tra xem câu hỏi đó đã được trả lời chưa, bạn có thể đặt câu lệnh IF xung quanh đầu ra của mình:

{if(!is_empty(q1),join("- ",q1.question,": ",q1.shown),"")}

Điều này "dịch" thành: NẾU câu hỏi có mã q1 không trống, xuất ra "- " VÀ văn bản câu hỏi VÀ ": " VÀ văn bản câu trả lời (hàm join() nối các phần tử dưới dạng một chuỗi mới; ELSE: không xuất ra gì (" " có nghĩa là chuỗi trống).

Câu hỏi có câu hỏi phụ

Đối với tất cả các loại câu hỏi này, LimeSurvey sử dụng các câu hỏi phụ:

  • Nhiều văn bản ngắn
  • Nhiều lựa chọn
  • Nhiều lựa chọn có nhận xét
  • Array
  • Array (lựa chọn 5 điểm)
  • Array (lựa chọn 10 điểm)
  • Array (Có /Không/Không chắc chắn)
  • Mảng (Tăng/Tương tự/Giảm)
  • Mảng theo cột

Giả sử mã câu hỏi của câu hỏi là q2 và các câu hỏi phụ được đánh số SQ001, SQ002, (đánh số tự động do LimeSurvey thực hiện), chúng ta có thể tham khảo nội dung câu hỏi và câu trả lời bằng cách sử dụng:

- {q2_SQ001.question}: {q2_SQ001.shown}

- {q2_SQ002.question}: {q2_SQ002.shown}

Đối với các câu hỏi trắc nghiệm, bây giờ nên hiển thị văn bản của câu hỏi phụ được đánh dấu nhưng hiển thị chữ Y cho mỗi tùy chọn đã chọn:

- {q2_SQ001.question}: {q2_SQ001}

- {q2_SQ002.question}: {q2_SQ002}

...

Lưu ý rằng hiện tại không thể xuất nội dung câu hỏi của các câu hỏi bằng câu hỏi phụ, hãy xem yêu cầu tính năng này.


Ví dụ 1 (giả sử loại câu hỏi là trắc nghiệm)

- Bạn có biết những hãng xe này không?

-- Mercedes: Đúng

-- Audi: N

-- Volvo: Y


Nếu bạn chỉ muốn xuất các mục đã chọn, bạn có thể đặt câu lệnh IF xung quanh đầu ra của mình và kiểm tra giá trị hộp kiểm:

{ if( q2_SQ001=="Y", join( "- ", q2_SQ001.question, ": ", q2_SQ001.shown ), "" ) }


Sử dụng hàm listifop nếu bạn muốn xuất danh sách chỉ các mục đã chọn, ví dụ: Mercedes, Volvo

{ listifop( 'value', '==', 'Y', 'câu hỏi', ', ', that.q2.sgqa ) }


Trong đó that.q2 mở rộng sang tất cả các câu hỏi phụ của q2. Xem self, cái này và cái kia để biết thêm chi tiết.


Ví dụ 2 (giả sử loại câu hỏi là Mảng (chọn 10 điểm))

- Vui lòng đánh giá chất lượng các hãng xe dưới đây theo thang điểm từ 1=rất tệ đến 10=rất tốt?

-- Mercedes: 7

-- Audi: 9

-- Volvo: 9


Nếu bạn chỉ muốn xuất ra các mục được xếp hạng, bạn có thể đặt câu lệnh IF xung quanh đầu ra của mình và kiểm tra xem câu hỏi phụ hiện tại đã được trả lời hay chưa bằng cách sử dụng:

{ if( ! is_empty( q3_SQ001 ), join( "- ", q3_SQ001.question, ": ", q3_SQ001.shown ), "" ) }


Sử dụng hàm listifop nếu chẳng hạn bạn chỉ muốn xuất danh sách các mục đã chọn lớn hơn 8, ví dụ: Audi / Volvo

{ listifop( 'value', '>', 8, 'câu hỏi', ' / ', that.q3.sgqa ) }


Câu hỏi có hai thang đo

Template:Lưu ý


Giả sử rằng các mã sau đang được sử dụng:

  • Mã câu hỏi: q4
  • Mã câu hỏi phụ: SQ001, SQ002, ...
  • Mã câu trả lời tỷ lệ 1: A1, A2, ...
  • Đáp án thang điểm 2: B1, B2, ...


Template:Lưu ý


Hãy xuất kết quả cho cả hai thang đo và hai câu hỏi phụ đầu tiên:

- {q4_SQ001_0.question}: {q4_SQ001_0.shown} / {q4_SQ001_1.shown}

- {q4_SQ002_0.question}: {q4_SQ002_0.shown} / {q4_SQ002_1.shown}

Để xuất văn bản câu hỏi phụ, bạn cần thêm ID thang đo vào phần giữ chỗ (mặc dù văn bản giống nhau cho cả hai thang đo). Vì vậy, thay vì {q4_SQ001.question} chúng ta phải sử dụng {q4_SQ001_0.question} hoặc {q4_SQ001_1.question}.

Nếu bạn muốn xuất/hiển thị kết quả của các câu hỏi phụ chỉ có ít nhất một câu trả lời, hãy sử dụng cú pháp này cho mỗi câu hỏi phụ:

{if(count(q4_SQ001_0,q4_SQ001_1)>0,join("- ",q4_SQ001_0.question,": ",q4_SQ001_0.shown," / ",q4_SQ001_1.shown),"")}

Câu hỏi có thang đo X và Y

Điều này áp dụng cho tất cả các câu hỏi ma trận cho phép trả lời cho mọi ô (không chỉ mỗi hàng như được hiển thị trước đó):

  • Array Texts
  • Array Numbers


Mã giả định được sử dụng:

  • Mã câu hỏi: q5
  • Mã câu hỏi phụ: SQ001, SQ002, ...
  • Mã trả lời: A1, A2, ...

Để tham khảo kết quả của một câu hỏi con nhất định từ một cột nhất định, bạn cần sử dụng Câu hỏi. '_' . Mã câu hỏi phụ . '_' . Mã trả lời. Ví dụ tham khảo câu trả lời của câu hỏi phụ thứ ba và cột thứ hai: q5_SQ003_A2.

Hãy xuất kết quả cho cột 1-3 của hai câu hỏi phụ đầu tiên:

- {q5_SQ001_A1.question}: {q5_SQ001_A1.shown} | {q5_SQ001_A2.shown} | {q5_SQ001_A3.shown}

- {q5_SQ002_A1.question}: {q5_SQ002_A1.shown} | {q5_SQ002_A2.shown} | {q5_SQ002_A3.shown}


Vì đối với những loại câu hỏi này, mỗi ô (kết hợp trục X và trục Y) tương đương với một tùy chọn trả lời, nên cần phải thực hiện kiểm tra dữ liệu hiện có cho từng ô. Ví dụ:

{if(!is_empty(q5_SQ001_A1),join("- ",q5_SQ001_A1.question,": ",q5_SQ001_A1.shown),"")}


Template:Lưu ý

Ẩn câu hỏi nếu câu trả lời ở câu hỏi trước trống

Purpose Hide question if answer from previous question is empty
Type Question Relevance
Example Question one: question code "name", question text "What's your name?"
Question two: question text "{name}, how old are you?"
To do: Hide question two if the textfield of question one is empty
Expression !is_empty(name)
Description is_empty() determines whether a variable is considered to be empty. The "!" negates the result. So if the variable is not empty the Expression will be true and the question is shown
Steps Create/edit question two
Insert "!is_empty(name)" into "Relevance equation:"
Sample File Hide_question_if_empty_question_group.zip


Hide question group if answer from previous question is Yes or No

Purpose Hide question group if answer from previous question is Yes or No
Type Question group Relevance
Example Page one, Question Group one, Question one: question code "PET", question text "Do you have a pet?" -Yes -No
Page two, Question Group two: Title "About your pet(s)"
To do: Show/Hide question group two if answer from question one is Yes/No
Expression PET == "Y"
Description PET is the question code for the question you want to check the answer. If you don't use a suffix EM will use "Qcode.code". So you compare the answer code from the PET question to the value "Y". If the participant answers "Yes" the Expression is true and the question group "About your pet(s)" will be shown.
Steps Create/edit question group two
Insert "PET == "Y"" into "Relevance equation:"
Sample File Hide_question group_if_answer_from_previous_question_is_Yes_or_No.zip


Display value of a multiple answer input question field

Purpose Display value of a multiple answer input question field
Type Reference
Example Question one: question code "AskChildAge", question text "How old are your children?". Subquestions codes -Child1 -Child2 -Child3 - ChildXXX
Question two: question code "ReportChildAge" question text "About your first child: - CHILD1 is AGE1."
Expression {AskChildAge_Child1.question}, {AskChildAge_Child1.value}
Description You want to use the value of a subquestion in a following question. You can access the subquestion value with this kind of expression: QcodeQuestion_QcodeSubquestion.value
Steps Create/edit the second question
Insert this text in the description: "About your first child: - {AskChildAge_Child1.question} is {AskChildAge_Child1.value}."
Sample File Display_value_of_a_multiple_answer_input_question_field.zip

Validate number of boxes ticked per row for an "Array (Numbers) Checkbox" question

Purpose Validate number of boxes ticked per row
Type Validation
Example Question of type "Array Numbers (Checkbox Layout)"
Expression sum(...)
Description (sum(Test_A_1, Test_A_2, Test_A_3, Test_A_4, Test_A_5) <= X) determines whether at least X checkboxes in row A are checked.
If you want to check all three rows (A, B, C), you can connect the expression using "&&":
(sum(Test_A_1, Test_A_2, Test_A_3, Test_A_4, Test_A_5) <= X)
&& (sum(Test_B_1, Test_B_2, Test_B_3, Test_B_4, Test_B_5) <= X)
&& (sum(Test_C_1, Test_C_2, Test_C_3, Test_C_4, Test_C_5) <= X)
Steps Create/edit question of type "Array Numbers (Checkbox Layout)".
Insert the above expression into "Question validation equation" at the advanced question settings (you might have to adjust variable namings!).
Sample File Validate number of boxes ticker per row for an Array (Numbers) Checkbox.lss

Calculate difference between two dates

Purpose Calculate difference between two dates
Type Relevance / Equation question type / Validation
Example Question one (date/time, code: DOB): What is your date of birth?
Question two (date/time, code: datetoday): What is the date today?
Question three (boilerplate): You are XXXX days old.
To do: Calculate and display the number of days between the date given in question 1 and the question 2.
Expression {(strtotime(datetoday)-strtotime(DOB))/60/60/24}
Description strtotime calculates the number of seconds between the 1st of January 1970 and the given date. The above expression calculates the number of seconds between the two given dates. The term "/60/60/24" just calculates the number of days from the number of seconds.
Instead of asking for the "datetoday", you can also use strtotime('now') or simply time(), which directly returns the number of seconds from January 1970 until now (i.e. the time the survey was taken). Thus you could quickly figure out the age of a person in years with the equation {(time() - strtotime(DOB)) / 60 / 60 / 24 / 365.25} In any of these cases, it is critical that the date is entered in a proper format, otherwise the strtotime() function will not work right.
Steps Create two date questions (for the date of birth and for today's date) and a boilerplate question.
In the question text of the boilerplate question insert: "On {datetoday} you were {(strtotime(today)-strtotime(dob))/60/60/24} days days old."

Please note: The function strtotime can work with MANY but not all date formats. If you run into problems set your survey's date format to mm/dd/yyyy or yyyy-mm-dd or dd.mm.yyyy"
Sample File Date_difference.zip

Using ExpressionScript for Assessments

Here comes another example on how to use the ExpressionScript with Array type questions and assessments:</ br>

Let's say you have 2 array questions and you want to save the results of the calculation data to your database. It is actually simple, you will need to create and test your arrays and submit a dummy response to see if it works and gives you the results in the completed page.


Implementation details:

  • add a question of type equation
  • add the following line assuming that Q1 is your array question code while Q2 is the second one:
    • {sum(Q1_SQ001.value,Q2_SQ001.value)}

Note that SQ001 is the default code for any subquestion. If you change the subquestion code, adjust the equation above accordingly.


Using em_validation_q in array

You can use the question validation equation to control an array with any condition.


Implementation details:

  • for the first array : array of single choice
    • Question code is ARRAY
    • Sub question code are SQ01,SQ02,SQ03 and SQ04
    • update the Whole question validation equation and put
      !is_empty(ARRAY_SQ01) and !is_empty(ARRAY_SQ03) 
  • for the second array : array of text
    • Question code is ARRAYTEXT
    • Sub question at Y axis code are SY01,SY02,SY03, and SY04
    • Update the Whole question validation equation and put
      count(self.sq_SY01 >= 1) and count(self.sq_SY03 >= 3)