जो शब्द मेल नहीं खाते हैं उन्हें उजागर करने के लिए मैं एक्सेल में दो कॉलम की तुलना कैसे कर सकता हूं?


2

(मैं माइक्रोसॉफ्ट एक्सेल 2010 का उपयोग कर रहा हूं)

Lts का कहना है कि मेरे पास कॉलम A और कॉलम B दोनों में वाक्यांशों की एक सूची है (नीचे स्क्रीन शॉट देखें)

यहाँ छवि विवरण दर्ज करें

मैं क्या करना चाहूंगा कि क्या यह एक स्थूल, VBA या सूत्र के साथ है:

यदि स्तंभ A के किसी कक्ष में कोई ऐसा शब्द है, जो उस शब्द को लाल रंग में हाइलाइट करने के लिए स्तंभ B के किसी भी कक्ष में कोई भी शब्द नहीं है।

उदाहरण के लिए: सेल ए 9 में "बाय" शब्द है, लेकिन कॉलम बी में कहीं भी खरीद शब्द का उल्लेख नहीं किया गया है, इसलिए मैं लाल रंग को उजागर करने के लिए शब्द खरीदना चाहूंगा।

मैं यह कैसे हासिल कर सकता हूं?

(मुझे लगता है कि एक मैक्रो / वीबीए सबसे अच्छा विकल्प होगा लेकिन मुझे नहीं पता कि इसे कैसे बनाया जाए, या यहां तक ​​कि यदि संभव हो तो।)


1
आपने जो चाहा उसे समझाने का अच्छा काम किया। मैंने शीर्षक में स्पष्टता जोड़ने और अभिवादन को हटाने के लिए इसे थोड़ा संपादित किया (यहाँ इस्तेमाल नहीं किया गया)। आपके सवाल को संपादित करने के लिए बेहतर क्या होगा कि आपने जो कोशिश की है या शोध किया है उसे शामिल करें
चार्लीआरबी

1
क्या शब्द सीमांकक हमेशा एक ही स्थान है?
निक्सन

जवाबों:


2

VBA मॉड्यूल में निम्न कोड डालें।

Sub highlightWords()
Application.ScreenUpdating = False
Dim rng2HL As Range, rngCheck As Range, dictWords As Object
Dim a() As Variant, b() As Variant, wordlist As Variant, wordStart As Long
Set r = Selection
'Change the addresses below to match your data.
Set rng2HL = Range("A1:A9")
Set rngCheck = Range("B1:B9")
a = rng2HL.Value
b = rngCheck.Value
Set dictWords = CreateObject("Scripting.Dictionary")
'Load unique words from second column into a dictionary for easy checking
For i = LBound(b, 1) To UBound(b, 1)
    wordlist = Split(b(i, 1), " ")
    For j = LBound(wordlist) To UBound(wordlist)
        If Not dictWords.Exists(wordlist(j)) Then
            dictWords.Add wordlist(j), wordlist(j)
        End If
    Next j
Next i
'Reset range to highlight to all black font.
rng2HL.Font.ColorIndex = 1
'Check words one by one against dictionary.
For i = LBound(a, 1) To UBound(a, 1)
    wordlist = Split(a(i, 1), " ")
    For j = LBound(wordlist) To UBound(wordlist)
        If Not dictWords.Exists(wordlist(j)) Then
            wordStart = InStr(a(i, 1), wordlist(j))
            'Change font color of word to red.
            rng2HL.Cells(i).Characters(wordStart, Len(wordlist(j))).Font.ColorIndex = 3
        End If
    Next j
Next i
Application.ScreenUpdating = True
End Sub

बस अपनी कार्यपत्रक से मिलान करने के लिए नीचे की पंक्तियों में पते बदलना सुनिश्चित करें।

Set rng2HL = Range("A1:A9")
Set rngCheck = Range("B1:B9")

परिणाम:

यहाँ छवि विवरण दर्ज करें

संपादित करें:

चूंकि आपने नीचे टिप्पणियों में आवश्यकताएं जोड़ी हैं, इसलिए मैंने कॉलम सी में लाल-हाइलाइट किए गए वाक्यांशों की सूची को प्रिंट करने के लिए कोड को भी संशोधित किया है। यदि आप इस सूची को कहीं और चाहते हैं, तो आपको कोड के अंतिम भाग में पता समायोजित करना होगा। । मैंने हाइलाइटिंग कोड में भी सुधार किया - मैंने देखा कि यह अजीब चीजें करेगा जैसे केवल गैर-मिलान शब्द के पहले उदाहरण को उजागर करें।

Sub highlightWords()
Application.ScreenUpdating = False
Dim rng2HL As Range, rngCheck As Range, dictWords As Object, dictRed As Object
Dim a() As Variant, b() As Variant, wordlist As Variant, wordStart As Long, phraseLen As Integer
Dim re As Object, consec As Integer, tmpPhrase As String
'Change the addresses below to match your data.
Set rng2HL = Range("A1:A9")
Set rngCheck = Range("B1:B9")
a = rng2HL.Value
b = rngCheck.Value
Set dictWords = CreateObject("Scripting.Dictionary")
'Load unique words from second column into a dictionary for easy checking
For i = LBound(b, 1) To UBound(b, 1)
    wordlist = Split(b(i, 1), " ")
    For j = LBound(wordlist) To UBound(wordlist)
        If Not dictWords.Exists(wordlist(j)) Then
            dictWords.Add wordlist(j), wordlist(j)
        End If
    Next j
Next i
Erase b
'Reset range to highlight to all black font.
rng2HL.Font.ColorIndex = 1
Set dictRed = CreateObject("Scripting.Dictionary")
Set re = CreateObject("vbscript.regexp")
'Check words one by one against dictionary.
For i = LBound(a, 1) To UBound(a, 1)
    wordlist = Split(a(i, 1), " ")
    consec = 0
    tmpPhrase = ""
    For j = LBound(wordlist) To UBound(wordlist)
        If Not dictWords.Exists(wordlist(j)) Then
            consec = consec + 1
            If consec > 1 Then tmpPhrase = tmpPhrase & " "
            tmpPhrase = tmpPhrase & wordlist(j)
        Else
            If consec > 0 Then
                If Not dictRed.Exists(tmpPhrase) Then dictRed.Add tmpPhrase, tmpPhrase
                re.Pattern = "(^| )" & tmpPhrase & "( |$)"
                Set matches = re.Execute(a(i, 1))
                For Each m In matches
                    wordStart = m.FirstIndex
                    phraseLen = m.Length
                    'Change font color of word to red.
                    rng2HL.Cells(i).Characters(wordStart + 1, phraseLen).Font.ColorIndex = 3
                Next m
                consec = 0
                tmpPhrase = ""
            End If
        End If
    Next j
    'Highlight any matches that appear at the end of the line
    If consec > 0 Then
        If Not dictRed.Exists(tmpPhrase) Then dictRed.Add tmpPhrase, tmpPhrase
        re.Pattern = "(^" & tmpPhrase & "| " & tmpPhrase & ")( |$)"
        Set matches = re.Execute(a(i, 1))
        For Each m In matches
            wordStart = m.FirstIndex
            phraseLen = m.Length
            'Change font color of word to red.
            rng2HL.Cells(i).Characters(wordStart + 1, phraseLen).Font.ColorIndex = 3
        Next m
    End If
Next i
Erase a
'Output list of unique red phrases to column C.
redkeys = dictRed.Keys
For k = LBound(redkeys) To UBound(redkeys)
    Range("C1").Offset(k, 0).Value = redkeys(k)
Next k
Erase redkeys
Application.ScreenUpdating = True
End Sub

नया उदाहरण


यह पूर्ण है!! आपकी मदद के लिए बहुत बहुत धन्यवाद, मुझे नहीं लगा कि यह संभव होगा। अब जब मुझे पता है कि यह हो सकता है कि आप थोड़ी मदद कर सकते हैं और मैक्रो में शामिल कर सकते हैं; एक बार सूची में कॉलम सी में उन शब्दों को स्थानांतरित करने के लिए शब्दों को लाल रंग में हाइलाइट किया जाता है? और यदि आप एक कदम आगे जा सकते हैं और किसी भी डुप्लिकेट शब्द को हटाने के लिए सूची में एक बार कॉलम सी में शामिल हैं?
जीज़ वेंडर ब्राउन

यदि इसे उसी VBA में शामिल नहीं किया जा सकता है, तो क्या आप मेरे लिए एक अलग निर्माण कर पाएंगे?
Jez Vander Brown

@JezVanderBrown ठीक है, मैंने अपने उत्तर में नया कोड जोड़ा है।
एक्सेल

0

अगर आप A और B को अलग-अलग शीट पर रखते हैं तो आप प्रत्येक कॉलम को एक सेल में एक सेल में विभाजित करने के लिए Text to Columns का उपयोग कर सकते हैं। तब एक साधारण LOOKUP () आपको उन शब्दों को खोजने देगा जो कोशिकाओं के दूसरे सेट में दिखाई नहीं देते हैं।

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.