Python usando o método da classe derivada na classe pai?
-
21-09-2019 - |
Pergunta
Posso forçar uma classe pai a chamar a versão de uma função de uma classe derivada?
class Base(object):
attr1 = ''
attr2 = ''
def virtual(self):
pass # doesn't do anything in the parent class
def func(self):
print "%s, %s" % (self.attr1, self.attr2)
self.virtual()
e uma aula que deriva dela
class Derived(Base):
attr1 = 'I am in class Derived'
attr2 = 'blah blah'
def virtual(self):
# do stuff...
# do stuff...
Limpando a imprecisão:
d = Derived()
d.func() # calls self.virtual() which is Base::virtual(),
# and I need it to be Derived::virtual()
Solução
Se você instanciar um Derived
(dizer d = Derived()
), a .virtual
Isso é chamado por d.func()
é Derived.virtual
. Se não houver nenhuma instância de Derived
Envolvido, então não há não adequado self
por Derived.virtual
E então é claro que é impossível chamá -lo.
Outras dicas
Não é impossível - existe uma maneira de contornar isso, e você não precisa passar na função ou algo assim. Estou trabalhando em um projeto, onde surgiu esse problema exato. Aqui está a solução:
class Base(): # no need to explicitly derive object for it to work
attr1 = 'I am in class Base'
attr2 = 'halb halb'
def virtual(self):
print "Base's Method"
def func(self):
print "%s, %s" % (self.attr1, self.attr2)
self.virtual()
class Derived(Base):
attr1 = 'I am in class Derived'
attr2 = 'blah blah'
def __init__(self):
# only way I've found so far is to edit the dict like this
Base.__dict__['_Base_virtual'] = self.virtual
def virtual(self):
print "Derived's Method"
if __name__ == '__main__':
d = Derived()
d.func()
Ok, acabei passando na instância de virtual () que eu precisava func
class Base(object):
attr1 = ''
attr2 = ''
def __init__(self):
pass
def virtual(self):
pass
def func(self, cb):
print "%s, %s" % (self.attr1, self.attr2)
cb()
class Derived(Base):
attr1 = 'I am in class Derived'
attr2 = 'blah blah'
def virtual(self):
# do stuff...
# do stuff...
d = Derived()
d.func(d.virtual)
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow