2010-04-08 76 views
30

我使用以下方法打破Python中的双循环。在Python中打破嵌套(双)循环

for word1 in buf1: 
    find = False 
    for word2 in buf2: 
     ... 
     if res == res1: 
      print "BINGO " + word1 + ":" + word2 
      find = True 
    if find: 
     break 

有没有更好的方法来打破双循环?

回答

36

你希望也许不是什么,但通常你会希望有一个break设置findTrue

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 
+1

+1简单而优雅! – 2012-08-13 23:06:54

+0

itertools.product()是一个很好的方法。 – 2016-02-27 00:22:22

+0

我今天学到了一些东西:) – wonzbak 2017-06-12 12:44:51

5

使用函数进行重构,以便在找到“宾果”时返回。

允许明确突破嵌套循环的提案已被否决: http://www.python.org/dev/peps/pep-3136/

+1

这应该是上投答案海事组织。 – 2018-01-14 18:04:00

9

大多数时候,你可以用多种方法使单个环路,做同样的事,作为一个双循环。

在您的例子,你可以使用itertools.product

import itertools 
for word1, word2 in itertools.product(buf1, buf2): 
    if word1 == word2: 
     print "BINGO " + word1 + ":" + word2 
     break 

更换您的代码段的其他itertools功能有利于其他模式了。

+0

我想你的意思是'itertools.product'。 '组合'从单个序列产生n长度的元组 – Jimmy 2010-04-08 03:19:39

+0

我认为你的意思是'itertools.product' – 2010-04-08 03:19:48

+0

哦b ....今晚我是个白痴。 – magcius 2010-04-08 03:23:35

29

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 
+2

真的吗?除了特殊的事情外,我从来没有看到任何异常。 – dave 2010-12-29 13:47:08

+10

真的,Python有一些不同的方法来处理异常,这种用法是可以的。 – Guard 2010-12-29 13:55:19

+0

我喜欢这个想法,因为它也涵盖了需要迭代嵌套for循环的二维列表的情况。其他一些想法不适用于此,因为嵌套for循环使用父循环提供的变量来获取多个项目进行迭代。 – Shule 2014-05-23 22:06:40