[excel] vba: LIKE + expression réguliere ?

Résolu/Fermé
mortelrdv - 7 nov. 2008 à 07:56
 mortelrdv - 8 nov. 2008 à 08:14
Bonjour,

mon probleme est le suivant, je voudrais faire des test sur des chaines de caracteres genre :
1-5-7-8     ->ok
5-3-2-7     ->ok
4-12-6-8   ->ok
2-1-13-7   ->nok
....


je passe par la possibilité que propose LIKE
if chaine like "#-AAA-#-#" then ...
ou alors mieux
if chaine like "[1-8]-AAA-[1-2]-[1-8]" then ...

le probleme c'est que je sèche à l'emplacement AAA, cette emplacement peut contenir un nombre entre 1 et 16 (et non 01 à 16)

connaissez vous une expression réguliere qui résolve ce probleme ?
sinon je vais passer par :
if chaine like "[1-8]-[1-9]-[1-2]-[1-8]" OR chaine like "[1-8]-1[0-6]-[1-2]-[1-8]" then ...
mais comme j'ai plusieurs conditions comme ça, ça me fait un IF à ralonge (vu que je dois doubler mes condition à chaque fois)

Merci

3 réponses

lermite222 Messages postés 8702 Date d'inscription dimanche 8 avril 2007 Statut Contributeur Dernière intervention 22 janvier 2020 1 190
7 nov. 2008 à 08:18
Bonjour,
Donne un exemple concret du contenu de "chaine" et le résultat souhaiter.
A+
0
Ok

ColonneA | Colonne B
1-5-1-8  |  OK
4-12-6-8 | NOK
2-1-13-7 | NOK
ati      | NOK
te-4-2-1 | NOK
1-3-5    | NOK
a-b-c-d  | NOK
a-2-1-7  | NOK
4-16-2-6 | OK


des chiffres séparrer par 3 x '-'
sachant que : (chiffre entre 09)-(chiffre entre 0-19)-(chiffre entre 0-9)-(chiffre entre 0-9)

j'espere que c'est un peu mieux
0
lermite222 Messages postés 8702 Date d'inscription dimanche 8 avril 2007 Statut Contributeur Dernière intervention 22 janvier 2020 1 190
7 nov. 2008 à 15:22
Re,
Ce n'est pas possible avec une seule comparaison vu que la longeur de la chaine se modifie et que la matrice reste la même.
Mais si c'est bien comme tu explique dans ton dernier poste
sachant que : (chiffre entre 09)-(chiffre entre 0-19)-(chiffre entre 0-9)-(chiffre entre 0-9)

Une autre façon..
 a = Chaine Like "#-#-#-#" Or Chaine Like "#-##-#-#"

A+
0
Je pensais faire ça, mais je me disais que peut etre il existait une expression réguliere quil résolvait ce probleme d'un seul coup.

Ok merci
0