打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
Excel-VBA自定义函数扩展VLOOKUP函数返回指定的结果

应用场景

工作表函数vlookup仅仅返回符合条件的第一个值,扩展后可指定返回的值


知识要点

1:开发一个名为Look的函数(包括4个参数,前两个为必选参数,后两个为可选参数),第一参数代表查找对象,第二参数代表被查找区域,通常为多列的单元格区域

2:第三参数代表返回值所在的列数,例如默认为2列,第四参数代表返回第几个值,默认为第一个。

3:DO  LOOP  WHILE 循环,FIND函数


Function Look(查找值 As String, 区域 As Range, Optional 列 As Integer = 2, Optional 索引号 As Integer = 1) As String

    Application.Volatile '声明为易失性函数

    Dim i As Long, Cell As Range, Str As String

    With 区域.Columns(1) '引用区域的第一列

        '如果引用区域第一个单元格等于查找的对象,那么将该单元格赋予变量cell;否则使用find方法查找,将找到的单元格赋予变量cell

        If .Cells(1) = 查找值 Then Set Cell = .Cells(1) Else Set Cell = .Find(查找值, LookIn:=xlValues, lookat:=xlWhole)

        If Not Cell Is Nothing Then '如果找到

            Str = Cell.Address   '记录单元格地址

            Do

                i = i 1  '累加变量

                '如果变量等于最后一个参数,那么将查找的单元格右边的值赋予look函数

                If i = 索引号 Then Look = Cell.Offset(0, 列 - 1): Exit Function

                Set Cell = 区域.Find(查找值, Cell, , xlWhole) '查找下一个

            Loop While Cell.Address <> Str

        Else

            Look = '' '如果找不到则直接返回空白

        End If

End Function


本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
一个例子入门VBA自定义Excel函数(多值查找)
vlookup函数
比VLOOKUP函数好用十倍的自定义函数
第一个查找引用函数VLOOKUP的简单应用
让你从菜鸟成为玩转Excel的高手
图文理解vlookup函数怎么用
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服