跳至主要内容

如何在Excel中查找值并返回多个对应的值?

Author: Sun Last Modified: 2025-05-07

arrow blue right bubble 使用数组公式查找值并返回多个对应的值

这里有一个长的数组公式可以帮助查找一个值并返回多个对应的值。

1. 在一个空白单元格中输入您要查找的值。见截图:

Enter the value you want to look up

2. 在相邻的单元格中输入此公式 =IF(ISERROR(INDEX($A$1:$B$7,SMALL(IF($A$1:$A$7=$D$4,ROW($A$1:$A$7)),ROW(1:1)),2)),"",

INDEX($A$1:$B$7,SMALL(IF($A$1:$A$7=$D$4,ROW($A$1:$A$7)),ROW(1:1)),2))
,然后同时按下 Shift + Ctrl + Enter 键,再拖动自动填充柄向下填充单元格,直到出现第一个空白单元格。见截图:

return multiple corresponding values with formula

备注:在上述公式中,$A$1:$B$7 表示数据区域,$A$1:$A$7代表您查找特定值的列区域,$D$4 表示您在步骤1中输入查找值的单元格,2 表示在第二列中查找对应的值。


arrow blue right bubble 使用筛选查找值并返回多个对应的值

在Excel中,您也可以使用筛选功能来解决此问题。

1.选择您要查找值的列区域,然后点击数据 > 筛选。见截图:

go to filter feature

2. 然后点击您选择的范围第一个单元格中的箭头按钮,并在下拉列表中仅勾选您要查找的值。见截图:

check the value you want to look up

3. 点击确定,现在您只会看到查找值及其对应的值被筛选出来。

filter all corresponding values


arrow blue right bubble 使用自定义函数查找值并返回多个对应的值

如果您对自定义函数感兴趣,也可以使用自定义函数来解决此问题。

1. 按下 Alt + F11 键打开 Microsoft Visual Basic For Applications 窗口。

2. 点击 模块 > 插入以插入一个模块窗口,并将下面的VBA代码复制到窗口中。

VBA:查找值并返回多个对应的值。

Function MyVlookup(pWorkRng As Range, pRng As Range, pColumnIndex As Integer, Optional pType As String = "v")
'Updateby20140827
Dim xRow As Single
Dim xCol As Single
Dim arr() As Variant
ReDim arr(0)
For i = 1 To pRng.Rows.Count
    If pWorkRng = pRng.Cells(i, 1) Then
        arr(UBound(arr)) = pRng.Cells(i, pColumnIndex)
        ReDim Preserve arr(UBound(arr) + 1)
    End If
Next
If pType = "h" Then
    xCol = Range(Application.Caller.Address).Columns.Count
    For i = UBound(arr) To xCol
        arr(UBound(arr)) = ""
        ReDim Preserve arr(UBound(arr) + 1)
    Next
    ReDim Preserve arr(UBound(arr) - 1)
    MyVlookup = arr
Else
xRow = Range(Application.Caller.Address).Rows.Count
For i = UBound(arr) To xRow
    arr(UBound(arr)) = ""
    ReDim Preserve arr(UBound(arr) + 1)
Next
ReDim Preserve arr(UBound(arr) - 1)
MyVlookup = Application.WorksheetFunction.Transpose(arr)
End If
End Function

3.关闭窗口,并在一个单元格中输入此公式 =MyVlookup(A10,$A$2:$B$7,2)(A10 表示查找值,$A$2:$B$7 表示数据区域,2 表示列索引号)。然后按下 Shift + Ctrl + Enter 键。接着拖动填充柄向下填充单元格,将光标放入编辑栏(F),再次按下 Shift + Ctrl + Enter

提示:如果您想在水平单元格中返回值,可以输入此公式 =MyVlookup(A10, $A$2:$B$7,2, "h")

最佳办公效率工具

🤖 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%,每天为您减少数百次鼠标点击!