我想循环检查每个项目的列表与其后面的项目。
有没有办法可以循环使用除了最后一项使用x中的所有项目?如果可以的话,我宁愿不使用索引。
注意
freespace回答了我的实际问题,这就是我接受答案的原因,但是SilentGhost回答了我应该问的问题。
为混乱道歉。
for x in y[:-1]
如果y
是一个生成器,那么上面的代码将不起作用。
将序列项与以下内容进行比较的最简单方法:
for i, j in zip(a, a[1:]):
# compare i (the current) to j (the following)
如果要获得序列对中的所有元素,请使用此方法(成对函数来自itertools模块中的示例)。
from itertools import tee, izip, chain
def pairwise(seq):
a,b = tee(seq)
b.next()
return izip(a,b)
for current_item, next_item in pairwise(y):
if compare(current_item, next_item):
# do what you have to do
如果需要将最后一个值与某个特殊值进行比较,请将该值链接到结尾
for current, next_item in pairwise(chain(y, [None])):
如果你的意思是比较第n项和列表中的第n + 1项,你也可以这样做
>>> for i in range(len(list[:-1])):
... print list[i]>list[i+1]
请注意,那里没有硬编码。除非你有其他想法,否则这应该没问题。
要在迭代器中比较每个项目与下一个项目而不实例化列表:
import itertools
it = (x for x in range(10))
data1, data2 = itertools.tee(it)
data2.next()
for a, b in itertools.izip(data1, data2):
print a, b
这回答了OP应该问的问题,即遍历一个比较连续元素的列表(优秀的SilentGhost答案),但是针对任何组(n-gram)进行推广:2,3,... n
:
zip(*(l[start:] for start in range(0, n)))
例子:
l = range(0, 4) # [0, 1, 2, 3]
list(zip(*(l[start:] for start in range(0, 2)))) # == [(0, 1), (1, 2), (2, 3)]
list(zip(*(l[start:] for start in range(0, 3)))) # == [(0, 1, 2), (1, 2, 3)]
list(zip(*(l[start:] for start in range(0, 4)))) # == [(0, 1, 2, 3)]
list(zip(*(l[start:] for start in range(0, 5)))) # == []
说明:
l[start:]
或start
:将所有元素传递给封闭函数*list
,好像它是写成*generator
注意:
AFAIK,这段代码尽可能地懒惰。没有测试过。