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

Résolu/Fermé
Signaler
-
 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

3 réponses

Messages postés
8700
Date d'inscription
dimanche 8 avril 2007
Statut
Contributeur
Dernière intervention
22 janvier 2020
1 197
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
Messages postés
8700
Date d'inscription
dimanche 8 avril 2007
Statut
Contributeur
Dernière intervention
22 janvier 2020
1 197
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