带有VBA后期绑定+跳过win注册的Python COM服务器(无管理员权限)

时间:2016-08-26 23:28:56

标签: python vba com winreg

我试图在VBA中import Python代码。

以下代码有效但需要管理员权限。有没有办法绕过赢得注册的需要(假设我只是没有管理员权限),但保持“迟到”等等。行为(不想在每次编译新内容时使用工具>>参考)

class ProofOfConcept(object):
    def __init__(self):
        self.output = []

    def GetData(self):
        with open('C:\Users\MyPath\Documents\COMs\SourceData.txt') as FileObj:
            for line in FileObj:
                self.output.append(line)
            return self.output

class COMProofOfConcept(object):
    _reg_clsid_ = "{D25A5B2A-9544-4C07-8077-DB3611BE63E7}"
    _reg_progid_= 'RiskTools.ProofOfConcept'
    _public_methods_ = ['GetData']

def __init__(self):
    self.__ProofOfConcept = ProofOfConcept()

def GetData(self):
    return self.__ProofOfConcept.GetData()

if __name__=='__main__':
    print "Registering COM server..."
    import win32com.server.register
    win32com.server.register.UseCommandLine(COMProofOfConcept)

调用它的VBA代码:

Sub TestProofOfConcept()
    Set PoF = CreateObject("RiskTools.ProofOfConcept")
    x = PoF.GetData()
    MsgBox x(0)
End Sub

1 个答案:

答案 0 :(得分:3)

简而言之,没有。 VBA运行时基本上使用了CoGetClassObject COM API - CreateObject()函数本质上只是它的一个薄包装(它调用CLSIDFromString来首先从参数中找到CLSID)。这两个函数都要求注册类。