Excel : Comment extraire des nombres d’une chaîne
Vous pouvez utiliser la formule suivante pour extraire des nombres d’une chaîne dans Excel :
=TEXTJOIN("",TRUE,IFERROR((MID(A2,ROW(INDIRECT("1:"&LEN(A2))),1)*1),""))
Cette formule particulière extraira tous les nombres de la chaîne dans la cellule A2 .
Par exemple, si la cellule A2 contient l’expression « 25 vélos », cette formule renverra simplement 25.
L’exemple suivant montre comment utiliser cette formule dans la pratique.
Exemple : extraire des nombres d’une chaîne dans Excel
Supposons que nous ayons la liste de chaînes suivante dans Excel :
Supposons que nous souhaitions extraire uniquement les nombres de chaque chaîne.
Pour ce faire, nous pouvons taper la formule suivante dans la cellule B2 :
=TEXTJOIN("",TRUE,IFERROR((MID(A2,ROW(INDIRECT("1:"&LEN(A2))),1)*1),""))
Nous pouvons ensuite cliquer et faire glisser la formule vers chaque cellule restante de la colonne B :
La colonne B contient désormais uniquement les nombres de chacune des chaînes correspondantes dans la colonne A.
Comment fonctionne cette formule
Rappelez-vous la formule que nous avons utilisée pour extraire les nombres des chaînes :
=TEXTJOIN("",TRUE,IFERROR((MID(A2,ROW(INDIRECT("1:"&LEN(A2))),1)*1),""))
Voici comment fonctionne cette formule :
Tout d’abord, ROW(INDIRECT(“1:”&LEN( A2 ))) renvoie une série de nombres allant de 1 à la longueur de la chaîne.
Ensuite, (MID( A2 ,ROW(INDIRECT(“1:”&LEN( A2 ))),1)*1) convertit tous les caractères du texte en #VALUE ! les erreurs.
Ensuite, IFERROR((MID( A2 ,ROW(INDIRECT(“1:”&LEN( A2 ))),1)*1),””) supprime tous les $VALUE ! les erreurs.
Enfin, TEXTJOIN(“”,TRUE,IFERROR((MID( A2 ,ROW(INDIRECT(“1:”&LEN( A2 ))),1)*1),””)) rassemble tous les nombres restants et ignore des blancs.
Le résultat final est que nous pouvons extraire uniquement les nombres de chaque chaîne.
Ressources additionnelles
Les didacticiels suivants expliquent comment effectuer d’autres tâches courantes dans Excel :
Excel : Comment extraire du texte entre deux caractères
Excel : Comment extraire du texte après un caractère
Excel : Comment extraire du texte avant un caractère