Python学习笔记之namedtuple()

namedtuple()是产生具有命名字段的元组的工厂函数。命名元组赋予元组中每个位置的意义,并更易读、代码更易维护。它们可以使用在通常元组使用的地方,并添加了通过名称访问字段的能力,而不是位置索引。

namedtuple()调用方式如下:

collections.namedtuple(typename, field_names, *, verbose=False, rename=False, module=None)

返回一个新类,名为typename,它是元组tuple的子类。它的特性与tuple类似,是可索引可迭代的。

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)

Python学习笔记之namedtuple()_第1张图片






参考:

1. collections — Container datatypes

2. Python的namedtuple使用详解

你可能感兴趣的:(Python)