无法掌握:在 python 中制作一个简单的单例(对于 mongodb 管理器)

Arn*_*Ben 1 python singleton class mongodb

我已经阅读了单例的各种主要示例,但我在制作我想要的东西时遇到了困难。我的主要灵感来自这个例子:

class OnlyOne:
    class __OnlyOne:
        def __init__(self, arg):
            self.val = arg

        def __str__(self):
            return repr(self) + self.val
    instance = None
    def __init__(self, arg):
        if not OnlyOne.instance:
            OnlyOne.instance = OnlyOne.__OnlyOne(arg)
        else:
            OnlyOne.instance.val = arg
    def __getattr__(self, name):
        return getattr(self.instance, name)
Run Code Online (Sandbox Code Playgroud)

但我不需要像 getattr 这样的东西,这是到目前为止我的代码:

class MongoManager:
    class __MongoManager:
        def __init__(self):
            # Initialise client
            self.client = pymongo.MongoClient('localhost', 27017)

    __instance = None

    def __init__(self):
        if not MongoManager.__instance:
            MongoManager.__instance = MongoManager.__MongoManager()
Run Code Online (Sandbox Code Playgroud)

我想要的只是在键入时获取变量clientMongoManager.client,但出现错误AttributeError: 'MongoManager' object has no attribute 'client'。我想我可以尝试使用 getattr 并检查类似的内容,if arg == "client"但感觉很脏,我确信有一个正确的方法可以做到这一点。

Pra*_*dhi 5

尝试这个:

class MongoManager:
     __instance = None
     @staticmethod 
     def getInstance():
         if MongoManager.__instance == None:
             MongoManager()
         return MongoManager.__instance
     def __init__(self):
        if MongoManager.__instance != None:
            raise Exception("This class is a singleton!")
        else:
            MongoManager.__instance = pymongo.MongoClient('localhost', 27017)
Run Code Online (Sandbox Code Playgroud)

您可以通过调用获取此类的实例MongoManager.getInstance()

我们在这里做什么?我们有一个类变量__instance,当创建该类的对象时,我们正在初始化它。现在,当我们调用getInstance()存储在其中的实例时__instance,将传递该实例,而不是创建新实例。