[Simple] Extraire un nombre d'un texte...
Résolu
zarbi3
-
zarbi3 -
zarbi3 -
Bonjour,
J'ai utiliser une fonction pour "télécharger" des données depuis internet, et j'aimerais pouvoir extraire un nombre d'une cellule ( pour copier le nombre dans une autre case )
Exemple:
J'ai "télécharger" une phrase: "Nombre de messages postés sur les forums : 3.821"
et j'aimerais pouvoir prendre le nombre, et le copier dans une autre cellule automatiquement, et dès que la cellule de base ( ou se trouve la phrase ) se modifie, que le nombre "extrais" se modifie aussi :)...
Je suis assez nouveau sous excel, donc je sais pas trop comment m'y prendre :D
Merci :)
J'ai utiliser une fonction pour "télécharger" des données depuis internet, et j'aimerais pouvoir extraire un nombre d'une cellule ( pour copier le nombre dans une autre case )
Exemple:
J'ai "télécharger" une phrase: "Nombre de messages postés sur les forums : 3.821"
et j'aimerais pouvoir prendre le nombre, et le copier dans une autre cellule automatiquement, et dès que la cellule de base ( ou se trouve la phrase ) se modifie, que le nombre "extrais" se modifie aussi :)...
Je suis assez nouveau sous excel, donc je sais pas trop comment m'y prendre :D
Merci :)
A voir également:
- [Simple] Extraire un nombre d'un texte...
- Extraire une video youtube - Guide
- Extraire texte d'une image - Guide
- Extraire le son d'une vidéo - Guide
- Iphone 14 simple - Guide
- Mettre un texte en majuscule - Guide
5 réponses
Est-ce que TOUTES les phrases téléchargées ont la même structure, c'est-à-dire le nombre en dernière position et précédé de deux points (:), ou le nombre peut-il se trouver n'importe où dans la phrase ?
Salut.
Supposons que la phrase donnée en exemple soit placée dans la cellule G12.
=NBCAR(G12) calcule le nombre total de caractères de la phrase, soit 48.
=CHERCHE(":";G12;1) renvoie la position de départ de la première occurrence du caractère ":" dans le texte en G12, à partir de la première lettre de la phrase, soit 42. Il reste donc 48-42=6 caractères après ":".
=DROITE(G12;6) extrait les 6 derniers caractères (ceux de droite) de la phrase en G12, soit " 3.821".
=CNUM( DROITE(G12;6) ) devrait convertir l'expression " 3.821" en un nombre ; mais il y aura affichage du message d'erreur #VALEUR! à cause du point séparateur de milliers ; il faut donc s'en débarrasser avant d'écrire la moindre formule.
De sorte que la manipulation globale est la suivante :
1) Sélectionner G12 et une cellule vide (faute de quoi tout le fichier subirait la modification), faire "Remplacer/Rechercher" et taper un point, puis cliquer sur "Remplacer tout" sans rien mettre dans "Remplacer par". Ainsi la fin de la phrase devient "... forums : 3821".
2) Saisir la formule =CNUM(DROITE(G12;NBCAR(G12)-CHERCHE(":";G12;1)))
Bon travail ; à bientôt.
Supposons que la phrase donnée en exemple soit placée dans la cellule G12.
=NBCAR(G12) calcule le nombre total de caractères de la phrase, soit 48.
=CHERCHE(":";G12;1) renvoie la position de départ de la première occurrence du caractère ":" dans le texte en G12, à partir de la première lettre de la phrase, soit 42. Il reste donc 48-42=6 caractères après ":".
=DROITE(G12;6) extrait les 6 derniers caractères (ceux de droite) de la phrase en G12, soit " 3.821".
=CNUM( DROITE(G12;6) ) devrait convertir l'expression " 3.821" en un nombre ; mais il y aura affichage du message d'erreur #VALEUR! à cause du point séparateur de milliers ; il faut donc s'en débarrasser avant d'écrire la moindre formule.
De sorte que la manipulation globale est la suivante :
1) Sélectionner G12 et une cellule vide (faute de quoi tout le fichier subirait la modification), faire "Remplacer/Rechercher" et taper un point, puis cliquer sur "Remplacer tout" sans rien mettre dans "Remplacer par". Ainsi la fin de la phrase devient "... forums : 3821".
2) Saisir la formule =CNUM(DROITE(G12;NBCAR(G12)-CHERCHE(":";G12;1)))
Bon travail ; à bientôt.
Bonjour Zarbi3, Raymond,
Une autre solution possible:
Dans un module de code:
Sur un bouton de commande placé sur la feuille:
Ou bien sur un click droit dans la cellule concernée (Cellule A1 dans cet exemple):
Ce programme analyse la chaine alphanumérique pour en extraire les chiffres. Si la chaine comporte plusieurs séries de nombres, l'analyse s'arrête au premier nombre rencontré.
Espérant avoir contribué.
Cordialement.
Une autre solution possible:
Dans un module de code:
Sub Extraction() With ActiveSheet .Range("A2").ClearContents For n = 1 To Len(.Range("A1").Value) char = Mid(.Range("A1").Value, n, 1) If IsNumeric(char) Then .Range("A2") = .Range("A2") & char End If If IsNumeric(.Range("A2")) And Not IsEmpty(.Range("A2")) And char = " " Then Exit For Next End With End Sub
Sur un bouton de commande placé sur la feuille:
Private Sub CommandButton1_Click() Extraction End Sub
Ou bien sur un click droit dans la cellule concernée (Cellule A1 dans cet exemple):
Private Sub Worksheet_BeforeRightClick(ByVal Target As Range, Cancel As Boolean) If ActiveCell = Range("A1") Then Extraction Cancel = True End If End Sub
Ce programme analyse la chaine alphanumérique pour en extraire les chiffres. Si la chaine comporte plusieurs séries de nombres, l'analyse s'arrête au premier nombre rencontré.
Espérant avoir contribué.
Cordialement.
TOUTES les phrases sont de la meme structure que en haut :)
Par contre, les nombres, varient entre 1 et 6 chiffres :)
Par contre, les nombres, varient entre 1 et 6 chiffres :)
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question