Печать всех свойств класса Python

У меня есть класс Animal с несколькими свойствами вроде:


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...

Теперь я хочу напечатать все эти свойства в текстовом файле. Уродливый способ, который я делаю сейчас, выглядит следующим образом:


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,)

Есть ли лучший способ Pythonic для этого?

Ответ 1

В этом простом случае вы можете использовать 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())

Если вы хотите хранить объекты Python на диске, вы должны посмотреть shelve - стойкость к объекту Python.

Ответ 2

Другим способом является вызов функции dir() (см. 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']

Обратите внимание, что dir() пытается достичь любого атрибута, который можно достичь.

Затем вы можете получить доступ к атрибутам, например. путем фильтрации с двойными символами подчеркивания:

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

Это просто пример того, что можно сделать с dir(), пожалуйста, проверьте другие ответы для действительно приятных и питонический путь:)

Ответ 3

Возможно, вы ищете что-то вроде этого?

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

Ответ 4

попробуйте 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)

Вывод:

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

Ответ 5

Вот полный код. Результат - именно то, что вы хотите.

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 __name__ == '__main__':
    animal = Animal()
    temp = vars(animal)
    for item in temp:
        print item , ' : ' , temp[item]
        #print item , ' : ', temp[item] ,

Ответ 6

Просто попробуйте beeprint

он печатает что-то вроде этого:

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

Я думаю, это именно то, что вам нужно.