[Javascript] Vérifier parentheses via regex

[Résolu/Fermé]
Signaler
Messages postés
74
Date d'inscription
jeudi 10 décembre 2009
Statut
Membre
Dernière intervention
16 septembre 2010
-
Messages postés
74
Date d'inscription
jeudi 10 décembre 2009
Statut
Membre
Dernière intervention
16 septembre 2010
-
Bonjour,

j'ai une zone de text dans laquel l'utilisateur peut saisi quelque chose comme ça:
(1 and 2) or 3 ou bien (1 and (2 and 3) or 4)....

je veux une reg exp pour vérifier pour chaque parenthèse ouverte j'ai une parenthèse fermée.

8 réponses

Messages postés
40805
Date d'inscription
jeudi 28 août 2003
Statut
Modérateur
Dernière intervention
10 août 2020
4 878
Salut,

Et le langage est ???
Messages postés
74
Date d'inscription
jeudi 10 décembre 2009
Statut
Membre
Dernière intervention
16 septembre 2010
15
Salut,
merci de votre reponse,
JavaScript
Salut,

Je pense qu'il faudra utiliser des motifs recursifs.
Je ne connais pas l'implementation en JavaScript.

En revanche je pourrai te donner en Perl.
Messages postés
74
Date d'inscription
jeudi 10 décembre 2009
Statut
Membre
Dernière intervention
16 septembre 2010
15
Salut,
tu peux me donner en Perl et je vais voir comment je peux le traduit en javascript..
Re,

je veux une reg exp pour vérifier pour chaque parenthèse ouverte j'ai une parenthèse fermée.
En ce cas il suffit de compter les paranthèses ouvrantes/fermantes.

En fait ce n'est pas vraiment ça que tu veux, puisqu'il faut aussi le bon emplacement sinon il pourra saisir ça et ça passera

(1 and )2 or 3 ou bien (1( and 2 and 3) or 4)....

Quelque chose comme ça, mais il faut peaufiner je pense

#!/usr/bin/perl

$str="(1 and (2 and 3) or 4)";
$str=~/(\((?:(?>[^()]+)|(?1))*\))/;
($str eq $1)?print "$1 ok\n":print "ne corresponds pas\n";
# manque une paranthese
$str="(1 and (2 and 3 or 4)";
$str=~/(\((?:(?>[^()]+)|(?1))*\))/;
($s eq $1)?print "$1 ok\n":print "ne corresponds pas\n";
__END__
Re,

Correction

#!/usr/bin/perl

$str="(1 and (2 and 3) or 4)";
$str=~/(\((?:(?>[^()]+)|(?1))*\))/;
($str eq $1)?print "$1 ok\n":print "ne corresponds pas\n";
# manque une paranthese
$str="(1 and (2 and 3 or 4)";
$str=~/(\((?:(?>[^()]+)|(?1))*\))/;
($str eq $1)?print "$1 ok\n":print "ne corresponds pas\n";
__END__
Messages postés
74
Date d'inscription
jeudi 10 décembre 2009
Statut
Membre
Dernière intervention
16 septembre 2010
15
Salut,
merci de votre reponse,
tu peux me donner des explications sur ce que tu as fait stp ?
$str=~/(\((?:(?>[^()]+)|(?1))*\))/;

?: , ?> , ?1 ..................
Pour être en mesure de convertir ce regexp à javaScript
Messages postés
74
Date d'inscription
jeudi 10 décembre 2009
Statut
Membre
Dernière intervention
16 septembre 2010
15
Re,
merci de votre reponse,
il me semble ça va pas marcher avec les regexp javascript...
car je pense que les lookbehind : (?<=X) positive lookbehind et (?<!X) negative lookbehind .
n'existe pas en javascript..
par contre je peux faire ça :
var incr = 0; 
var parentheseOk = false; 
for(var i =0 ; i < maChaine.length; i++){ 
     if(maChaine[i] == '('){ 
         incr++; 
     } 
     if(maChaine[i] == ')'){ 
        incr--; 
        if (incr < 0) { 
            break;
        } 
     }
}
alert(incr);
parentheseOk = (incr == 0) ;
alert(parentheseOk);


merci et bon dev