namedtuple
collections.
namedtuple
(typename, field_names, *, rename=False, defaults=None, module=None)
typename 创建的namedtuple返回的对象类型
field_names 创建的namedtuple每个元素对应的name,不然为啥叫namedtuple呢。这个参数传递的可以是一个列表,一个用空格或者","间隔开的字符串。
rename 如果为True,则对field_names中的关键字和重复的键(官方文档原文为invalid fieldnames,暂时没想到其他可能无效的键)进行重命名,命名方式为对应参数的位置前加一个占位符"_"
defaults 只能是None或者一个iterable(可迭代对象,python中具有__item__或__getitem__方法的对象都可称之为iterable),并且该可迭代对象的元素个数不能超过field_names传递的参数个数,不然会报错;这个参数的作用是在创建namedtuple时,传递的参数数量小于field_names参数数量时,用iterable中的元素来填充不足,补足的方式为从可迭代对象的最右端开始逐一填充到field_names的末端。
moudle 当其值为None的时候,调用.__module__时返回的是__main__
三个namedtuple的方法
_make(iterable) 用已有的一个namedtuple去创建一个新的实例,针对iterable一个方法
_asdict() 返回一个OrderedDict,把field_names和他们的值做一个映射,OrderedDcit同样是collections下的一个特殊字典(有序字典)
_replace(**kwargs) 将已创建的namedtuple指定的field_names对应的值替换,返回替换之后的namedtuple。
两个namedtuple的属性
_fields 返回一个fields_names构成的元组。
_field_defaults 返回含默认值的field_names和其默认值组成的一个字典
将字典转化为namedtuple的方法,使用 ** 运算符
1 from collections import namedtuple 2 ss = namedtuple(‘t‘, ‘a b c‘) 3 d0 = {‘x‘:1, ‘y‘:2, ‘z‘:3} 4 d1 = {‘a‘:1, ‘b‘:2, ‘z‘:3} 5 ss(**d0) 6 #报错,原因是键名和field_names不匹配 7 ss(**d1) 8 #正常输出t(a=1, b=2, c=3)
原文地址:https://www.cnblogs.com/slientbrain/p/10887584.html