在Python中打破嵌套(双)循环
问题描述:
我使用以下方法打破Python中的双循环。在Python中打破嵌套(双)循环
for word1 in buf1:
find = False
for word2 in buf2:
...
if res == res1:
print "BINGO " + word1 + ":" + word2
find = True
if find:
break
有没有更好的方法来打破双循环?
答
你希望也许不是什么,但通常你会希望有一个break
设置find
到True
for word1 in buf1:
find = False
for word2 in buf2:
...
if res == res1:
print "BINGO " + word1 + ":" + word2
find = True
break # <-- break here too
if find:
break
后
的另一种方式是使用一个发电机表达到for
压扁成一个单一的环
for word1, word2 in ((w1, w2) for w1 in buf1 for w2 in buf2):
...
if res == res1:
print "BINGO " + word1 + ":" + word2
break
您也可以考虑使用itertools.product
from itertools import product
for word1, word2 in product(buf1, buf2):
...
if res == res1:
print "BINGO " + word1 + ":" + word2
break
答
使用函数进行重构,以便在找到“宾果”时返回。
允许明确突破嵌套循环的提案已被否决: http://www.python.org/dev/peps/pep-3136/
+1
这应该是上投答案海事组织。 – 2018-01-14 18:04:00
答
大多数时候,你可以用多种方法使单个环路,做同样的事,作为一个双循环。
在您的例子,你可以使用itertools.product与
import itertools
for word1, word2 in itertools.product(buf1, buf2):
if word1 == word2:
print "BINGO " + word1 + ":" + word2
break
更换您的代码段的其他itertools功能有利于其他模式了。
答
Python中的推荐方式打破嵌套循环是...异常
class Found(Exception): pass
try:
for i in range(100):
for j in range(1000):
for k in range(10000):
if i + j + k == 777:
raise Found
except Found:
print i, j, k
+1简单而优雅! – 2012-08-13 23:06:54
itertools.product()是一个很好的方法。 – 2016-02-27 00:22:22
我今天学到了一些东西:) – wonzbak 2017-06-12 12:44:51