Excel精英培训网

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

[已解决]怎样导出对象的属性和方法

[复制链接]
发表于 2010-9-17 09:37 | 显示全部楼层

经过进一步测试,有个AttributeMask属性是表示属性方法的类型

0为公有属性或方法,64是事件以及隐藏的某些对象集合,1应该是私有的,其余的不明

'自定义函数获取对象属性和方法。许多隐藏的属性和方法也出来了。
Function GetAllPros(Target As Object)
    Dim ArrJG()
    Dim oTLB As InterfaceInfo
    Set oTLB = TLI.InterfaceInfoFromObject(Target)
    '定义结果数组
    ReDim ArrJG(1 To oTLB.Members.Count, 1 To 2)
    '获取各属性
    For i = 1 To oTLB.Members.Count
        Select Case oTLB.Members(i).InvokeKind
        Case INVOKE_CONST
            ArrJG(i, 1) = "常数:" & oTLB.Members(i).Name
        Case INVOKE_EVENTFUNC
            ArrJG(i, 1) = "事件:" & oTLB.Members(i).Name
        Case INVOKE_FUNC
            ArrJG(i, 1) = "方法:" & oTLB.Members(i).Name
        Case INVOKE_PROPERTYGET
            ArrJG(i, 1) = "属性(Get):" & oTLB.Members(i).Name
        Case INVOKE_PROPERTYPUT
            ArrJG(i, 1) = "属性(Let):" & oTLB.Members(i).Name
        Case INVOKE_PROPERTYPUTREF
            ArrJG(i, 1) = "属性(Set):" & oTLB.Members(i).Name
        Case INVOKE_UNKNOWN
            ArrJG(i, 1) = "未知:" & oTLB.Members(i).Name
        End Select
        ArrJG(i, 2) = oTLB.Members(i).AttributeMask
    Next i
    '返回结果数组
    GetAllPros = ArrJG
End Function

Sub 测试()
    Dim Arr()
    Arr = GetAllPros(Sheet1)
    Range("A1").Resize(UBound(Arr), 2) = Arr
End Sub

回复

使用道具 举报

发表于 2010-9-17 09:38 | 显示全部楼层
回复

使用道具 举报

 楼主| 发表于 2010-9-17 10:03 | 显示全部楼层

谢谢阿木!

看不懂的,慢慢再看

[em04]
回复

使用道具 举报

发表于 2012-1-28 19:59 | 显示全部楼层
煩請指教如何解決此錯誤 謝謝

編譯錯誤:
使用者自訂型態尚未定義

Dim oTLB As InterfaceInfo
回复

使用道具 举报

发表于 2012-2-27 11:10 | 显示全部楼层
很困难吗?                        
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-3-29 03:56 , Processed in 0.251875 second(s), 9 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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