- 命名切片
- 问题: 程序出现一大堆已经无法直视的硬编码切片下标,想清理下代码
- 解决方案:
- 假定有一段代码要从一个记录字符串几个固定位置提取出特定的数据字段(比如文件或类似格式)
###### 0123456789012345678901234567890123456789012345678901234567890'
record = '....................100 .......513.25 ..........'
cost = int(record[20:23]) * float(record[31:37])
SHARES = slice(20,23)
PRICE = slice(31, 37)
print(int(record[SHARES]))
cost = int(record[SHARES]) * float(record[PRICE])
- 讨论
- 一般来讲,代码中如果出现大量的硬下标值会使得可读性和可维护性大大降低。比如,如果你回过来看看一 年前你些的代码,你会摸着脑袋想拿时候自己在干嘛啊。这里的解决方案是一个简单的方法让你更加清晰的 表达清楚代码到底在做什么。
- 内置的 slice() 函数创建了一个切片对象,可以被用在任何切片允许使用的地方。比如:
items = [0, 1, 2, 3, 4, 5, 6]
a = slice(2, 4)
print(items[2: 4]) # [2, 3]
print(items[a]) # [2, 3]
items[a] = [10, 11]
print(items) # [0, 1, 10, 11, 4, 5, 6]
del items[a]
print(items) # [0, 1, 4, 5, 6]
- 如果你有一个切片对象,你可以分别调用它的 s.start, s.stop, s.step 属性来获取更多的信息。比如:
s = slice(5, 50, 2)
print(s.start) # 5
print(s.stop) # 50
print(s.step) # 2
- 另外,你还能通过调用切片的 indices(size)方法将它映射到一个确定大小的序列上,这个方法返回一个三 元组(start, stop, step),所有值都会被合适的缩小以满足边界限定,从而避免使用的时候出现IndexError 异常。比如:
a = "helloworld"
s.indices(len(a))
print(s.indices(len(a))) # (5, 10, 2)
for i in range(*s.indices(len(a))):
print(a[i]) # w, r , d
- 注: 根据运行结果,原书中上面的例题印刷有错误。正确的应该是上面的写法。