Re,
il me manquait juste un " non m".
Souvent on n'aboutit pas à nos recherches avec les regex puisque on raisonne mal la regex et pas parce que on ne connaît pas le métacaractères (qui ne sont pas nombreux).
Ta façon de raisonner la regex est un peu fausse, si je n'abuse pas.
non m pour toi correspond à [^m]
suivant ton raisonnement [m] correspond à m
En fait [m] c'est une classe de caractère qui fait correspondre au caractère m, tandis que [^m] c'est une classe de caractère complementée qui fait correspondre à n'importe quel caractère qui n'est pas m (ce qui n'est pas la même chose avec non m qui veut dire que ça peut être un m ou pas)
Le but d'une regex c'est de faire correspondre et pas de ne pas faire correspondre (pour ça on utilise les opérateurs d'un langage de programmation)
En bref [^m] veut dire faire correspondre à tout caractère qui n'est pas m et pas ne pas faire correspondre au caractère m.
Cette subtilité on peut l'expliquer avec un petit exemple
echo "Salut" | egrep 't[^m]
Normalement si on pense à ne pas faire correspondre au caractère m la regex doit réussir. Mais ce n'est pas le cas.
Pourquoi?
Puisque [^m] veut plutôt dire de faire correspondre à quelque chose et dans notre cas t c'est le dernière caractère.
Bonne continuation.
lami20j


