namedtuple让代码更易维护
from collections import namedtuple
# 一般写法
lst = [(1.5, 2, 3.0), (-0.3, -1.0, 2.1), (1.3, 2.8, -2.5)]
print(lst[0][1] - lst[1][1])
使用命名的元祖namedtuple
:
Point = namedtuple('Point', ['x', 'y', 'z']) # 定义名字为Point的元祖,字段属性有x,y,z
lst = [Point(1.5, 2, 3.0), Point(-0.3, -1.0, 2.1), Point(1.3, 2.8, -2.5)]
print(lst[0].y - lst[1].y)
命名的元祖,写出来的代码相比第一种写法可读性更好,当属性变多时,我们甚至很难按照index方式访问元素。
更重要的是,当需要增加或删除一个维度时,命名元祖代码改动量比第一种要小。
如在属性x和y间增加一个维度k时:
Point = namedtuple('Point', ['x', 'k', 'y', 'z'])
lst = [Point(1.5, 2, 0.0, 3.0), Point(-0.3, -1.0, 0.0, 2.1),
Point(1.3, 2.8, 0.0, -2.5)]
命名不需要重写下面代码,
print(lst[0].y - lst[1].y)
但是普通元祖就得如下修改:
print(lst[0][2] - lst[1][2])
近期小例子:
两种合并字典的方法对比;
计算和聚合同时进行;
groupby 分组;
plotly画柱状图+折线图;
Python小例子完整列表
60页《Python之路1.0.pdf
》下载方式,关注《Python小例子》并在其后台回复 mypy
,即可下载。

Python小例子,长按关注
后期计划:不断深入Python小例子,添加更多基于Python的小例子,不限于:PyQt制作GUI
,NumPy数值计算
,Pandas数据分析
,Sklearn机器学习实战
,Keras+TensorFlow深度学习
等。2.0版本预计在春节前发出来。
如果你想每天看到小例子的更新动态,欢迎star
这个小例子库,我们也真诚欢迎你贡献小例子,直接点击文章最下的阅读原文.