Astuce: Les autres langues sont Google-Traduction. Vous pouvez visiter le English version de ce lien.
Se connecter
x
or
x
x
S'enregistrer
x

or

Comment comparer deux chaînes de similarité ou mettre en évidence des différences dans Excel?

Dans certains cas, vous pouvez seulement devoir comparer deux cellules adjacentes de chaînes et marquer leurs similitudes ou différences dans Excel. Cet article fournit deux méthodes pour vous de l'atteindre.

Comparez deux chaînes avec une formule

Comparer deux chaînes pour la similarité ou mettre en évidence les différences avec le code VBA


Comparer facilement deux plages / feuilles de calcul et mettre en évidence les mêmes cellules / différentes dans Excel

Cliquez Kutools > Ou sélectionner > Sélectionnez les mêmes cellules et différentes. le Kutools for Excel's Sélectionnez des cellules identiques et différentes utilitaire vous permet de comparer facilement deux plages ou feuilles de calcul, puis de mettre en évidence les mêmes cellules ou des cellules différentes dans Excel. Voir ci-dessous capture d'écran:

Kutools for Excel comprend plus de 300 outils maniables Excel. Gratuit pour essayer sans limitation dans les jours 60. Téléchargez l'essai gratuit maintenant


Comparez deux chaînes avec une formule


Comme ci-dessous capture d'écran, si vous voulez juste savoir si les chaînes comparées correspondent ou non, vous pouvez appliquer la formule suivante.

1. Sélectionnez une cellule vide C2, entrez la formule = EXACT (A2, B2) dans la barre de formule, puis appuyez sur la touche Entrée. Voir la capture d'écran:

Note: Dans la formule, A2 et B2 sont les cellules contenant les chaînes de comparaison.

2. Continuez à sélectionner la cellule de résultat, puis faites glisser le handle de remplissage vers les cellules jusqu'à obtenir tous les résultats comparés.

Le résultat FALSE signifie que les chaînes comparées sont différentes et le résultat TRUE indique que les deux chaînes comparées correspondent. Voir la capture d'écran:


Comparer deux chaînes pour la similarité ou mettre en évidence les différences avec le code VBA

Si vous voulez comparer deux chaînes et mettre en évidence les similitudes ou les différences entre eux. Le code VBA suivant peut vous aider.

1. presse autre + F11 touches simultanément pour ouvrir le Microsoft Visual Basic pour applications fenêtre.

2. dans le Microsoft Visual Basic pour applications fenêtre, cliquez sur insérer > Module. Ensuite, copiez et collez le code suivant dans la fenêtre Code.

Code VBA: comparez deux chaînes de colonnes pour rechercher des similitudes ou mettre en évidence des différences

Sub highlight()
    Dim xRg1 As Range
    Dim xRg2 As Range
    Dim xTxt As String
    Dim xCell1 As Range
    Dim xCell2 As Range
    Dim I As Long
    Dim J As Integer
    Dim xLen As Integer
    Dim xDiffs As Boolean
    On Error Resume Next
    If ActiveWindow.RangeSelection.Count > 1 Then
      xTxt = ActiveWindow.RangeSelection.AddressLocal
    Else
      xTxt = ActiveSheet.UsedRange.AddressLocal
    End If
lOne:
    Set xRg1 = Application.InputBox("Range A:", "Kutools for Excel", xTxt, , , , , 8)
    If xRg1 Is Nothing Then Exit Sub
    If xRg1.Columns.Count > 1 Or xRg1.Areas.Count > 1 Then
        MsgBox "Multiple ranges or columns have been selected ", vbInformation, "Kutools for Excel"
        GoTo lOne
    End If
lTwo:
    Set xRg2 = Application.InputBox("Range B:", "Kutools for Excel", "", , , , , 8)
    If xRg2 Is Nothing Then Exit Sub
    If xRg2.Columns.Count > 1 Or xRg2.Areas.Count > 1 Then
        MsgBox "Multiple ranges or columns have been selected ", vbInformation, "Kutools for Excel"
        GoTo lTwo
    End If
    If xRg1.CountLarge <> xRg2.CountLarge Then
       MsgBox "Two selected ranges must have the same numbers of cells ", vbInformation, "Kutools for Excel"
       GoTo lTwo
    End If
    xDiffs = (MsgBox("Click Yes to highlight similarities, click No to highlight differences ", vbYesNo + vbQuestion, "Kutools for Excel") = vbNo)
    Application.ScreenUpdating = False
    xRg2.Font.ColorIndex = xlAutomatic
    For I = 1 To xRg1.Count
        Set xCell1 = xRg1.Cells(I)
        Set xCell2 = xRg2.Cells(I)
        If xCell1.Value2 = xCell2.Value2 Then
            If Not xDiffs Then xCell2.Font.Color = vbRed
        Else
            xLen = Len(xCell1.Value2)
            For J = 1 To xLen
                If Not xCell1.Characters(J, 1).Text = xCell2.Characters(J, 1).Text Then Exit For
            Next J
            If Not xDiffs Then
                If J <= Len(xCell2.Value2) And J > 1 Then
                    xCell2.Characters(1, J - 1).Font.Color = vbRed
                End If
            Else
                If J <= Len(xCell2.Value2) Then
                    xCell2.Characters(J, Len(xCell2.Value2) - J + 1).Font.Color = vbRed
                End If
            End If
        End If
    Next
    Application.ScreenUpdating = True
End Sub

3. appuie sur le F5 clé pour exécuter le code. En premier Kutools for Excel boîte de dialogue, sélectionnez la première colonne de chaînes de texte à comparer, puis cliquez sur OK .

4. Puis la seconde Kutools for Excel La boîte de dialogue s'affiche, sélectionnez les deuxièmes colonnes, puis cliquez sur OK .

5. À la fin Kutools for Excel boîte de dialogue, si vous souhaitez comparer les chaînes pour la similarité, cliquez sur Oui bouton. Et pour mettre en évidence les différences des chaînes comparées, cliquez sur Non bouton. Voir la capture d'écran:

Ensuite, vous pouvez voir les résultats comparés comme ci-dessous capture d'écran montré.


Articles Liés:



Outils de productivité recommandés

Office Tab

étoile d&#39;or1 Apportez des onglets pratiques à Excel et à d'autres logiciels Office, tout comme Chrome, Firefox et Internet Explorer.

Kutools for Excel

étoile d&#39;or1 Incroyable! Augmentez votre productivité dans les minutes 5. Ne nécessite pas de compétences particulières, économisez deux heures par jour!

étoile d&#39;or1 300 Nouvelles fonctionnalités pour Excel, rendent Excel facile et puissant:

  • Fusionner des cellules / lignes / colonnes sans perdre de données.
  • Combiner et consolider plusieurs feuilles et classeurs.
  • Comparez les gammes, copiez plusieurs gammes, convertissez le texte en date, l'unité et la conversion de devise.
  • Compter par couleurs, sous-totaux de recherche, tri avancé et super filtre,
  • Plus Sélectionner / Insérer / Supprimer / Texte / Format / Lier / Commenter / Classeurs / Feuilles de calcul Outils ...

Capture d&#39;écran de Kutools pour Excel

Say something here...
symbols left.
You are guest ( Sign Up? )
or post as a guest, but your post won't be published automatically.
Loading comment... The comment will be refreshed after 00:00.
  • To post as a guest, your comment is unpublished.
    Stefan · 4 months ago
    Very useful script! thanks
  • To post as a guest, your comment is unpublished.
    Eddy · 6 months ago
    Hello
    How do I copy Column1 next to Column2 if one or more items in Column 1 resembles / is identical to one or more items in Column2?
    I'm sorry but I've been working with Excel VBA for a while and I can not find the answer to this question.
    Thank you in advance for your answer.
  • To post as a guest, your comment is unpublished.
    Eddy · 6 months ago
    Hello
    How do I copy Column1 next to Column2 if one or more items in Column 1 resembles / is identical to one or more items in Column2?
    I'm sorry but I've been working with Excel VBA for a while and I can not find the answer to this question.
    Thank you in advance for your answer.
  • To post as a guest, your comment is unpublished.
    Carlos · 1 years ago
    Need to know how I can identify strings with the same text format so I can link an acct to all those strings. For instance, if I have 1,000 cells with different content, I want to separate those that have format 042-XXX-XX-00 to link them to an acct#.
  • To post as a guest, your comment is unpublished.
    SDJ · 1 years ago
    Thank you!