39

我正在编写一系列文本菜单。使用下面的类和子类,它运行没有问题。但是我正在审查我的编码,我想知道....我没有def __init__(self)在课堂上使用可以吗?我是否应该将数据成员放在def __init__(Self):诸如self.images =(),self.options =()之类的地方?如果我这样做了,那么我就不能使用 abc 模块进行约束,对吗?

class BaseMenu(object):
    __metaclass__ = abc.ABCMeta

    @abc.abstractproperty
    def options(self):
        pass

    @abc.abstractproperty
    def menu_name(self):
        pass

    def display(self):
        header = "FooBar YO"
        term = getTerminalSize()
        #sys.stdout.write("\x1b[2J\x1b[H")
        print header.center(term, '*')
        print self.menu_name.center(term, '+')
        print "Please choose which option:"
        for i in self.options:
            print(
                str(self.options.index(i)+1) + ") "
                + i.__name__
            )
        value = int(raw_input("Please Choose: ")) - 1

        self.options[value](self)

class Servers(BaseMenu):

    menu_name = "Servers"
    images = ()
    foo = ()

    def get_images(self):
        if not self.images:
            self.images = list_images.get_images()
        for img in self.images:
            print (
                str(self.images.index(img)+1) + ") "
                + "Name: %s\n    ID: %s" %
                (img.name, img.id)
                )

    def get_foo(self):
        if not self.foo:
            self.foo = list_list.get_list()
        for list in self.foo:
            print "Name:", list.name
            print "  ID:", list.id
            print

    def create_servers(self):
         create_server.create(self)

    options = (
        get_images,
        get_foo,
        create_servers
        )
4

2 回答 2

29

您的代码非常好。你不必方法__init__

__init__即使使用 ABC,您仍然可以使用。ABC 元测试的所有内容是名称是否已定义。images在do 中设置__init__需要您定义一个类属性,但您可以None首先将其设置为:

class Servers(BaseMenu):

    menu_name = "Servers"
    images = None
    foo = None

    def __init__(self):
        self.images = list_images.get_images()
        self.foo = list_list.get_list()

现在您可以在 ABC 上设置要求images抽象属性可用的约束;images = Noneclass 属性将满足该约束。

于 2013-06-26T22:14:17.493 回答
8

你的代码很好。下面的示例显示了一个最小示例。您仍然可以实例化未指定__init__方法的类。忽略它不会使你的类抽象。

class A:
    def a(self, a):
        print(a)
ob = A()
ob.a("Hello World")
于 2018-09-06T14:04:12.493 回答