【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

相关推荐
CeshirenTester42 分钟前
9B 上端侧:多模态实时对话,难点其实在“流”
开发语言·人工智能·python·prompt·测试用例
Starry_hello world42 分钟前
Python (2)
python
ID_180079054731 小时前
Python爬取京东商品库存数据与价格监控
jvm·python·oracle
-To be number.wan2 小时前
Python数据分析:时间序列数据分析
开发语言·python·数据分析
Faker66363aaa3 小时前
YOLO13-C3K2-AdditiveBlock:水果质量智能检测系统_3
python
2401_828890643 小时前
实现扩散模型 Stable Diffusion - MNIST 数据集
人工智能·python·深度学习·stable diffusion
jz_ddk3 小时前
[指南] Python循环语句完全指南
开发语言·python·continue·循环·for·while·break
Evand J3 小时前
【Python代码例程】长短期记忆网络(LSTM)和无迹卡尔曼滤波(UKF)的结合,处理复杂非线性系统和时间序列数据
python·lstm·滤波
workflower4 小时前
易用性和人性化需求
java·python·测试用例·需求分析·big data·软件需求
嚯嚯歪4 小时前
攻克腾讯 TCaptcha 滑块验证码:纯 HTTP 协议逆向实战
爬虫·python·逆向·验证码识别