Reconnaître des chaînes de caractères variables avec une même forme de base

Résolu/Fermé
Stamd - 30 juil. 2019 à 08:36
 Stamd - 31 juil. 2019 à 08:16
Bonjour,

Je cherche une formule (solution sans VBA si c'est faisable, sinon VBA qui s'exécute automatiquement) qui me permette de reconnaître une certaine suite de caractères et d'inscrire dans une cellule une donnée selon la structure reconnue. C'est-à-dire:

J'ai des titres de documents dans ma colonne B sous cette forme:

A-215-2019
B-025-2019
C-014-2019 (tous les titres ont la même structure:
B-026-2019 Une lettre pour le type de document, un numéro de doc et l'année)
D-002-2019
A-056-2019

Je voudrais que dans la colonne C, les cellules reconnaissent le pattern X-000-AAA et selon que c'est A/B/C/D affichent Urgent(A)/Important(B)/À faire(C)/À classer(D).

Mon problème c'est que je ne peux pas me contenter de faire reconnaître juste le segment "A-/B-/C-/D-", car j'ai aussi d'autres documents dans ma liste qui commencent ainsi, mais qui sont ensuite différents (par exemple "C-Inventory"). Il faudrait donc que la formule ne correspondent qu'aux documents avec la structure ci-dessus.

J'ai essayé avec des caractères génériques dans la formule SI, mais ça ne marche pas. J'ai aussi essayé de faire une liste de tous les documents A-001-2019, A-002-2019, A-003-2019... pour ensuite utiliser un SI avec des valeurs précises, mais ce n'est pas possible de remplir automatiquement la suite (Excel ne reconnaît pas de structure), et taper à la main 4x999 écritures, bof bof...

Voilà, j'espère que c'est assez clair et que vous pourrez m'aider.

Merci beaucoup



Configuration: Windows / Internet Explorer 11.0
A voir également:

4 réponses

Bonjour,

Tu peux créer une formule qui associe les conditions suivantes :
- nombre de caractères=10,
- numéro de code du premier caractère du texte supérieur ou égal à 65 (lettre A),
- numéro de code du premier caractère du texte inférieur ou égal à 68 (lettre D),
- valeur numérique du 3ème au 5ème caractère,
- valeur numérique du 7ème au 10ème caractère.

=ET(NBCAR(A1)=10;CODE(A1)>=65;CODE(A1)<=68;ESTNUM(STXT(A1;3;3)*1);ESTNUM(STXT(A1;7;4)*1))

Cordialement.
0
Merci beaucoup !
0
via55 Messages postés 14405 Date d'inscription mercredi 16 janvier 2013 Statut Membre Dernière intervention 25 avril 2024 2 703
30 juil. 2019 à 09:23
Bonjour

Un exemple, en espérant qu'il corresponde à ce que tu recherches
https://mon-partage.fr/f/bSRuAFmx/

Cdlmnt
Via
0
Merci pour la réponse et le fichier !
0
Vaucluse Messages postés 26496 Date d'inscription lundi 23 juillet 2007 Statut Contributeur Dernière intervention 1 avril 2022 6 396
30 juil. 2019 à 09:37
Bonjour
voyez cette proposition.
Elle détecte si le texte contient bien deux tirets et si les 3 caractères qui suivent le premier tiret donnent bien une valeur numérique
si oui, elle va chercher selon la 1° lettre dans le tableau de référence
Je ne peux pas dire si ces conditions vont suffire, mais il est peut être possible, sur ce principe, d'en rajouter d'autre dans l'item SI(ET(condition1;condition;2;condition3;ect);RECHERCHE....
https://mon-partage.fr/f/xDEiANVZ/


crdlmnt
0
Merci !
0
yclik Messages postés 3595 Date d'inscription vendredi 25 juillet 2014 Statut Membre Dernière intervention 26 avril 2024 1 481
Modifié le 30 juil. 2019 à 10:08
Bonjour
Tant qu'on y'est une autre proposition
si en A2 A-215-2019
test en B2
=SI(ESTERREUR(TROUVE("-";A2)+TROUVE("-";A2;TROUVE("-";A2)+1));"";TROUVE("-";A2)+TROUVE("-";A2;TROUVE("-";A2)+1))

affichage en C2
=SI(ET(B2=8;GAUCHE(A2;1)="A");"Urgent";SI(ET(B2=8;GAUCHE(A2;1)="B");"Important";SI(ET(B2=8;GAUCHE(A2;1)="C");"A faire";SI(GAUCHE(A2;1)="D";"Aclasser";"---"))))
0