ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
楼主: YZC51

[讨论] 自定义函数--提取单元格内多个被分开的数字

  [复制链接]

TA的精华主题

TA的得分主题

 楼主| 发表于 2020-3-13 11:42 | 显示全部楼层
WYS67 发表于 2020-3-13 04:09
Function 查找行列(sr, rng As Range, Optional x As Integer, Optional y As Integer)
      '0、默认 ...

您好!请参考391楼!

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2020-3-13 11:52 | 显示全部楼层
YZC51 发表于 2020-3-13 11:42
您好!请参考391楼!

1.gif

老师请看截图:1.因为没有对应的第4个字符,所以返回结果为空白!所以,应该默认为精确查找;比如A列没有5,但=查找行列($C$5,$A$5:$A$100,$D5,E$4),却显示$A$15,而$A$15是45;同样A列里本没有3,但C5指定为3后,却显示有5个3,实际上A12是31,A13是36,A14是43,A27是73,A40是113......这个问题还没有解决

2.找不到数据时,已不再显示#VALUE!  ,这个问题已解决。

TA的精华主题

TA的得分主题

 楼主| 发表于 2020-3-13 12:39 | 显示全部楼层
WYS67 发表于 2020-3-13 11:52
老师请看截图:1.因为没有对应的第4个字符,所以返回结果为空白!所以,应该默认为精确查找;比如A列 ...

试试
'        If InStr(s, sr) Then
修改为
        If s = sr Then

评分

2

查看全部评分

TA的精华主题

TA的得分主题

发表于 2020-3-13 12:52 | 显示全部楼层
YZC51 发表于 2020-3-13 12:39
试试
'        If InStr(s, sr) Then
修改为

这次算是 精确查找了!功能很强大!谢谢老师!

TA的精华主题

TA的得分主题

 楼主| 发表于 2020-3-13 12:55 | 显示全部楼层
玉阳山人 发表于 2020-3-13 12:52
这次算是 精确查找了!功能很强大!谢谢老师!

不客气,解决问题就好!

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2020-3-13 13:15 | 显示全部楼层
YZC51 发表于 2020-3-13 12:55
不客气,解决问题就好!

Function 查找行列(sr, rng As Range, Optional x As Integer, Optional y As Integer)
   '  y=  0、默认,单元格绝对引用;1、查找列;2、查找行;3、单元格相对引用
    Dim d As Object, arr, brr, v, xd, n%
    arr = rng
    Set d = CreateObject("Scripting.Dictionary")
    For Each s In arr
        d(i) = ""
    Next
    brr = d.keys
    n = UBound(brr)
    For Each s In rng
        If s = sr Then '为精确查找
         'If InStr(s, sr) Then 为模糊查找
            n = n + 1
            ReDim Preserve brr(0 To n)
            brr(n) = s.Address
        End If
    Next
    If Abs(x) > UBound(brr) Then 查找行列 = "": Exit Function
    If x < 0 Then x = UBound(brr) + x + 1
    v = Split(brr(x), "$")
    查找行列 = Choose(y + 1, brr(x), v(1), v(2), v(1) & v(2))
End Function

老师:怎样编写 当第三参数【查找顺序】为空时,让计算结果返回返回空白


TA的精华主题

TA的得分主题

 楼主| 发表于 2020-3-13 13:31 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
试试
Function 查找行列(sr, rng As Range, Optional x As Integer, Optional y As Integer)
   If len(x) =0 Then 查找行列 = "": Exit Function

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2020-3-13 14:07 | 显示全部楼层
YZC51 发表于 2020-3-13 13:31
试试
Function 查找行列(sr, rng As Range, Optional x As Integer, Optional y As Integer)
   If len( ...

改成  If len(x) =0 Then 查找行列 = "": Exit Function  后,仍然显示#VALUE!错误。

这个问题还不算是太重要,我只是跟您学习处理意外情况的方法和技巧。

我把函数名称查找行列改成CZWZ【输入时方便!】后,发现当没有符合条件的数据时,原先的空白都变成了0.这个问题怎么解决?

TA的精华主题

TA的得分主题

 楼主| 发表于 2020-3-13 14:26 | 显示全部楼层
WYS67 发表于 2020-3-13 14:07
改成  If len(x) =0 Then 查找行列 = "": Exit Function  后,仍然显示#VALUE!错误。

这个问题还不算 ...

贴出代码看看才能知道的

评分

2

查看全部评分

TA的精华主题

TA的得分主题

发表于 2020-3-13 14:36 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
YZC51 发表于 2020-3-13 14:26
贴出代码看看才能知道的

1.gif

Function CZWZ(sr, rng As Range, Optional x As Integer, Optional y As Integer)
   If Len(x) = 0 Then 查找行列 = "": Exit Function
   '  y=  0、默认,单元格绝对引用;1、查找列;2、查找行;3、单元格相对引用
    Dim d As Object, arr, brr, v, xd, n%
    arr = rng
    Set d = CreateObject("Scripting.Dictionary")
    For Each s In arr
        d(i) = ""
    Next
    brr = d.keys
    n = UBound(brr)
    For Each s In rng
        If s = sr Then '为精确查找
        'If InStr(s, sr) Then 为模糊查找
            n = n + 1
            ReDim Preserve brr(0 To n)
            brr(n) = s.Address
        End If
    Next
    If Abs(x) > UBound(brr) Then 查找行列 = "": Exit Function
    If x < 0 Then x = UBound(brr) + x + 1
    v = Split(brr(x), "$")
    CZWZ = Choose(y + 1, brr(x), v(1), v(2), v(1) & v(2))
End Function


只是把查找行列改成了CZWZ,其它地方都没动。
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-12-25 14:29 , Processed in 0.049280 second(s), 8 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表