namedtuple()是产生具有命名字段的元组的工厂函数。命名元组赋予元组中每个位置的意义,并更易读、代码更易维护。它们可以使用在通常元组使用的地方,并添加了通过名称访问字段的能力,而不是位置索引。
namedtuple()调用方式如下:
collections.namedtuple(typename, field_names, *, verbose=False, rename=False, module=None)
field_names的格式通常为字符串序列,如['x', 'y']
,也可以是一个单一的字符串,每个字段以空格或逗号分隔,如 'x y'
or 'x, y'。
如果rename=True,无效的字段名将被自动更换为位置名称,如下所示:
['abc', 'def', 'ghi', 'abc']
中无效的字段名为关键字'def'与重复字段名'abc',均视为无效,所以讲自动更换为如下形式:
['abc', '_1', 'ghi', '_3']
。
具体示例如下:
>>> # Basic example
>>> Point = namedtuple('Point', ['x', 'y'])
>>> p = Point(11, y=22) # instantiate with positional or keyword arguments
>>> p[0] + p[1] # indexable like the plain tuple (11, 22)
33
>>> x, y = p # unpack like a regular tuple
>>> x, y
(11, 22)
>>> p.x + p.y # fields also accessible by name
33
>>> p # readable __repr__ with a name=value style
Point(x=11, y=22)
参考:
1. collections — Container datatypes
2. Python的namedtuple使用详解