Structure d'enquête Valeur séparée par des tabulations
From LimeSurvey Manual
Importation et exportation de valeurs séparées par des tabulations de la structure d'enquête
Cette fonctionnalité est conçue pour faciliter l'utilisation d'un tableur tel que LibreOffice, Excel ou Google Docs pour créer et modifier des enquêtes. Cela élimine complètement la dépendance aux codes SGQA.
Cette fonctionnalité prend en charge l'importation à partir de fichiers TSV (Tab Separated Value) codés en ASCII ou UTF-8 qui ont une extension .txt.
Mise en route
Le moyen le plus simple consiste à prendre une enquête existante et à l'exporter au format Valeurs séparées par des tabulations. Utilisez le bouton d'exportation normal de l'enquête et, au lieu de sélectionner le format .lss, sélectionnez "Format de valeurs séparées par des tabulations (*.txt)". Il sera enregistré en tant que fichier de valeurs séparées par des tabulations au format approprié (fichier Unicode délimité par des tabulations), avec tous les en-têtes de colonnes corrects.
Tout logiciel de feuille de calcul prenant en charge les valeurs séparées par des tabulations convient (par exemple, OpenOffice ou LibreOffice). LimeSurvey ignore tout formatage dans la feuille de calcul, mais n'hésitez pas à en ajouter si cela vous aide.
Il y aura une ligne pour chaque groupe, question, sous-question et réponse. Il existe également des lignes pour les variables d'enquête globales et pour les variables d'enquête spécifiques à la langue. La langue principale sera répertoriée en premier, suivie de toutes les langues secondaires. Ainsi, s'il existe plusieurs langues, l'intégralité du contenu de la langue de base apparaîtra en premier (par exemple, tous les groupes, questions, sous-questions et réponses). Ceci sera suivi d'une copie traduite pour chaque langue secondaire (avec exactement le même numéro et le même ordre ou lignes pour l'ensemble traduit).
Les relations sont déduites de la proximité. Ainsi, les questions qui suivent un groupe font partie de ce groupe ; les sous-questions suivant une question font partie de cette question, et les réponses suivant une question font partie de cette question. Ainsi, vous n'avez pas besoin de connaître les identifiants (gid, qid, sqid) pour toute question. Ceux-ci seront calculés automatiquement lors de l'importation. En fait, ce format n'utilise pas du tout gid, qid ou sqid (ou codes SGQA).
Conseils
L’objectif de l’import/export de valeurs séparées par des tabulations est de vous permettre de concevoir rapidement votre enquête à l’aide d’une feuille de calcul. Nous nous attendons à ce que vous importiez fréquemment la feuille, vérifiiez sa validité à l'aide de la fonction « Afficher la logique d'enquête » et la testiez. Chaque fois que vous l'importerez, vous obtiendrez une nouvelle enquête. Ainsi, vous pourriez vous retrouver avec de nombreuses enquêtes partiellement développées, mais ce n’est pas un problème. Prenez simplement l’habitude de garder une trace du plus récent ou supprimez l’ancien après avoir importé les nouveaux. Puisque vous n'utilisez jamais de codes SGQA dans la valeur séparée par des tabulations, vous n'avez jamais à vous soucier des codes attribués par LimeSurvey pour l'enquête principale, le groupe, les questions et les réponses. Alors n’hésitez pas à importer et exporter aussi souvent que vous le souhaitez.
Here are some convenient things you can do with this approach to authoring instruments:
- Use same Answers for many questions. Just copy the 'A' rows and paste after each question that should have the same set.
- Use same subquestions for many questions. Just copy the 'SQ' rows and paste them after each question that needs it.
- "Looping" - use same group many times. After the group is the way you want it, copy it as many times as needed. Use Excel filtering to view just the 'G' rows (for groups), and use the Excel column drag feature to update the relevance equations for each group (e.g., for a census, the first relevance might be "numPeople > 1", the next should be "numPeople > 2". The drag feature will auto-update the number). Filter by 'Q' rows and ensure that each question has a unique value (e.g., say you name your variables g1_q1, g1_q2, g1_qN, use find/replace to convert g1 to g2 the second group; g3 for the third, etc.).
- Re-ordering questions/groups. Simply re-order the rows of the spreadsheet file.
- Testing survey modules. For long surveys, you may want to break up the testing into modules. Simply create new spreadsheet files for each module, deleting any rows that you don't need. This avoids the need to enter lots of data to test later sections of the survey.
- Testing mandatory questions. A common complaint is not the need to make many questions mandatory, but the need to turn off the mandatory feature for testing. Simply create the master spreadsheet with mandatory set to the final desired values. Then, to test it, just delete the "mandatory" column and save the test version of the spreadsheet. When you import that version, none of the questions will be mandatory. After you have finished your testing, import the master copy.
- Setting defaults. Rather than using the GUI, you can enter any desired defaults in the default column. This is especially helpful for cases where the GUI does not let you enter the desired value, like expressions to set the default for list items (like populating a list from a survey participant attribute).
- Translation. You can create copies of your spreadsheet - one per language. Include all the rows for the primary language, then copy and paste them below, and use drag to change the language field to the target language. These can be distributed to your translators, and re-integrated into a single spreadsheet file when they are done.
- Bulk setting of advanced question attributes. You may want all of your equations to start visible (so you can see their values as you collect data), but then hide them all before going to production. Simply filter the spreadsheet on class = 'Q' and question type = '*' (equation), and set always_hide to 1 for each of those questions. Similarly, say after you create the survey, you decide which questions should appear in public statistics. Rather than edit each question through the GUI, filter on class = 'Q', and set public_statistics = 1 for all of the questions that should be visible in statistics.
- Find and replace. Say you decide you need to change some phrasing across all of your questions, you can use Excel find and replace to make those changes. Similarly, say you decide to do a bulk-renaming of your variables, find and replace can come to the rescue. If you need regular-expression based find and replace, you can select the desired column, copy to a text editor, do your find and replace, and paste the column back into the spreadsheet.
- Gaining approvals. If you are doing research, you may have an Institutional Review board who insists upon seeing the text of the questions. This may be a convenient way to share it. Similarly for discussions with a client.
- Team consensus. If you are trying to get a group to agree upon the wording or appearance of a question or group, you can rapidly prototype / edit the spreadsheet, import it, and show the team (via question or group preview) exactly what the users will see. That way you can get approval from the team before they leave the room rather than having to document requirements, build them, and get approval at future meetings.
- Upgrading from other survey formats. If your survey is in XML, Word, or other format, you can create a translation process to map them to this format. Although you could also try mapping to the .lss format, the advantage of this format is that it doesn't require you to keep track of foreign key relationships between groups, questions, subquestions, answers, and defaults.
Limitations
- By design, this feature only works properly for surveys that use qcode (rather than SGQA) naming. This feature assumes that variable names (question identifiers) are unique throughout the survey. Subquestion names can be repeated, as long as they are unique within the scope of a particular question.
File Format
General
We use the same set of column headings for multiple purposes. The first 14 columns serve different purposes depending upon the type of entity (e.g., group, question, answer). The remaining columns are an alphabetical list of the database field names for the advanced question codes. Below is the syntax for each entity type
The first 14 columns are:
- id (New in 3.14.0 )
- related_id (New in 3.14.0 )
- class
- type/scale
- name
- relevance
- text
- help
- language
- validation
- mandatory
- other
- default
- same_default
Survey Global Parameters
There is one row per parameter in the surveys table.
- class => 'S'
- name => database field name
- text => value
Survey Language-Specific Parameters
There is one row per field per language in the surveys_languagesettings table. All entries for a given language are collected before doing the insert into that table.
- class => 'SL'
- name => database field name
- text => value
- language => language
Groups
One group row per survey language (e.g., there would be 3 group rows if survey has 3 languages).
- id => unique numeric identifier for the group, starting with number 1, use the same ID for additional languages belonging to current group
- class => 'G'
- name => group_name -- the unique identifier for the group
- relevance => grelevance -- the group-level relevance equation, without curly braces
- text => description -- the language-specific description of the group
- language => language -- the language for the group (e.g., 'en')
Questions
One question row per survey language (e.g., there would be 3 question rows if survey has 3 languages). Questions are assumed to belong to the group that precedes them.
- id => unique numeric identifier for the question, starting with number 1, use the same ID for additional languages belonging to current question
- class => 'Q'
- type/scale => type -- the (usually one letter) question type (e.g., 'M' is Multiple Choice)
- name => title -- the unique question name (the root of the qcode naming system)
- relevance => relevance -- the relevance equation for the question
- text => question -- the language-specific text of the question
- help => help -- the language-specific help text
- language => language -- the language for the group (e.g., 'en')
- validation => preg -- the optional regular expression validation criteria for the question
- mandatory => mandatory -- 'Y' if mandatory
- other => other -- 'Y' if the "Other" option should be available (only for some question types)
- default => default -- if set, this value is inserted into the defaultvalues table for this question
- same_default => same_default -- 'Y' for true, in which case any defaultvalue set for primary language applies to other languages
Subquestions
One subquestion row per survey language. Subquestions are assumed to belong to the question that precedes them.
- id => same unique numeric identifier which is used for the questions. Subquestions should use next available value, question and subquestion IDs should be different (e.g. use ID 1 for question and IDs 2, 3 and 4 for subquestions belonging to question 1, next question ID should be 5 and so on). Use the same subquestion ID for additional languages belonging to current subquestions.
- class => 'SQ'
- type/scale => scale_id -- 0 or 1, depending upon question type (e.g. array text will have two scales)
- name => title -- the "name" of the subquestion, e.g. the one used for exclude_all_others
- relevance => relevance -- (Future) to support subquestion-level relevance
- text => question -- the language-specific text of the subquestion
- help => help -- (Future) to support subquestion-level help
- language => language -- the language for the subquestion
- validation => preg -- (Future) to support subquestion-level regular expression validation (e.g. for address parts)
- mandatory => mandatory -- (Future) to support subquestion-level mandatory (e.g. make only a few subquestions mandatory)
- default => default -- if set, then this is the default value for the subquestion (inserted into defaultvalues table)
- same_default => same_default -- if set, then the default for the primary language is used for all other languages
Answers
One answer row per survey language (e.g., there would be 3 answer rows if survey has 3 languages). Answers are assumed to belong to the question that precedes them, and be in the desired sort order.
- id => use the same ID as the ID of the question it belongs to
- class => 'A'
- type/scale => scale_id -- 0 or 1 (e.g. for dual-scale)
- name => code -- the unique answer identifier
- relevance => assessment_value -- if using assessment option, this is the assessment value for the answer
- text => answer -- the language-specific text of the answer
- language => language -- the language for this answer (e.g. 'en')
Assessments
One assessment row per survey language (e.g., there would be 3 assessment rows if survey has 3 languages). Assessments are written at the end of file.
- id => unique numeric identifier for the assessment, starting with number 1, use the same ID for additional languages belonging to current assessment
- related_id => id of group to which current assessment belongs to
- class => 'AS'
- type/scale => assessment scope: T-Total, G-group
- name => name
- text => message
- min_num_value => Minimum
- max_num_value => Maximum
- language => language -- the language for this answer (e.g. 'en')
Quotas
One row per quota. Quotas are written at the end of file.
- id => unique numeric identifier for the quota, starting with number 1
- class => 'QTA'
- name => quota name
- mandatory => limit
- other => quota action
- default => active
- same_default => autoload URL
Quota language settings
One quota row per survey language. Quota language settings are assumed to belong to the quota that precedes them.
- id => unique numeric identifier for the quota language settings, starting with number 1. Each row for different survey languages should have different IDs
- related_id => quota id of quota to which this setting belongs to
- class => 'QTALS'
- relevance => message
- text => URL
- help => URL description
- language => language -- the language for this quota (e.g. 'en')
Quota members
One row per quota member, no language dependent. Quota member row should be placed immediately after question it relates to. Quota members are assumed to belong to the question that precedes them.
- id => unique numeric identifier for the quota members, starting with number 1
- related_id => quota id of quota to which this member belongs to
- class => 'QTAM'
- name => answer code
Conditions
One row per condition, no language dependent. Condition row should be placed immediately after question it relates to. Conditions are assumed to belong to the question that precedes them.
- id => unique numeric identifier for the condition, starting with number 1.
- related_id => question id of related question, if applicable
- class => 'C'
- type/scale => scenario
- name => answer field name
- relevance => comparison operator
- text => expected answer