Python: collections.nametuple()--映射名称到序列元素

问题:  通过下标访问列表或者元组中元素

answer: collections.namedtuple()通过使用元组对象来解决这个问题

这个函数实际上是一个返回Python中标准元组类型子类的一个工厂方法,需要传递一个类型名和字段给它,然后它返回一个类,可以初始化一个类,为定义的字段传递值。

eg1:

1.

>>> from collections import namedtuple
>>> Subscriber = namedtuple(‘Subscriber‘, [‘addr‘, ‘joined‘])
>>> sub = Subscriber(‘[email protected]‘, ‘2012-10-19‘)
>>> sub
Subscriber(addr=‘[email protected]‘, joined=‘2012-10-19‘)
>>> sub.addr
‘[email protected]‘
>>> sub.joined
‘2012-10-19‘

2.支持索引和解压

>>> addr, joined = sub
>>> addr
‘[email protected]‘
>>> joined
‘2012-10-19‘

eg2:

1.命名元组的一个用途从下标操作中解脱出来

>>>from collections import namedtuple
>>>Stock = namedtuple(‘Stock‘, [‘name‘, ‘shares‘, ‘price‘])
>>>def compute_cost(records):
...  total = 0.0
...  for rec in records:
...    s = Stock(*rec)
...  total += s.shares * s.price
...  return total

2.命名元组的另一个用途是作为字典的替代。

字典存储需要更多的内存空间,如果需要构建一个非常大的包含字典的数据结构,使用元组会更加高效,需要注意的是命名元组不可更改

>>> s = Stock(‘ACME‘, 100, 123.45)
>>> s
Stock(name=‘ACME‘, shares=100, price=123.45)
>>> s.shares = 75
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
AttributeError: can‘t set attribute

如果真的需要改变命名元组的属性,可以使用命名元组实例的_replace()方法,它会创建一个全新的命名元组并将对应的字段用新的值取代

>>> s = s._replace(shares=75)
>>> s
Stock(name=‘ACME‘, shares=75, price=123.45)

它是一个非常方便的填充数据的方法。你可以先创建一个包含缺省值的原型元组,然后使用replace() 方法创建新的值被更新过的实例。比如:
>>>from collections import namedtuple
>>>Stock = namedtuple(‘Stock‘, [‘name‘, ‘shares‘, ‘price‘, ‘date‘, ‘time‘])
stock_prototype = Stock(‘‘, 0, 0.0, None, None)
>>>def dict_to_stock(s):
...  return stock_prototype._replace(**s)

下面是它的使用方法:
>>> a = {‘name‘: ‘ACME‘, ‘shares‘: 100, ‘price‘: 123.45}
>>> dict_to_stock(a)
Stock(name=‘ACME‘, shares=100, price=123.45, date=None, time=None)
>>> b = {‘name‘: ‘ACME‘, ‘shares‘: 100, ‘price‘: 123.45, ‘date‘: ‘12/17/2012‘}
>>> dict_to_stock(b)
Stock(name=‘ACME‘, shares=100, price=123.45, date=‘12/17/2012‘, time=None)

如果目标是定义一个需要更新很多实例属性的高效数据结构,命名元组不是最佳选择,这时候考虑定义一个__slots__方法的类

原文地址:https://www.cnblogs.com/baxianhua/p/8297539.html

时间: 2024-12-15 08:40:26

Python: collections.nametuple()--映射名称到序列元素的相关文章

传说中的华为Python笔试题——两等长整数序列互换元素,序列和的差值最小(修正)

有两个序列a,b,大小都为n,序列元素的值任意整形数,无序:要求:通过交换a,b中的元素,使[序列a元素的和]与[序列b元素的和]之间的差最小. 1. 将两序列合并为一个序列,并排序,得到sourceList2. 拿出最大元素Big,次大的元素Small3. 在余下的序列S[:-2]进行平分,得到序列max,min4. 将Small加到max序列,将Big加大min序列,重新计算新序列和,和大的为max,小的为min. 如下,提供递归版本和迭代版本的解体思路: #!/usr/bin/env py

Python从菜鸟到高手(12):通过索引操作序列元素

1.定义序列   本文将介绍一下在Python语言中如何定义序列.定义序列的语法与Java中的数组类似,使用一对中括号将序列中的元素值括起来.下面的例子创建一个元素类型是字符串的序列,实现代码如下: names = ["Bill", "Mary", "Jack"]   同一个序列,不仅可以包含相同类型的值,还可以包含不同类型的值.下面的例子在一个序列中放置不同类型的值,实现代码如下: values = ["Bill", 30,

【Python】序列元素的输出

在做题目的过程中,我们常常需要以一定格式对某个序列进行输出.如果用遍历的方法将序列元素一个一个输出的话还必须考虑到最后一个元素后面所跟的是什么符号.python中的字符串提供了join方法,用于将序列中的元素以指定的字符连接生成一个新的字符串. 例: 1 a = [1, 2, 3, 4] 2 print(" ".join(list(map(str, a)))) 输出: 1 2 3 4 输出的语句中,join()方法是由用来分隔的字符调用的.作为参数的序列元素必须是字符串,否则会报错.

Python: 序列: 过滤序列元素

问题: 你有一个数据序列,想利用一些规则从中提取出需要的值或者是缩短序列 answer: eg1:列表推导 最简单的过滤序列元素的方法就是使用列表推导.比如:>>> mylist = [1, 4, -5, 10, -7, 2, 3, -1]>>> [n for n in mylist if n > 0][1, 4, 10, 2, 3]>>> [n for n in mylist if n < 0][-5, -7, -1] eg2:生成器表达

Python collections模块总结

Python collections模块总结 除了我们使用的那些基础的数据结构,还有包括其它的一些模块提供的数据结构,有时甚至比基础的数据结构还要好用. collections ChainMap 这是一个为多个映射创建单一视图的类字典类型,也就是说,它同样具有字典类型的方法,它比基础数据结构中的字典的创建和多次更新要快,需要注意的是,增删改的操作都只会针对该对象的第一个字典,其余字典不会发生改变,但是如果是查找,则会在多个字典中查找,直到找到第一个出现的key为止. 特有方法 解释 maps 返

Python collections模块实例

collections模块基本介绍 我们都知道,Python拥有一些内置的数据类型,比如str, int, list, tuple, dict等, collections模块在这些内置数据类型的基础上,提供了几个额外的数据类型: 1.namedtuple(): 生成可以使用名字来访问元素内容的tuple子类2.deque: 双端队列,可以快速的从另外一侧追加和推出对象3.Counter: 计数器,主要用来计数4.OrderedDict: 有序字典5.defaultdict: 带有默认值的字典 n

Python collections 模块用法举例

Python作为一个“内置电池”的编程语言,标准库里面拥有非常多好用的模块.比如今天想给大家 介绍的 collections 就是一个非常好的例子. 1.collections模块基本介绍 我们都知道,Python拥有一些内置的数据类型,比如str, int, list, tuple, dict等, collections模块在这些内置数据类型的基础上,提供了几个额外的数据类型: 1.namedtuple(): 生成可以使用名字来访问元素内容的tuple子类 2.deque: 双端队列,可以快速

[NHibernate]集合类(Collections)映射

系列文章 [Nhibernate]体系结构 [NHibernate]ISessionFactory配置 [NHibernate]持久化类(Persistent Classes) [NHibernate]O/R Mapping基础 引言 这部分不包括大量的.NET代码例子.我们假定你已经了解如何使用.NET自身的集合类框架(.NET's collections framework)和Set集合的概念.其实如果是这样,这里就真的没有什么东西需要学习了....用一句话来做个总结,你就用你已经掌握的知识

python kayb算法之从一组序列当中获取一组与目标值最接近的算法

python  kayb算法之从一组序列当中获取一组与目标值最接近的算法 思想:1.考虑所有序列当中的所有元素相遇的情况进行迭代2.在迭代过程当中维护一个与目标数值的最小差值3.在迭代完之后剩余的那一项 即为与目标值最接近的元素序列注意: 1.如果总和大于目标数需要判断此时大于目标数的和与前一个值总和哪个差值最小 2.考虑初始序列元素与目标值的最小差值 3.考虑序列当中所有元素的总和比目标值小问题: 1.是否有最小可以接受的范围 可以大大提高时间 1 # -*- coding:utf-8 -*-