Actions

Utilisation des expressions régulières: Difference between revisions

From LimeSurvey Manual

No edit summary
No edit summary
Line 24: Line 24:
<div class="simplebox"><u>Attention</u>
<div class="simplebox"><u>Attention</u>


Pour le contenu de la zone de saisie ''Validation'' soit &eacute;valu&eacute;, il faut obligatoirement rendre la question obligatoire.
Pour le contenu de la zone de saisie ''Validation'' soit &eacute;valu&eacute;, il faut obligatoirement que l'utilisateur est saisi un caract&egrave;re.


</div>
</div>
Line 182: Line 182:
  <nowiki>/^[1-9]?[0-9]{1}$|^100$/</nowiki>
  <nowiki>/^[1-9]?[0-9]{1}$|^100$/</nowiki>


===Validation d'un nombre d&eacute;cimal===
===validation d'un nombre d&eacute;cimal===


Ce type de validation peut &ecirc;tre utilis&eacute; dans le cas de prix, mesure
Ce type de validation peut &ecirc;tre utilis&eacute; dans le cas de prix, mesure


====Validation d'un nombre d&eacute;cimal====
====validation d'un nombre d&eacute;cimal====


  <nowiki>/^([1][0-9][0-9]|[1-9][0-9]|[0-9])[[\.)[0-9][0-9])?$/</nowiki>
  <nowiki>/^([1][0-9][0-9]|[1-9][0-9]|[0-9])[[\.)[0-9][0-9])?$/</nowiki>
Line 193: Line 193:


   <nowiki>/^[1-9][0-9]{0,2}(?:,?[0-9]{3}){0,3}\.[0-9]{2}$/
   <nowiki>/^[1-9][0-9]{0,2}(?:,?[0-9]{3}){0,3}\.[0-9]{2}$/
forces two decimal points
accepts numbers from 1.00 to 999,999,999.00 with an optional comma delimiting thousands/millions
including all of the following: 1.00, 1,000.00 , 12,345.67 , 12345,02 , 123,456,468.00 , 1234566.00 , 123456789.00
but not 1,23.00 , 12,3.4 or 1234,43.04</nowiki>  <nowiki>/^[1-9][0-9]{0,2}(?:,?[0-9]{3}){0,3}(?:\.[0-9]{2})?$/ same as above but the two decimal points are optional</nowiki>


  ==Monnaie==
  ==Monnaie==
Line 222: Line 214:
==Validation d'une date==
==Validation d'une date==


====Validation d'une date au format jj/mm/aaaa====
====validation d'une date au format jj/mm/aaaa====


  <nowiki>/^\d{1,2}\/\d{1,2}\/\d{4}$/</nowiki>
  <nowiki>/^\d{1,2}\/\d{1,2}\/\d{4}$/</nowiki>


====Validation d'une date au format jj/mm/aaaa du 20 ou 21&eacute;me si&egrave;cle====
====validation d'une date au format jj/mm/aaaa du 20 ou 21&eacute;me si&egrave;cle====


  <nowiki>/^\d{1,2}\/\d{1,2}\/(19|20)\d{2}$/</nowiki> a tester
  <nowiki>/^\d{1,2}\/\d{1,2}\/(19|20)\d{2}$/</nowiki> a tester


====Validation d'un mois (1-12)====
====validation d'un mois (1-12)====


  <nowiki>/^[0]?[1-9]$|^1[0-2]$/</nowiki>
  <nowiki>/^[0]?[1-9]$|^1[0-2]$/</nowiki>
Line 238: Line 230:
==Validation d'une heure==
==Validation d'une heure==


  <nowiki>/^(?:[01][0-9]|2[0-3]):[0-5][0-9]$/
  <nowiki>/^(?:[01][0-9]|2[0-3]):[0-5][0-9]$/</nowiki>
 
cette expression permet de valider un format d'heure HH:MM ex : 11:32
 
<nowiki>/^(?:[01][0-9]|2[0-3]):[0-5][0-9](?::[0-5][0-9])?$/</nowiki>


/^(?:[01][0-9]|2[0-3]):[0-5][0-9](?::[0-5][0-9])?$/
Cette expression permet de valider un format d'heure HH:MM:SS o&ugrave; la partie de secondes est optionnelle ex : 11:32:53 ou bien 11:32


/^(?:[01][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9]$/</nowiki>
<nowiki>/^(?:[01][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9]$/</nowiki>


The following three match 12 hour time, as above with seconds, optional seconds and with seconds required
Cette expression permet de valider un format d'heure HH:MM:SS o&ugrave; la partie des secondes est obligatoire ex : 11:32:53


==Validation d'une longueur de saisie==
==Validation d'une longueur de saisie==
Line 250: Line 246:
Pour certain type de question, LimeSurvey propose dans les param&egrave;tres avanc&eacute;s ce type de contr&ocirc;le.
Pour certain type de question, LimeSurvey propose dans les param&egrave;tres avanc&eacute;s ce type de contr&ocirc;le.


====Validation d'une longueur de saisie minimum====
====validation d'une longueur de saisie minimum====


  <nowiki>/^.{3,}$/</nowiki>
  <nowiki>/^.{3,}$/</nowiki>
Line 256: Line 252:
ici la longueur minimum est de 3 caract&egrave;res quelconques
ici la longueur minimum est de 3 caract&egrave;res quelconques


====Validation d'une longueur de saisie maximum====
====validation d'une longueur de saisie maximum====


  <nowiki>/^.{3,}$/</nowiki>
  <nowiki>/^.{3,}$/</nowiki>
Line 272: Line 268:
  <nowiki>/(?:[</div>,.;:?!& \n\r]+(?: [<div class="simplebox">,.;:?!& \n\r]+)*)(?:[,.;:?!& \n\r]?(?:\n|\r|\n\r|\r\n)(?:[</div>,.;:?!& \n\r]+(?: [<div class="simplebox">,.;:?!& \n\r]+)*)){2,10}/is</nowiki>
  <nowiki>/(?:[</div>,.;:?!& \n\r]+(?: [<div class="simplebox">,.;:?!& \n\r]+)*)(?:[,.;:?!& \n\r]?(?:\n|\r|\n\r|\r\n)(?:[</div>,.;:?!& \n\r]+(?: [<div class="simplebox">,.;:?!& \n\r]+)*)){2,10}/is</nowiki>


Si vous voulez v&eacute;rifier qu'il y a au moins 5 mots par ligne, vous devez changer le premi&egrave;r et le derni&egrave;r caract&egrave;re &eacute;toile (*) par {4,}
Si vous voulez v&eacute;rifier qu'il y a au moins 5 mots par ligne, vous devez changer le premier et le dernier caract&egrave;re &eacute;toile (*) par {4,}


  <nowiki>/(?:[</div>,.;:?!& \n\r]+(?: [<div class="simplebox">,.;:?!& \n\r]+){4,})(?:[,.;:?!& \n\r]?(?:\n|\r|\n\r|\r\n)(?:[</div>,.;:?!& \n\r]+(?: [<div class="simplebox">,.;:?!& \n\r]+){4,})){2,10}/is</nowiki>
  <nowiki>/(?:[</div>,.;:?!& \n\r]+(?: [<div class="simplebox">,.;:?!& \n\r]+){4,})(?:[,.;:?!& \n\r]?(?:\n|\r|\n\r|\r\n)(?:[</div>,.;:?!& \n\r]+(?: [<div class="simplebox">,.;:?!& \n\r]+){4,})){2,10}/is</nowiki>


Si voulez 1 ou plusieurs mots par ligne et de 1 &agrave; 5 lignes, vous pouvez changer
Si voulez 1 ou plusieurs mots par ligne et de 1 &agrave; 5 lignes, vous pouvez changer les valeurs du quantificateur {0,4}.


If you wanted one or more words per line on between 1 and 5 lines, you can change the content of the last curley braces to {0,4} (note you use 0 because you're already matching the first line. <nowiki>/(?:[</div>,.;:?!& \n\r]+(?: [<div class="simplebox">,.;:?!& \n\r]+)*)(?:[,.;:?!& \n\r]?(?:\n|\r|\n\r|\r\n)(?:[</div>,.;:?!& \n\r]+(?: [<div class="simplebox">,.;:?!& \n\r]+)*)){0,4}/is</nowiki>
<nowiki>/(?:[</div>,.;:?!& \n\r]+(?: [<div class="simplebox">,.;:?!& \n\r]+)*)(?:[,.;:?!& \n\r]?(?:\n|\r|\n\r|\r\n)(?:[</div>,.;:?!& \n\r]+(?: [<div class="simplebox">,.;:?!& \n\r]+)*)){0,4}/is</nowiki>


===Limiter le nombre de mots===
===Limiter le nombre de mots===
Line 287: Line 283:


Vous pouvez varier le minimum et le maximum selon vos besoins en changeant {0,199} ( voir ci-dessus le tableau ''Quantificateur'')
Vous pouvez varier le minimum et le maximum selon vos besoins en changeant {0,199} ( voir ci-dessus le tableau ''Quantificateur'')
<nowiki>To increase the minimum change the zero part of {0,199}
To increase or decrease the maximum change the "199" part of {0,199}</nowiki>


==Validation d'un mot==
==Validation d'un mot==
Line 300: Line 292:
Le mot saisie doit correspondre exactement (minuscule) au mot dans la liste.
Le mot saisie doit correspondre exactement (minuscule) au mot dans la liste.


====Validation du mot dans une liste====
====validation du mot dans une liste====


  <nowiki>/^(arbre|feuille|fleur){1}$/i</nowiki>
  <nowiki>/^(arbre|feuille|fleur){1}$/i</nowiki>


Ici, on ne tient pas compte des minuscules et des majuscules : Les mots suivants Arbre,arbre, ARBRE, ArBrE, etc. sont tous valides.
Ici, on ne tient pas compte des minuscules et des majuscules : Les mots suivants Arbre,arbre, ARBRE, ArBrE, etc. sont tous valides.

Revision as of 22:54, 2 June 2011

La traduction de cette page n'est pas terminée.

#Validation

Lorsque vous définissez les attributs d'une question, vous devez indiquer son code, le texte de la question, le type de question,

le nombre minimum et/ou maximum de caractères, etc.

Cependant, il n'est pas possible définir tous les attributs de contrôle pouvant satisfaire les besoins des utilisateurs de LimeSurvey.

La zone de saisie Validation de l'écran d'édition d'une question joue ce rôle et permet d'ajouter des contrôles supplémentaires sur la réponse.

Ces contrôles se font grâce à des expressions régulières que l'on place dans la zone de saisie Validation.

Dans la situation présentée ci-dessus, la réponse sera considérée comme valide si d'une part elle est composée uniquement de lettres

en majuscule et d'autre part si le nombre de lettres est compris entre 1 et 10.

Attention

Pour le contenu de la zone de saisie Validation soit évalué, il faut obligatoirement que l'utilisateur est saisi un caractère.

#Bref rappel

Avertissements

L'objet de cette section n'est pas d'expliquer comment constituer des expressions régulières

ou bien d'expliquer leurs fonctionnements.

De très bons livres le font comme Maîtrise des expressions régulières de Jeffrey E. F. Friedl.

Il y a également des sites qui traitent de ces sujets comme  http://www.regxlib.net/ (en anglais)

ou bien http://perl.enstimac.fr/DocFr/perlrequick.html (en français).

L'expression régulière est un moyen puissant,flexible et efficace d'appliquer un traitement sur du texte.

Grâce à une notation générale (motif, pattern), c'est une sorte de mini-langage de programmation qui permet de décrire

et d'analyser le texte. Plusieurs notations existent.

Celle utilisée dans LimeSurvey est du type PERL et doivent commencer et se terminer par le caractère slash ("/").

  Métacaractère   Signification
  .   n'importe quel caractère sauf \n
  [  ] tous les caractères énumérés     [abc]
  [~94~  ] tous les caractères sauf ceux qui sont énumérés     [~94~abc]
  ~124~ tous les caractères sauf ceux qui sont énumérés     mot1~124~mot2~124~mot3
  - intervalle     a-z
  Quantificateur   Signification   Exemple
  *   zéro ou plus   A* = zéro ou plus de lettre A
  + 1 ou plus       A+ = une lettre A ou plus
  ? 0 ou 1           A? = pas de lettre A ou une seule lettre A
{n} n fois exactement A{3} = trois lettres A
{min,} minimum min fois et plus A{3,} trois lettres A ou plus
{min,max} minimum min et maximum max  fois A{3,7} trois lettres A au minimum et au maximum 7 lettres A
  Caractères   Signification Équivalence
\n nouvelle ligne
\r retour à la ligne
\t tabulation
\v tabulation vertical
\f nouvelle page
  \s   caractères d'espacement [\n\r\t\f]
  \S tous les caractères sauf les caractères d'espacement [~94~\n\r\t\f]
  \d les chiffres [0-9]
\D tous les caractères sauf les chiffres [~94~0-9]
\w caractère constituant un mot [0-9a-zA-Z_]
\W tous les caractères ne constituant pas un mot [~94~\w]
\xhh caractère en hexadécimal(hh) ex: \x41 = A
  Modificateur   Signification
i ignore la casse
x le point reconnait aussi \n
m mode multi lignes

Les modificateurs se mettent après le dernier slash ex : /[a-z]/i est équivalent à /[a-zA-Z]/

Vous pouvez tester vos expressions régulières sur http://www.spaweditor.com/scripts/regex/index.php

#Quelques exemples

Vous pouvez ajouter des expressions régulières mais testées auparavant!

Exemples (notez qu'elles sont toutes sur une seule ligne):

Validation d'un code postal français

/^0[1-9]|[1-8][0-9]|9[0-8]|2A|2B[0-9]{3}$/

Cette expression teste seulement de le format du code postal mais pas de sa validité.

Validation du numéro de département français

/^0[1-9]|[1-8][0-9]|9[0-8]|2A|2B$/

Cette expression teste seulement de le format du numéro du département mais pas de sa validité.

Validation d'un nombre

Validation d'un nombre entier

nombre entier compris dans un intervalle défini (age, etc.) de 20 à 99

/([2-9][0-9])/

nombre entier compris dans un intervalle défini (age, etc.) de 18 à 35

/(1[8-9]|2[0-9]|3[0-5])/

nombre entier compris dans un intervalle défini (age, etc.) de 19 à 65

<div class="simplebox">(1[8-9]|[2-5][0-9]|6[0-5])$

nombre entier compris dans un intervalle de 1 à 99999

/^([1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9])$/  /^[1-9][0-9]{0,4}$/

C'est deux expressions produisent le même résultat.

nombre entier compris dans plusieurs intervalles de 1 à 999, de 1.000 à 999.999

/^[1-9][0-9]{0,2}(?:\.[0-9]{3}){0,1}$/

validation d'un score compris entre 1 et 10

/^[1-9]{1}$|^10$/

validation d'un score compris entre 1 et 100

/^[1-9]?[0-9]{1}$|^100$/

validation d'un nombre décimal

Ce type de validation peut être utilisé dans le cas de prix, mesure

validation d'un nombre décimal

/^([1][0-9][0-9]|[1-9][0-9]|[0-9])[[\.)[0-9][0-9])?$/
les nombres entre ayant une partie décimale optionnelle à deux chiffres
 /^[1-9][0-9]{0,2}(?:,?[0-9]{3}){0,3}\.[0-9]{2}$/

 ==Monnaie==

 ====Euro (le signe Euro et les centimes sont optionnels)====

  <nowiki>/^\d+(\.(\d{3}]]?€?$/

Dollar US

/^\$?\d+(\.(\d{2}))?$/

Le signe dollar en début de saisie et les cents sont optionnels.

Prix en Franc Suisse

C'est un nombre avec deux décimales  après la virgule dont le dernier chiffre est soit 5, soit 0.

/^(\d+)(\.\d(05)?)?$/

Validation d'une date

validation d'une date au format jj/mm/aaaa

/^\d{1,2}\/\d{1,2}\/\d{4}$/

validation d'une date au format jj/mm/aaaa du 20 ou 21éme siècle

/^\d{1,2}\/\d{1,2}\/(19|20)\d{2}$/ a tester

validation d'un mois (1-12)

/^[0]?[1-9]$|^1[0-2]$/

Cette expression permet de saisir le mois de janvier soit 1, soit 01.

Validation d'une heure

/^(?:[01][0-9]|2[0-3]):[0-5][0-9]$/

cette expression permet de valider un format d'heure HH:MM ex : 11:32

/^(?:[01][0-9]|2[0-3]):[0-5][0-9](?::[0-5][0-9])?$/

Cette expression permet de valider un format d'heure HH:MM:SS où la partie de secondes est optionnelle ex : 11:32:53 ou bien 11:32

/^(?:[01][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9]$/

Cette expression permet de valider un format d'heure HH:MM:SS où la partie des secondes est obligatoire ex : 11:32:53

Validation d'une longueur de saisie

Pour certain type de question, LimeSurvey propose dans les paramètres avancés ce type de contrôle.

validation d'une longueur de saisie minimum

/^.{3,}$/

ici la longueur minimum est de 3 caractères quelconques

validation d'une longueur de saisie maximum

/^.{3,}$/

ici la longueur maximum est de 3 caractères quelconques

Validation de texte

Actuellement, le type de question Multiples zones de texte court ne permet pas de contrôler le minimum ou le maximum de réponses.

Une des manières d'y parvenir est d'utiliser le type question Zone de texte long sur laquelle on appliquera une expression régulière.

L'expression ci-dessous vérifie qu'il y a au moins un mot par ligne et qu'il y a au moins trois lignes mais pas plus de 10 lignes :

/(?:[</div>,.;:?!& \n\r]+(?: [<div class="simplebox">,.;:?!& \n\r]+)*)(?:[,.;:?!& \n\r]?(?:\n|\r|\n\r|\r\n)(?:[</div>,.;:?!& \n\r]+(?: [<div class="simplebox">,.;:?!& \n\r]+)*)){2,10}/is

Si vous voulez vérifier qu'il y a au moins 5 mots par ligne, vous devez changer le premier et le dernier caractère étoile (*) par {4,}

/(?:[</div>,.;:?!& \n\r]+(?: [<div class="simplebox">,.;:?!& \n\r]+){4,})(?:[,.;:?!& \n\r]?(?:\n|\r|\n\r|\r\n)(?:[</div>,.;:?!& \n\r]+(?: [<div class="simplebox">,.;:?!& \n\r]+){4,})){2,10}/is

Si voulez 1 ou plusieurs mots par ligne et de 1 à 5 lignes, vous pouvez changer les valeurs du quantificateur {0,4}.

/(?:[</div>,.;:?!& \n\r]+(?: [<div class="simplebox">,.;:?!& \n\r]+)*)(?:[,.;:?!& \n\r]?(?:\n|\r|\n\r|\r\n)(?:[</div>,.;:?!& \n\r]+(?: [<div class="simplebox">,.;:?!& \n\r]+)*)){0,4}/is

Limiter le nombre de mots

L'expression ci-dessous permet d'écrire au minimum 1 mot et au maximum 200 mots.

/^[-\w]+(?:\W+[-\w]+){0,199}\W*$/

Vous pouvez varier le minimum et le maximum selon vos besoins en changeant {0,199} ( voir ci-dessus le tableau Quantificateur)

Validation d'un mot

mot dans une liste

/^(arbre|feuille|fleur){1}$/

Le mot saisie doit correspondre exactement (minuscule) au mot dans la liste.

validation du mot dans une liste

/^(arbre|feuille|fleur){1}$/i

Ici, on ne tient pas compte des minuscules et des majuscules : Les mots suivants Arbre,arbre, ARBRE, ArBrE, etc. sont tous valides.