Python中存储系列数据,比较常见的数据类型有list,除此之外,还有tuple数据类型。因为元组的局限性:不能为元组内部的数据进行命名,所以往往我们并不知道一个元组所要表达的意义,所以在这里引入了 collections.namedtuple 这个工厂函数,来构造一个带字段名的元组。相比与list,tuple中的元素不可修改,在映射中可以当键使用。tuple元组的item只能通过index访问,collections模块的namedtuple子类不仅可以使用item的index访问item,还可以通过item的name进行访问
用法
def namedtuple(typename, field_names, *, verbose=False, rename=False,
module=None):
- typename: 元组名称
- field_names : 元组中元素的名称
- rename: 如果元素名称中包含python关键字, 必须设置rename=True
示例:
from collections import namedtuple
User = namedtuple('User', ['name', 'age', 'gender'])
u = User('fentiao', 13, 'male') ###此处的User为变量名 并赋值
print(u)
print(u.name,u.age,u.gender)
print(u[0],u[1],u[2]) ##通过索引查找
u = User._make(['westos',20,'male']) ##重新创造一个
print(u.name,u.age,u.gender)
u= u._replace(name = 'hello') ##替换某个元素
print(u.name,u.age,u.gender)