C'est parfaitement possible, mais pas très significatif. Méditez la classe suivante:
class MyClass:
# Normal method:
def normal_method(self, data):
print "Normal method called with instance %s and data %s" % (self, data)
@classmethod
def class_method(cls, data):
print "Class method called with class %s and data %s" % (cls, data)
@staticmethod
def static_method(data):
print "Static method called with data %s" % (data)
De toute évidence, nous pouvons appeler cela de la manière attendus:
>>> instance = MyClass()
>>> instance.normal_method("Success!")
Normal method called with instance <__main__.MyClass instance at 0xb7d26bcc> and data Success!
>>> instance.class_method("Success!")
Class method called with class __main__.MyClass and data Success!
>>> instance.static_method("Success!")
Static method called with data Success!
Mais aussi considérer ceci:
>>> MyClass.normal_method(instance, "Success!")
Normal method called with instance <__main__.MyClass instance at 0xb7d26bcc> and data Success!
La syntaxe instance.normal_method()
est à peu près juste un "raccourci" pour MyClass.normal_method(instance)
. C'est pourquoi il y a ce paramètre "self" dans les méthodes, pour passer en soi. Le nom de soi n'est pas magique, vous pouvez l'appeler comme vous voulez.
La même astuce est parfaitement possible avec une méthode statique. Vous pouvez appeler la méthode normale avec une instance comme premier paramètre, comme ceci:
@staticmethod
def a_cool_static_method(instance, data):
print "Cool method called with instance %s and data %s" % (instance, data)
MyClass.normal_method(instance, data)
MyClass.class_method(data)
MyClass.static_method(data)
>>> instance.a_cool_static_method(instance, "So Cool!")
Cool method called with instance <__main__.MyClass instance at 0xb7d26bcc> and data So Cool!
Normal method called with instance <__main__.MyClass instance at 0xb7d26bcc> and data So Cool!
Class method called with class __main__.MyClass and data So Cool!
Static method called with data So Cool!
Donc, la réponse est oui, vous pouvez cal méthodes non statiques de méthodes statiques. Mais seulement si vous pouvez passer dans une instance en tant que premier paramètre. Vous devez donc le générer à partir de la méthode statique (et dans ce cas vous êtes probablement mieux avec une méthode de classe) ou le transmettre. Mais si vous passez dans l'instance, vous pouvez généralement en faire une méthode normale.
Alors vous pouvez, mais c'est plutôt inutile.
Et cela pose alors la question: Pourquoi voulez-vous?
Ned Batchelder @ Pourquoi ne pas appeler l'électricité statique? Quelle est la syntaxe? J'ai "NameError: nom global 'my_static_method' n'est pas défini" jusqu'à présent. – legesh
Même syntaxe que toutes les autres méthodes: object_or_class.méthode (paramètres) –