序列的一个常见操作就是通过切片提取有意义的数据片段进行处理,通常我们的做法时通过硬编码的形式[start, end, step]来定位数据。随着项目的不断复杂化和规模化,这种硬编码的形式会使整个项目变得难以维护。
此时,我们可以通过给切片进行命名,这样我们就不需要在每次提取给定数据时重新计算和核对切片位置。
###### 0123456789012345678901234567890123456789012345678901234567890'
record = '....................100 .......513.25 ..........'
cost = int(record[20:32]) * float(record[40:48])
这种方式就是硬编码的方式,以下就是通过一次命名,后续可以直接调用的方式:
SHARES = slice(20,32)
PRICE = slice(40,48)
cost = int(record[SHARES]) * float(record[PRICE])
其实这种方式就是对slice对象的直接使用,以下代码可以很直观的看出:
>>> items = [0, 1, 2, 3, 4, 5, 6]
>>> a = slice(2, 4)
>>> items[2:4]
[2, 3]
>>> items[a]
[2, 3]
>>> items[a] = [10,11]
>>> items
[0, 1, 10, 11, 4, 5, 6]
>>> del items[a]
>>> items
[0, 1, 4, 5, 6]
>>> a = slice(10, 50, 2)
>>> a.start
10
>>> a.stop
50
>>> a.step
2
>>>