excel hlookup函数怎么用? excel中的高效查找技巧-kb88凯时官网登录

时间:2024-11-17
阅读:
免费资源网 - https://freexyz.cn/

microsoft excel 是数据管理和分析的首选应用程序,提供大量功能来简化各种任务。在这些函数中,hlookup是一个强大的工具,可以让用户进行水平查找。在这篇文章中,我将深入探讨 hlookup 的概念、它的语法以及它的实际应用。

excel 中的 hlookup 是什么?

hlookup 是“水平查找”的缩写,是一种 excel 函数,允许用户在表或区域的第一行中搜索值,并从另一个指定行中检索相关值。就像其对应的 vlookup(垂直查找)一样,hlookup 旨在简化从大型数据集中查找和提取特定信息的过程。在处理水平组织的数据表时,它尤其有价值。

hlookup 函数的语法

hlookup函数的语法如下:

=hlookup(lookup_value, table_array, row_index_num, [range_lookup])

  • lookup_value:要在表或范围的第一行中搜索的值。
  • table_array:包含查找值和要检索的数据的单元格范围。它必须包括包含查找值的行和包含相应数据的行。
  • row_index_num:要检索的数据相对于行的行号(从1开始)
  • [range_lookup]:可选参数,用于确定您想要精确匹配还是近似匹配。如果设置为 true 或省略,excel 将执行近似匹配(默认行为)。如果设置为 false,excel 将执行精确匹配。

1、问题描述

如下图:是一张集团公司的升职加薪表。

excel hlookup函数怎么用? excel中的高效查找技巧

现在需要将集团公司中部分人员的岗位工资、薪级工资、岗位补贴和合计等内容引用到一张新表中。

正常情况下,我们会这样写公式:

excel hlookup函数怎么用? excel中的高效查找技巧

【l2】单元格输入如下公式:

=vlookup($k2,$b:$h,column(d1),0)

公式解析:

以【k2】单元格的内容:「武胜」 作为查找值,在数据源区域 b 到 h 列中进行查找,如果查找到就返回第 4 列对应的值。

公式向右拖动一个单元格,column (d1)(即数字 4)会变成 column (e1)(即数字 5),以此类推。

但是,大家有没有发现,他只返回了每个人员第一次出现的值,如果,我们现在只需要返回升职加薪之后的数据,那该怎么办呢?

这个时候,就轮到它的二师弟猪哥(hlookup)上场了。

那我们一起来看看它的表演吧。

2、解决问题

hlookup 这个函数与 vlookup 函数是一对孪生兄弟,

vlookup 是垂直方向查找,返回列对应的值。

而 hlookup 是水平方向查找,返回行对应的值。

我们在【l2】单元格输入如下公式:

=hlookup(l$1,$b$2:$h$14,match($k2,$b$2:$b$14,0) 1,0)

excel hlookup函数怎么用? excel中的高效查找技巧

公式解析:

这个函数也有四个参数,与 vlookup 完全相同。

语法如下:

excel hlookup函数怎么用? excel中的高效查找技巧

第❶参数是 lookup_value 查找值,

第❷参数是 table_array 查找区域,

第❸参数是 row_index_num 返回对应的行值。

第❹参数是 range_lookup 为精确查找。

查找值为:【l1】单元格的内容【岗位工资】,

查找区域为:$b$2:$h$14,即首列,必须包含查找值。

返回对应的行值,用了一个 match 来配合下,

match($k2,$b$2:$b$14,0)

excel hlookup函数怎么用? excel中的高效查找技巧

第一参数查找值【k2】单元格中的值「武胜」。

第二参数查找区域【$b$2:$b$14】,这个姓名所在的单元格区域中查找,并返回在这个区域中是排到第几个单元格。比如排到第 4,就返回数字 4。

第三参数为 0,表示精确查找。

因为 match 函数也是返回第一查找到的值所对应的数字,所以让它的返回值 1,就返回了升职加薪之后的所在行的数字了。即 4 1=5。

于是 hlookup 函数的结果如下:

=hlookup ("岗位工资",$b$2:$h$14,5,0)

如下图所示:

excel hlookup函数怎么用? excel中的高效查找技巧

备注:match 函数也将其中合并单元格中的空白单元格算在内。

3、知识扩展

某些小伙伴可能很好奇,是否一定不能用 vlookup 函数解决这个问题,

或者有的小伙伴会很痴迷于用 vlookup 函数,一定要用其解决。这倒也不是不行。

但是,这里需要结合 if 函数,并进行数据区域重新构造。只有满足 vlookup 的查找要求才能让其正确返回值。如下图:

excel hlookup函数怎么用? excel中的高效查找技巧

=vlookup($k2,if({1,0},$b$3:$b$13,e$4:e$14),2,0)

公式解析:

与常规的 vlookup 函数的第二参数不同的是,

这里用 if 函数进行了两个区域的重新构造

if 的第二参数是:查找的区域,即:$b$3:$b$13

if 的第三参数是:返回的区域,即:e$4:e$14

而且是错行排列的。正好符合 vlookup 函数返回第一个查找值的要求。

excel hlookup函数怎么用? excel中的高效查找技巧

另外:if 的第三参数是:返回的区域,即:e$4:e$14,是一个行绝对引用,列相对引用,这样在向右拖动公式的时候,可以返回正确的列。

因为这个公式是数组公式,所以还需要按三键【ctrl shift enter】结束(ps.office 365 按【enter】即可)。

上面的问题到此就解决了。

but,领导们的想法是会随时变化的。

比如,现在的领导的要求是:

不仅需要看升职加薪之后的明细数据,也需要同时查看升职加薪之前的数据。那该怎么办呢?就像下图这样:

excel hlookup函数怎么用? excel中的高效查找技巧

这种情况下,如果要用函数的话,还真是要猪哥上场了。

而且原来的公式基本不用改动,只需要增加一个求余函数 返回行号的函数就行。

excel hlookup函数怎么用? excel中的高效查找技巧

公式如下:

excel hlookup函数怎么用? excel中的高效查找技巧

公式解析:

第三参数那里增加 mod (row (a2),2)。其中:

row (a2),返回行号 2(即:row (a2)=2),作为 mod 的函数参数。

mod (2,2),然后对 2 求余额数即为:0。(即:mod (2,2)=0)

然后 match 查找到的值再加上 0 值,还是返回 match 的值。

公式向下拖动即返回:mod (row (a3),2)。其中:row (a3),返回行号 3(即:row (a3)=3),作为 mod 的函数参数。

mod (3,2), 然后对 3 求余额数即为:1。(即:mod (3,2)=1)

最终 match 的返回值 1。

这里的关键点是:

用 mod 函数来代替原来公式中的 1 这个值,调节返回 0 和 1 两个数字。

4、写在最后

今天我们分享了 vlookup 函数二师弟,猪哥 hlookup 函数的用法

在大部分情况下,vlookup 的查找还是非常方便实用的,但是在某些情况下,真不如它的师弟 hlookup 函数。

另外在上面的例子中,虽然 vlookup 函数结合 if 函数进行数据区域重新构造也能解决问题,但是在实际工作中,不建议使用。

因为,它是一个数组公式,在数据比较多的情况下,会导致表格很卡

所以,尽量不使用数组公式,只使用简单公式的组合,而且组合越少越好,计算次数越少越好,这才是工作中需要实现的目标。

好了,今天我们就分享到这里,如果喜欢此篇文章,欢迎点赞 & 转发

除了上面介绍的 hlookup 函数,excel 里还有很多的函数,比如 lookup、xlookup、sumif 等等。

使用 hlookup 函数时的常见错误

在 excel 中使用 hlookup 函数时,您可能会遇到一些常见错误。以下是最常见的问题以及解决方法:

1. #n/a 错误

原因:当 hlookup 函数无法在 table_array 的第一行中找到查找值的匹配项时,会发生 #n/a 错误。当查找值不存在于顶行时,就会发生这种情况。

kb88凯时官网登录的解决方案:仔细检查查找值和 table_array 第一行中的数据以确保它们匹配。如有必要,请检查可能导致不匹配的前导/尾随空格。

2.#参考!错误

原因:#ref!当 hlookup 公式中的 table_array 引用无效或已被删除时,会发生错误。

kb88凯时官网登录的解决方案:检查 table_array 引用以确保其有效并涵盖查找所需的数据范围。如果您意外删除了 table_array 或其一部分,请恢复引用。

3.#value!错误

原因:#value!当 row_index_num 参数不是有效数字或公式包含不正确的数据类型时,通常会发生错误。

kb88凯时官网登录的解决方案:确保 row_index_num 参数是一个正整数,表示要返回结果的行号。另外,检查公式中使用的数据类型是否存在不一致。

有效使用 hlookup 函数的专家提示

  • 以表格形式组织数据:hlookup 设计用于处理水平排列的数据。确保您的数据以表格格式组织良好,标题位于顶行。
  • 对数据进行排序:与 vlookup 类似,根据 table_array 第一行中的值按升序对数据进行排序将提高 hlookup 的性能,尤其是对于近似匹配。
  • 使用精确匹配:要获得准确的结果,请将 range_lookup 参数设置为 false 以实现精确匹配。这可确保您获得所需的精确匹配,并避免任何潜在的错误结果。
  • 将 hlookup 与 iferror 结合使用:与 vlookup 一样,使用 iferror 可以更优雅地处理错误。使用 iferror 包装 hlookup 函数允许您显示自定义消息或在未找到查找值时返回默认值。
  • 锁定 table_array 范围:如果要将 hlookup 公式复制到多个单元格,请对 table_array 参数使用绝对单元格引用 ($)。这可以防止在复制公式时 table_array 的引用发生更改。
  • 检查前导/尾随空格:确保数据干净且 table_array 第一行中没有任何前导或尾随空格。多余的空格可能会导致 hlookup 无法找到匹配项。
  • 最大限度地减少易失性函数:避免将 hlookup 与易失性函数(例如 today()、now() 或 rand())一起使用,以保持最佳的电子表格性能。
免费资源网 - https://freexyz.cn/
返回顶部
顶部
网站地图