1

У меня есть два столбца со строками, и я хочу знать, какие части строки из одного столбца имеют с другим столбцом. Я проверил это решение Сравните 2 текстовых ячейки и показать разницу в третьей ячейке | Супер пользователь, но это не работает для моей проблемы.

На приведенном ниже снимке экрана я хочу, чтобы в столбце результатов была строка Elementary поскольку именно это отличает B2 от A2 . Я попытался использовать =SUBSTITUTE(A2,B2,"") на основе решения, приведенного в ссылке выше, но формула делает противоположное, отображая общие строки в обоих столбцах:

скриншот формулы

Как я могу заставить его отображать разницу строк (Elementary)?

1 ответ1

3

Как я могу заставить его отображать разницу строк (элементарный)?

Вот пользовательская функция WORDDIF которая может делать то, что вы хотите.

Чтобы установить пользовательскую функцию ...

  • Alt+F11, чтобы открыть редактор VBA
  • В меню VBA выберите "Вставка"> "Модуль".
  • Вставьте приведенный ниже код в окно редактирования VBA.

Вернувшись в Excel, поместите эту формулу в C1

=WORDDIF(A1,B1)

Код:

Function WORDDIF(rngA As Range, rngB As Range) As String

    Dim WordsA As Variant, WordsB As Variant
    Dim ndxA As Long, ndxB As Long, strTemp As String

    WordsA = Split(rngA.Text, " ")
    WordsB = Split(rngB.Text, " ")

    For ndxB = LBound(WordsB) To UBound(WordsB)
        For ndxA = LBound(WordsA) To UBound(WordsA)
            If StrComp(WordsA(ndxA), WordsB(ndxB), vbTextCompare) = 0 Then
                WordsA(ndxA) = vbNullString
                Exit For
            End If
        Next ndxA
    Next ndxB

    For ndxA = LBound(WordsA) To UBound(WordsA)
        If WordsA(ndxA) <> vbNullString Then strTemp = strTemp & WordsA(ndxA) & " "
    Next ndxA

    WORDDIF = Trim(strTemp)

End Function

Источник https://www.mrexcel.com/forum/excel-questions/486708-compare-two-strings-find-difference.html

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .