Aller au contenu

Les tableaux dynamiques

On peut vouloir créer des tableaux dont on ne connait pas à l'avance le nombre de lignes (Tableau dynamique). Ces tableaux se présenteront :

  • sans en-tête de lignes en première colonne
  • avec un bouton Ajouter une ligne (sous le tableau)
  • et un bouton Supprimer une ligne (la dernière).

Pour ce faire, on créera une question de type Tableau avec pour axe principal une liste.

Choix de l'axe d'information principal :

Pour avoir un tableau dynamique, choisir Liste.
On a ensuite 2 choix pour le calcul du nombre de lignes : Min/Max ou Formule

Nombre de lignes déterminés par Min/Max

choix min-max

  • Indiquer le nombre de lignes minimum (aujourd'hui un nombre mais une évolution permettra à terme de saisir un champ VTL)
  • Indiquer le nombre de lignes maximum (aujourd'hui un nombre borné à 300 mais une évolution permettra à terme de saisir un champ VTL)).

Nombre de lignes déterminés par Formule

choix formule

  • Indiquer une formule VTL qui doit retourner un nombre, imaginons n.
  • Le tableau généré aura exactement n lignes
VTL non valide

Si le résultat du VTL n'est pas interprété avec le type 'Nombre', ex Formule = "Du texte", on a l'erreur suivante formule different d'un nombre

Exemple de tableau dynamique avec formule VTL
  • Si on a un questionnaire avec une question NB_PERSONNE de type Nombre input nb personnes
  • On peut alors créer ensuite un tableau dynamique avec pour formule de nombre de lignes $NB_PERSONNE$. Dans le cas où l'utilisateur réponds 5 à la question NB_PERSONNE, alors le tableau aura exactement 5 lignes
    tableau dynamique

Information(s) mesurée(s) :

renseigner une information de type Réponse simple ou Réponse à choix unique Si on souhaite qu'une de ces informations mesurées ne soit pas "collectée", voir l'item données non-collectées

Calculer des totaux de lignes ou de colonnes

Ces totaux peuvent être ensuite utilisées dans deslibellés, des filtres ou des contrôles

Contrôles

Dans l'onglet Contrôles, décrire classiquement le contrôle en VTL mais préciser son niveau : si le contrôle concerne les informations relatives à une ligne du tableau, préciser "Niveau : ligne"

Contrôles par ligne

Préremplir un tableau avec des données non collectées

Pogues permet de préremplir certaines colonnes des tableaux dynamiques, que ce soit par de la donnée externe ou par des variables calculées. Ces colonnes ne sont alors pas modifiables en collecte.

Spécifier des données non-collectées

✨ Filtrer des cases

Il est possible de filtrer des cases dans un tableau dynamique selon une formule VTL.

alt text

alt text

La même logique que pour filtrer une question est appliquée : on propose un éditeur VTL conditionnant l'affichage de la case avec les règles suivantes :

Validité de la Formule VTL Condition d'affichage Résultat
Pas de formule / la case est affichée, l'enquêté peut la renseigner
ERROR la case est affichée, l'enquêté peut la renseigner
TRUE la case est affichée, l'enquêté peut la renseigner
FALSE la case n'est pas affichée, l'enquêté ne peut pas la renseigner
Exemple

Imaginons le tableau suivant avec l'identifiant PRODUIT alt text

Variables générées du tableau.

  1. La première variable est non collectée. On y injecte une variable externe.
  2. PRODUIT2 est un booléen : case à cocher qui vaut true ou false.
  3. PRODUIT3 est le CA que l'on veut collecter.

Pour une liste de produits, on veut savoir quels sont les produits pour lesquels une entreprise à un CA de plus de 10 000€, et avoir la valeur précise de ce CA uniquement dans ce cas.
On veut donc éviter que l'enquêté puisse saisir une valeur dans la colonne Précision du CA si son CA est inférieur à 10 000€ pour un produit. Pour ce faire on va rajouter une Condition d'affichage sur cette colonne pour afficher ou non les case selon la formule VTL $PRODUIT2$. alt text

En VTL, $PRODUIT2$ est équivalent à $PRODUIT2$ = true

Si PRODUIT2 vaut true, l'enquêté a coché la case, alors on affiche le champ pour collecter la variable $PRODUIT3$ (colonne "Précision du CA")

Ce qui donne le tableau suivant

alt text

alt text

alt text