web-dev-qa-db-fra.com

Imprimer toutes les propriétés d'une classe Python

J'ai une classe Animal avec plusieurs propriétés comme:


class Animal(object):
    def __init__(self):
        self.legs = 2
        self.name = 'Dog'
        self.color= 'Spotted'
        self.smell= 'Alot'
        self.age  = 10
        self.kids = 0
        #many more...

Je veux maintenant imprimer toutes ces propriétés dans un fichier texte. La façon dont je le fais maintenant est la suivante:


animal=Animal()
output = 'legs:%d, name:%s, color:%s, smell:%s, age:%d, kids:%d' % (animal.legs, animal.name, animal.color, animal.smell, animal.age, animal.kids,)

Y a-t-il une meilleure façon de faire cela en Pythonic?

143
Idr

Dans ce cas simple, vous pouvez utiliser vars() :

an = Animal()
attrs = vars(an)
# {'kids': 0, 'name': 'Dog', 'color': 'Spotted', 'age': 10, 'legs': 2, 'smell': 'Alot'}
# now dump this in some way or another
print ', '.join("%s: %s" % item for item in attrs.items())

Si vous souhaitez stocker des objets Python sur le disque, vous devez consulter shelve - Python persistance des objets .

260
Jochen Ritzel

Une autre méthode consiste à appeler la fonction dir() (voir https://docs.python.org/2/library/functions.html#dir ).

a = Animal()
dir(a)   
>>>
['__class__', '__delattr__', '__dict__', '__doc__', '__format__', '__getattribute__',
 '__hash__', '__init__', '__module__', '__new__', '__reduce__', '__reduce_ex__', 
 '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', 
 '__weakref__', 'age', 'color', 'kids', 'legs', 'name', 'smell']

Notez que dir() essaie d’atteindre tout attribut possible.

Ensuite, vous pouvez accéder aux attributs, par exemple. en filtrant avec double soulignement:

attributes = [attr for attr in dir(a) 
              if not attr.startswith('__')]

Ceci est juste un exemple de ce qu'il est possible de faire avec dir() , veuillez vérifier les autres réponses pour connaître la bonne façon de procéder.

67
Zaur Nasibov

Peut-être que vous cherchez quelque chose comme ça?

    >>> class MyTest:
        def __init__ (self):
            self.value = 3
    >>> myobj = MyTest()
    >>> myobj.__dict__
    {'value': 3}
54
Urjit

essayez ppretty :

from ppretty import ppretty


class Animal(object):
    def __init__(self):
        self.legs = 2
        self.name = 'Dog'
        self.color= 'Spotted'
        self.smell= 'Alot'
        self.age  = 10
        self.kids = 0


print ppretty(Animal(), seq_length=10)

Sortie:

__main__.Animal(age = 10, color = 'Spotted', kids = 0, legs = 2, name = 'Dog', smell = 'Alot')
7
Symon

Voici le code complet. Le résultat est exactement ce que vous voulez.

class Animal(object):
    def __init__(self):
        self.legs = 2
        self.name = 'Dog'
        self.color= 'Spotted'
        self.smell= 'Alot'
        self.age  = 10
        self.kids = 0

if __== '__main__':
    animal = Animal()
    temp = vars(animal)
    for item in temp:
        print item , ' : ' , temp[item]
        #print item , ' : ', temp[item] ,
6
JaeWoo So

Essayez juste beeprint

ça affiche quelque chose comme ça:

instance(Animal):
    legs: 2,
    name: 'Dog',
    color: 'Spotted',
    smell: 'Alot',
    age: 10,
    kids: 0,

Je pense que c'est exactement ce dont vous avez besoin.

3
Anyany Pan