跳至主要内容

如何在Excel中比较两个单元格中的逗号分隔值并返回重复或唯一值?

Author: Siluvia Last Modified: 2025-05-07

如下图所示,有两列——列1和列2,每列中的每个单元格都包含逗号分隔的数字。要将列1中的逗号分隔数字与列2同一行的单元格内容进行比较,并返回所有重复或唯一的值,您会怎么做?

本教程提供两种方法帮助您完成此任务。

compare comma separated values in two cells


使用公式比较两个单元格中的逗号分隔值并返回重复或唯一值

本节提供了两个公式,帮助比较两个单元格中的逗号分隔值并返回它们之间的重复或唯一值。

注意:以下公式仅适用于Excel for 365。如果您使用的是其他版本的Excel,请尝试使用下面的VBA方法

以上述两列为示例,要将列1中的逗号分隔数字与列2同一行的逗号分隔数字进行比较并返回重复或唯一值,请按照以下步骤操作。

sample data

返回重复值

1. 选择一个单元格以输出两个指定单元格之间的重复数字(带有逗号分隔的数字),在此情况下,我选择了单元格D2,然后输入以下公式并按Enter键。选择公式单元格并向下拖动其自动填充柄以获取其他行中单元格之间的重复数字。

=LET(x, TRANSPOSE(TEXTSPLIT(TEXTJOIN(", ",TRUE,A2:B2), ", ")),y,UNIQUE(x),z,UNIQUE(x,,1), TEXTJOIN(", ",TRUE,IF(ISERROR(MATCH(y,z,0)),y, "")))

 compare to return duplicate values

返回唯一值

要返回同一行中两个指定单元格之间带有逗号分隔数字的唯一值,以下公式可以提供帮助。

1. 选择一个单元格以输出唯一数字,在此情况下,我选择了单元格E2,然后输入以下公式并按Enter键。选择公式单元格并向下拖动其自动填充柄以获取其他行中单元格之间的唯一数字。

=TEXTJOIN(", ",TRUE,UNIQUE(TRANSPOSE(TEXTSPLIT(TEXTJOIN(", ",TRUE,A2:B2), ", ")),,1))

compare to return unique values

注意事项

1) 上述两个公式只能应用于Excel for 365。如果您使用的不是Excel for 365版本,请尝试以下VBA方法。
2) 要比较的单元格必须在同一行或列中彼此相邻。
a screenshot of kutools for excel ai

使用 Kutools AI 解锁 Excel 魔法

  • 智能执行:执行单元格操作、分析数据和创建图表——所有这些都由简单命令驱动。
  • 自定义公式:生成量身定制的公式,优化您的工作流程。
  • VBA 编码:轻松编写和实现 VBA 代码。
  • 公式解释:轻松理解复杂公式。
  • 文本翻译:打破电子表格中的语言障碍。
通过人工智能驱动的工具增强您的 Excel 能力。立即下载,体验前所未有的高效!

使用VBA比较两列逗号分隔值并返回重复或唯一值

本节提供的用户自定义函数可帮助比较两个指定单元格中的逗号分隔值并返回它们之间的重复值或唯一值。请按照以下步骤操作。

以上述相同示例为例,要将列1中的逗号分隔数字与列2同一行的逗号分隔数字进行比较并返回重复或唯一值,请尝试使用本节中的用户自定义函数。

 sample data

1. 在打开的工作簿中,按Alt + F11键打开Microsoft Visual Basic for Applications窗口。

2. 在Microsoft Visual Basic for Applications窗口中,单击“插入”>“模块”,并将以下VBA代码复制到“模块(代码)”窗口中。

 copy anf paste the code into the module

VBA代码:比较两个单元格中的逗号分隔值并返回重复/唯一值

Private Function COMPARE(Rng1, Rng2 As Range, Op As Boolean)
'Updated by Extendoffice 20221019
    Dim R1Arr As Variant
    Dim R2Arr As Variant
    Dim Ans1 As String
    Dim Ans2 As String
    Dim Separator As String
    Dim d1 As New Dictionary
    Dim d2 As New Dictionary
    Dim d3 As New Dictionary
    Application.Volatile

    Separator = ", "
    
    R1Arr = Split(Rng1.Value, Separator)
    R2Arr = Split(Rng2.Value, Separator)
    
    Ans1 = ""
    Ans2 = ""
    
    For Each ch In R2Arr
        If Not d2.Exists(ch) Then
            d2.Add ch, "1"
        End If
    Next
    
    If Op Then
        For Each ch In R1Arr
            If d2.Exists(ch) Then
                If Not d3.Exists(ch) Then
                    d3.Add ch, "1"
                    Ans1 = Ans1 & ch & Separator
                End If
            End If
        Next
        If Ans1 <> "" Then
            Ans1 = Mid(Ans1, 1, Len(Ans1) - Len(Separator))
        End If
        COMPARE = Ans1
    Else
        For Each ch In R1Arr
            If Not d1.Exists(ch) Then
                d1.Add ch, "1"
            End If
        Next
        
        For Each ch In R1Arr
            If Not d2.Exists(ch) Then
                If Not d3.Exists(ch) Then
                    d3.Add ch, "1"
                    Ans2 = Ans2 & ch & Separator
                End If
            End If
        Next
        For Each ch In R2Arr
            If Not d1.Exists(ch) Then
                If Not d3.Exists(ch) Then
                    d3.Add ch, "1"
                    Ans2 = Ans2 & ch & Separator
                End If
            End If
        Next
        If Ans2 <> "" Then
            Ans2 = Mid(Ans2, 1, Len(Ans2) - Len(Separator))
        End If
        COMPARE = Ans2
    End If

End Function

3. 将代码粘贴到“模块(代码)”窗口后,转到单击“工具” > “引用”以打开“引用 – VBAProject”窗口,勾选“Microsoft Scripting Runtime”框,然后单击“确定”按钮。

 click Tools > References and check Microsoft Scripting Runtime box

4. 按Alt + Q键关闭Microsoft Visual Basic for Applications窗口。

5. 现在,您需要分别应用两个函数来从两个逗号分隔值单元格中返回重复值和唯一值。

返回重复值

选择一个单元格以输出重复数字,在此示例中,我选择了单元格D2,然后输入以下公式并按Enter键以获取单元格A2和B2之间的重复数字。

选择公式单元格并向下拖动其自动填充柄以获取其他行中单元格之间的重复数字。

=COMPARE(A2,B2,TRUE)

 use formula to return duplicate value

返回唯一值

选择一个单元格以输出唯一数字,在此示例中,我选择了单元格E2,然后输入以下公式并按Enter键以获取单元格A2和B2之间的唯一数字。

选择公式单元格并向下拖动其自动填充柄以获取其他行中单元格之间的唯一数字。

=COMPARE(A2,B2,FALSE)

 use formula to return unique value

最佳办公效率工具

🤖 Kutools AI 助手:基于智能执行生成代码创建自定义公式分析数据并生成图表调用 Kutools 函数等功能,彻底改变数据分析方式…
热门功能查找、高亮或标记重复项 | 删除空行 | 合并不丢失数据的列或单元格 | 四舍五入 ...
高级 LOOKUP多条件 VLookup | 多值 VLookup | 多表查找 | 模糊查找 ....
高级下拉列表快速创建下拉列表 | 从属下拉列表 | 多选下拉列表 ....
列管理器添加指定数量的列 | 移动列 | 切换隐藏列的可见状态 | 比较区域和列 ...
精选功能网格聚焦 | 设计视图 | 增强编辑栏 | 工作簿与工作表管理器 | 资源库(自动文本) | 日期提取 | 合并数据 | 加密/解密单元格 | 按列表发送电子邮件 | 超级筛选 | 特殊筛选(筛选粗体/斜体/删除线...)...
排名前 15 的工具集12 种文本 工具添加文本删除特定字符等) | 50 多 种图表 类型甘特图等) | 40 多种实用 公式基于生日计算年龄等) | 19 种插入 工具插入二维码根据路径插入图片等) | 12 种转换 工具小写金额转大写汇率转换等) | 7 种合并与分割 工具高级合并行分割单元格等) | 还有更多...

使用 Kutools for Excel 提升您的 Excel 技能,体验前所未有的高效。 Kutools for Excel 提供超过 300 种高级功能来提高生产力并节省时间。 单击此处获取您最需要的功能...


Office Tab 将标签式界面引入 Office,让您的工作更加轻松

  • 在 Word、Excel、PowerPoint 中启用标签式编辑和阅读
  • 在同一窗口的新标签页中打开和创建多个文档,而不是在新窗口中进行操作。
  • 将您的生产力提升 50%,每天为您减少数百次鼠标点击!