Comment extraire une phrase avant ou après un caractère dans une cellule Excel

Microsoft Excel est un outil puissant pour la gestion des données, et il offre de nombreuses fonctionnalités pour manipuler et extraire des informations à partir de cellules. Dans cet article, nous allons expliquer comment extraire une phrase avant ou après un caractère spécifique, tel qu’un point-virgule (;) ou une virgule (,), dans une cellule Excel. Nous allons également vous fournir le code VBA (Visual Basic for Applications) pour le faire.

Extraction de la phrase avant le caractère (ici le point  virgule)

Si vous souhaitez extraire la phrase avant le caractère dans une cellule Excel, vous pouvez utiliser la fonction « GAUCHE » combinée avec la fonction « TROUVE ». Voici un exemple de formule :

=GAUCHE(A1, TROUVE(";", A1) - 1)

Dans cette formule, « A1 » représente la cellule contenant le texte à analyser, et « TROUVE(« ; », A1) » trouve la position du premier point-virgule dans la cellule. La fonction « GAUCHE » extrait ensuite tous les caractères avant cette position.

Extraction d’une chaine après un caractère donné

Si vous souhaitez extraire la phrase après le caractère dans une cellule Excel, vous pouvez utiliser la fonction « DROITE » combinée avec la fonction « TROUVE ». Voici un exemple de formule :

=DROITE(A1, LONGUEUR(A1) - TROUVE(";", A1))

Dans cette formule, « A1 » représente la cellule contenant le texte à analyser, et « TROUVE(";", A1) » trouve la position du premier point-virgule dans la cellule. La fonction « DROITE » extrait ensuite tous les caractères après cette position en soustrayant la position trouvée de la longueur totale de la cellule.

Utilisation de VBA pour automatiser l’extraction

Si vous avez besoin d’automatiser l’extraction de phrases avant ou après un caractère dans plusieurs cellules, vous pouvez utiliser une macro VBA. Voici un exemple de code VBA pour extraire la phrase avant un point-virgule et la placer dans une cellule adjacente :


Sub ExtractBeforeSemicolon()
Dim cell As Range
For Each cell In Selection
If InStr(1, cell.Value, ";") > 0 Then
cell.Offset(0, 1).Value = Left(cell.Value, InStr(1, cell.Value, ";") - 1)
End If
Next cell
End Sub

Ce code parcourt la plage de cellules sélectionnées, recherche un point-virgule dans chaque cellule et extrait la phrase avant le point-virgule, la plaçant dans la cellule adjacente.

Vous pouvez également adapter ce code pour extraire des phrases après un point-virgule ou pour travailler avec d’autres caractères, tels que des virgules. Assurez-vous d’activer les macros dans Excel et de sauvegarder votre classeur au format « XLSM » pour utiliser des macros VBA.

En utilisant les formules Excel et le code VBA, vous pouvez extraire des informations spécifiques de vos données, ce qui peut être utile pour la gestion et l’analyse de vos feuilles de calcul.

LAISSER UNE REPONSE

S'il vous plaît entrez votre commentaire!
S'il vous plaît entrez votre nom ici