【Python Cookbook】S1E09 对切片命名

目录

问题

代码的可阅读性非常重要,如何增强切片中的可阅读性?本文将提供一种方案。

解决方案

假设有一些代码用来从字符串的固定位置取出具体的数据:

python 复制代码
record = "...100...513.25..."
cost = int(record[3:6]) * float(record[9:15])
print("cost is ", cost)

上述的代码可读性和可维护性很低,在一段时间后再回看这段代码,可能会发现自己都难理解这两个字段到底是什么。对于这种切片切分,不妨我们使用合理的命名,不仅便于后期维护,还可显著增加代码的可阅读性:

python 复制代码
shares = slice(3, 6)
price = slice(9, 15)
cost = int(record[shares]) * float(record[price])
print("cost is ", cost)

讨论

slice() 函数,不仅可以用于上述增强代码的可阅读性,其本质上会创建一个切片对象,我们可以在对象的实例上进行很多其他的操作。

假设有一个 slice 对象的实例 s ,我们可以分别通过 s.starts.stop 以及 s.step 属性来得到关于该对象的信息,例如:

python 复制代码
s = slice(3, 6, 2)
print("s.start =", s.start)
print("s.stop = ", s.stop)
print("s.step = ", s.step)

所以可以看出,slice 对象有三个参数,分别是 (start, stop, step) ,顾名思义,即开始的 index ,结束的 index 以及每一步的跨步大小是多少 step

相关推荐
一个天蝎座 白勺 程序猿42 分钟前
Python爬虫(47)Python异步爬虫与K8S弹性伸缩:构建百万级并发数据采集引擎
爬虫·python·kubernetes
XiaoMu_0012 小时前
基于Django+Vue3+YOLO的智能气象检测系统
python·yolo·django
honder试试3 小时前
焊接自动化测试平台图像处理分析-模型训练推理
开发语言·python
心本无晴.3 小时前
Python进程,线程
python·进程
java1234_小锋6 小时前
Scikit-learn Python机器学习 - 特征降维 压缩数据 - 特征提取 - 主成分分析 (PCA)
python·机器学习·scikit-learn
java1234_小锋6 小时前
Scikit-learn Python机器学习 - 特征降维 压缩数据 - 特征提取 - 线性判别分析 (LDA)
python·机器学习·scikit-learn
思辨共悟7 小时前
Python的价值:突出在数据分析与挖掘
python·数据分析
计算机毕业设计木哥7 小时前
计算机毕设选题:基于Python+Django的B站数据分析系统的设计与实现【源码+文档+调试】
java·开发语言·后端·python·spark·django·课程设计
中等生8 小时前
Pandas 与 NumPy:数据分析中的黄金搭档
后端·python
用户8356290780518 小时前
Python查找替换PDF文字:告别手动,拥抱自动化
后端·python