跳至主要内容

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

Author: Sun Last Modified: 2025-07-31

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")

最佳 Office 办公效率工具

🤖 Kutools AI 助手:基于智能执行,彻底革新数据分析 生成代码创建自定义公式分析数据并生成图表调用 Kutools Functions
热门功能:查找、选中项的背景色或标记重复项|删除空行|合并列或单元格且不丢失数据|四舍五入(无公式)...
高级 LOOKUP多条件查找 (VLookup)多值查找 (VLookup)多表查找 (VLookup Across Multiple Sheets)模糊查找 (Fuzzy Lookup)...
高级下拉列表快速创建下拉列表依赖型下拉列表多选下拉列表...
列管理器添加指定数量的列移动列切换隐藏列的可见状态比较区域及列...
特色功能网格聚焦设计视图增强编辑栏工作簿 & 工作表管理器资源库(自动文本)|日期提取合并数据加密/解密单元格按列表发送电子邮件超级筛选特殊筛选(筛选粗体/倾斜/删除线等)...
热门15 大工具集12 款文本工具添加文本删除特定字符等)50+ 种图表 类型甘特图等)40+ 实用公式基于生日计算年龄等)19 款插入工具插入二维码按路径插入图片等)12 种转换工具小写金额转大写汇率转换等)7 款合并与分割工具高级合并行分割单元格等)...更多精彩等你发现
使用 Kutools,支持您的首选语言——包括英语、西班牙语、德语、法语、中文及40 多种其他语言!

用 Kutools for Excel 加速你的 Excel 技能,体验前所未有的高效办公。 Kutools for Excel 提供300 多项高级功能,助您提升效率,节省大量时间。点击此处,获取你最需要的功能...


Office Tab 为 Office 带来标签式界面,让你的工作更加轻松

  • 在 Word、Excel、PowerPoint 启用标签式编辑和阅读
  • 在同一窗口的新标签中打开和创建多个文档,无需新建窗口。
  • 办公效率提升50%,每天帮你减少上百次鼠标点击!