python正向切片_使Python切片正常(正/正向+无无+无负索引+在边界内)
在Python中實現(xiàn)可以用標(biāo)準(zhǔn)Python語法進(jìn)行切片的類(即負(fù)索引、單步執(zhí)行等)時,有時可以將切片轉(zhuǎn)換為“理智的、向前的切片”,以確定切片的元素。怎樣才能以簡潔/優(yōu)雅的形式寫出這樣一個函數(shù)呢?在
對于“理智的、向前的切片”,我指的是一個與初始切片等效的切片,在這個意義上,結(jié)果元素是相同的,但是有一個正步長,沒有負(fù)索引,也沒有大于對象長度的索引。在
示例(假設(shè)數(shù)組長度為10):slice(None, 4,None) -> slice( 0, 4, 1)
slice( -7, 12, 1) -> slice( 3,10, 1)
slice(None,None, -1) -> slice( 0,10, 1)
slice( 7, 3, -2) -> slice( 5, 8, 2)
slice( 9, 1, -3) -> slice( 3,10, 3)
編寫一個執(zhí)行這種轉(zhuǎn)換的函數(shù)并不是非常困難,但我不能編寫得簡潔明了。尤其是在將“向后切片”轉(zhuǎn)換為等效的“向前切片”時確定起始索引似乎相當(dāng)麻煩。在
工作示例:
^{pr2}$
.
.
. 在
編輯(最終功能):
通過使用slice.indices(),@doublep善意地指向我,它變成了:def to_sane_slice(s, N):
# get rid of None's, overly large indices, and negative indices (except -1 for
# backward slices that go down to first element)
start, stop, step = s.indices(N)
# get number of steps & remaining
n, r = divmod(stop - start, step)
if n < 0 or (n==0 and r==0):
return slice(0,0,1)
if r != 0: # its a "stop" index, not an last index
n += 1
if step < 0:
start, stop, step = start+(n-1)*step, start-step, -step
else: # step > 0, step == 0 is not allowed
stop = start+n*step
stop = min(stop, N)
return slice(start, stop, step)
總結(jié)
以上是生活随笔為你收集整理的python正向切片_使Python切片正常(正/正向+无无+无负索引+在边界内)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python预测疾病_吴裕雄--天生自然
- 下一篇: 登录计算机怎么保存用户名,浏览器保存了账