Вы не можете использовать ту же реализацию, что и объект результата os.stat () и других. Однако в Python 2.6 появилась новая фабричная функция, которая создает аналогичный тип данных с именем named tuple. Именованный кортеж - это кортеж, слоты которого также могут быть адресованы по имени. В соответствии с документацией именованный кортеж не должен требовать больше памяти, чем обычный кортеж, поскольку у него нет словаря для каждого экземпляра. Заводская функция подписи:
collections.namedtuple(typename, field_names[, verbose])
Первый аргумент задает имя нового типа, второй аргумент - это строка (разделенная пробелами или запятыми), содержащая имена полей, и, наконец, если verbose равен true, функция factory также напечатает сгенерированный класс.
Пример
Предположим, у вас есть кортеж, содержащий имя пользователя и пароль. Для доступа к имени пользователя вы получаете элемент в нулевой позиции, а пароль - в первой позиции:
credential = ('joeuser', 'secret123')
print 'Username:', credential[0]
print 'Password:', credential[1]
В этом коде нет ничего плохого, но кортеж не самодокументирован. Вы должны найти и прочитать документацию о расположении полей в кортеже. Вот где именной кортеж может прийти на помощь. Мы можем перекодировать предыдущий пример следующим образом:
import collections
# Create a new sub-tuple named Credential
Credential = collections.namedtuple('Credential', 'username, password')
credential = Credential(username='joeuser', password='secret123')
print 'Username:', credential.username
print 'Password:', credential.password
Если вас интересует, как выглядит код для вновь созданного типа Credential, вы можете добавить verbose = True к списку аргументов при создании типа, в этом конкретном случае мы получим следующий вывод:
import collections
Credential = collections.namedtuple('Credential', 'username, password', verbose=True)
class Credential(tuple):
'Credential(username, password)'
__slots__ = ()
_fields = ('username', 'password')
def __new__(_cls, username, password):
return _tuple.__new__(_cls, (username, password))
@classmethod
def _make(cls, iterable, new=tuple.__new__, len=len):
'Make a new Credential object from a sequence or iterable'
result = new(cls, iterable)
if len(result) != 2:
raise TypeError('Expected 2 arguments, got %d' % len(result))
return result
def __repr__(self):
return 'Credential(username=%r, password=%r)' % self
def _asdict(t):
'Return a new dict which maps field names to their values'
return {'username': t[0], 'password': t[1]}
def _replace(_self, **kwds):
'Return a new Credential object replacing specified fields with new values'
result = _self._make(map(kwds.pop, ('username', 'password'), _self))
if kwds:
raise ValueError('Got unexpected field names: %r' % kwds.keys())
return result
def __getnewargs__(self):
return tuple(self)
username = _property(_itemgetter(0))
password = _property(_itemgetter(1))
Именованный кортеж не только предоставляет доступ к полям по имени, но также содержит вспомогательные функции, такие как функция _make (), которая помогает создавать экземпляр Credential из последовательности или итерации. Например:
cred_tuple = ('joeuser', 'secret123')
credential = Credential._make(cred_tuple)
Документация библиотеки python для namedtuple содержит больше информации и примеров кода, поэтому я советую вам взглянуть.