collections模块学习之namedtuple

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)

猜你喜欢

转载自www.cnblogs.com/slientbrain/p/10887584.html