Вот некоторый (упрощенный) код для того, что я пытаюсь сделать:
class a:
pass
class b:
def printSelf(self):
print self
instOfA = a()
instOfB = b()
instOfA.printSelf = instOfB.printSelf
instOfA.printSelf()
<__main__.b instance at 0x0295D238>
Когда я вызываю instOfA.printSelf (), он печатает self как instOfB.
Но я хочу, чтобы self было instOfA, когда я вызываю instOfA.printSelf (), и instOfB, когда я вызываю instOfB.printSelf ()
Как мне поступить так, не определяя вручную printSelf в классе a?
Для тех, кто интересуется, почему я бы даже хотел сделать что-то подобное, вот более длинный пример:
#Acts as a template for aInstance. I would have several aInstances that have common rules, which are defined by an instance of the aDefinition class (though I'd have multiple rule sets too)
class aDefinitionClass:
def setInput(self, val):
self.inputStr = val
def checkInputByLength(self):
return len(self.inputStr) < 5
def checkInputByCase(self):
return self.inputStr == self.inputStr.upper()
checkInput = checkInputByLength
class aInstance(aDefinition):
inputStr = ""
def __init__(self, ruleDefinition):
self.checkInput = ruleDefinition.checkInput
aDef = aDefinitionClass()
aDef.checkInput = aDef.checkInputByCase #Changing one of the rules.
aInst = aInstance(aDef)
aInst.setInput("ABC")
aInst.checkInput()
AttributeError: aDefinitionClass instance has no attribute 'inputStr'
Я понимаю, что это немного необычно, но я не мог придумать другой способ сделать это. Я эффективно пытаюсь создать подкласс экземпляра. Это выглядело бы примерно так, если бы Python это разрешил:
class aInstance(aDef):
inputStr = ""