问题:希望通过名称来访问元素,减少结构中对位置的依赖性
解决方案:使用命名元组collections.namedtuple()。它是一个工厂方法,返回的是python中标准元组类型的子类,提供给它一个类型名称以及相应的字段名称,它就返回一个可实例化的类,为你以定义好的字段名称传入值等。
命名元组的主要作用在于将代码同它所控制的元素位置间进行解耦
>>> from collections import namedtuple >>> Sub=namedtuple(‘Subscriber‘,[‘addr‘,‘joined‘]) >>> subscriber=Sub(‘lucy@example.com‘,‘2016-8-7‘) >>> subscriber Subscriber(addr=‘lucy@example.com‘, joined=‘2016-8-7‘) >>> subscriber.addr ‘lucy@example.com‘ >>> subscriber.joined ‘2016-8-7‘
namedtuple的实例与普通的元组是可互换的,而且支持所有普通元组所支持的操作,例如索引和分解(unpacking).
>>> len(subscriber) 2 >>> addr,joined=subscriber >>> addr ‘lucy@example.com‘ >>> joined ‘2016-8-7‘ >>>
【python cookbook】【数据结构与算法】18.将名称映射到序列的元素中
原文:http://www.cnblogs.com/apple2016/p/5747656.html