Наследование статических переменных в Python - PullRequest
12 голосов
/ 13 августа 2010

Я пишу скрипты Python для Blender для проекта, но я довольно плохо знаком с языком.Что-то меня смущает, это использование статических переменных.Вот фрагмент кода, над которым я сейчас работаю:

class panelToggle(bpy.types.Operator):
    active = False

    def invoke(self, context, event):
        self.active = not self.active
        return{'FINISHED'}

class OBJECT_OT_openConstraintPanel(panelToggle):
    bl_label = "openConstraintPanel"
    bl_idname = "openConstraintPanel"

Идея состоит в том, что второй класс должен наследовать переменную active и метод invoke отпервый, так что вызов OBJECT_OT_openConstraintPanel.invoke () изменяет OBJECT_OT_openConstraintPanel.active.Однако использование self , как я делал выше, не будет работать, равно как и использование panelToggle .Есть идеи, как мне это сделать?

Ответы [ 2 ]

21 голосов
/ 13 августа 2010

используйте type(self) для доступа к атрибутам класса

>>> class A(object):
 var  = 2
 def write(self):
  print type(self).var
>>> class B(A):
 pass
>>> B().write()
2
>>> B.var = 3
>>> B().write()
3
>>> A().write()
2
4 голосов
/ 13 августа 2010

Вы можете получить доступ к active через класс, к которому он принадлежит:

if panelToggle.active:
    # do something

Если вы хотите получить доступ к переменной class из метода, вы можете написать:

def am_i_active(self):
    """ This method will access the right *class* variable by
        looking at its own class type first.
    """
    if self.__class__.active:
        print 'Yes, sir!'
    else:
        print 'Nope.'

Рабочий пример можно найти здесь: http://gist.github.com/522619


Переменная self (именуемая self по соглашению) - это текущий экземпляр класса, неявно переданный, ноточно получено.

class A(object):

    answer = 42

    def add(self, a, b):
        """ ``self`` is received explicitely. """
        return A.answer + a + b

a = A()

print a.add(1, 2) # ``The instance -- ``a`` -- is passed implicitely.``
# => 45

print a.answer 
# => print 42
...