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

Résolu
mortelrdv -  
 mortelrdv -
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
A voir également:

3 réponses

lermite222 Messages postés 8724 Date d'inscription   Statut Contributeur Dernière intervention   1 191
 
Bonjour,
Donne un exemple concret du contenu de "chaine" et le résultat souhaiter.
A+
0
mortelrdv
 
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 8724 Date d'inscription   Statut Contributeur Dernière intervention   1 191
 
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
mortelrdv
 
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