Excel精英培训网

 找回密码
 注册
数据透视表40+个常用小技巧,让你一次学会!
12
返回列表 发新帖
楼主: excelpxfans001

[已解决]自定函数返回相同的个数及实际数。

[复制链接]
发表于 2016-3-5 17:35 | 显示全部楼层
'限制条件:
'1)各参数都是一行区域
'2)各参数包含的元素个数,都相同
Function SameNumber(ParamArray A() As Variant)
    Dim B, C, D, i%, j%, str$

    SameNumber = 0
    C = A(0): D = C
    ReDim C(1 To 1, 1 To UBound(C, 2))

    '1)求个数。遍历每个子区,只有第1个子区是直接赋值给C,其它子区是和C比较。
    For i = 0 To UBound(A)
        B = A(i)
        For j = LBound(C, 2) To UBound(C, 2)
            C(1, j) = IIf(i, C(1, j) = B(1, j), B(1, j))
        Next j
    Next i

    '只有为True的位置上,是各子区都相同的情况。
    For j = LBound(C, 2) To UBound(C, 2)
        If C(1, j) Then SameNumber = SameNumber + 1
    Next j

    '2)求实际数字的列表。根据位置,找出对应的值。
    For j = LBound(C, 2) To UBound(C, 2)
        If C(1, j) Then str = str & "," & D(1, j)
    Next j

    '3)返回结果
    If str <> "" Then str = "(" & Mid(str, 2) & ")"
    SameNumber = SameNumber & str
End Function

求相同6.rar (10.25 KB, 下载次数: 5)
excel精英培训的微信平台,每天都会发送excel学习教程和资料。扫一扫明天就可以收到新教程
回复

使用道具 举报

 楼主| 发表于 2016-3-5 17:52 | 显示全部楼层
爱疯 发表于 2016-3-5 17:35
'限制条件:
'1)各参数都是一行区域
'2)各参数包含的元素个数,都相同

是的,左上角的提示。不过让它也没关系 。有结果就可以了。谢谢版主的出手。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|Archiver|Excel精英培训 ( 豫ICP备11015029号 )

GMT+8, 2024-5-5 02:43 , Processed in 0.399054 second(s), 10 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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