Nie można używać tego samego wdrożenia jako przedmiot wynikowej os.stat() i innych. Jednak Python 2.6 ma nową funkcję fabryczną, która tworzy podobny typ danych o nazwie nazwanej krotce. Nazwana krotka jest krotką, której gniazda mogą być również adresowane po imieniu. Nazwana krotka nie powinna wymagać więcej pamięci, zgodnie z dokumentacją, niż zwykłej krotki, ponieważ nie mają one słownika dla danej instancji. Podpis funkcja fabryczne to:
collections.namedtuple(typename, field_names[, verbose])
Pierwszy argument określa nazwę nowego typu, drugi argument jest ciągiem znaków (spacja lub oddzielone przecinkami) zawierający nazwy pól i wreszcie, jeśli gadatliwy jest prawdziwe, funkcja fabryczna wydrukuje również wygenerowaną klasę.
Przykład
Załóżmy, że masz krotki zawierający nazwę użytkownika i hasło.Aby uzyskać dostęp do nazwy użytkownika masz pozycja w pozycji zerowej, a hasło jest dostępne w jednej pozycji:
credential = ('joeuser', 'secret123')
print 'Username:', credential[0]
print 'Password:', credential[1]
Nie ma nic złego z tego kodu, ale krotka nie jest samodokumentujące. Musisz znaleźć i przeczytać dokumentację dotyczącą pozycjonowania pól w krotce. To tutaj nazwana krotka może przyjść z pomocą. Możemy przekodować poprzedni przykład w następujący sposób:
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
Jeśli jesteś zainteresowany, co kod wygląda dla nowo utworzonego poświadczeń typu można dodać gadatliwy = True do listy argumentów podczas tworzenia typu, w tym szczególny przypadek otrzymujemy następujący wynik:
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))
Podany krotka nie tylko zapewniają dostęp do pól przez nazwę, ale zawiera również funkcje pomocnicze, takie jak funkcja _make(), która pomaga tworząc poświadczeń wystąpienie z sekwencji lub iterable. Na przykład:
cred_tuple = ('joeuser', 'secret123')
credential = Credential._make(cred_tuple)
Dokumentacja biblioteki Pythona do namedtuple ma więcej informacji i przykładów kodu, więc sugerujemy take a peek.