笛卡爾積python
⑴ python中斷多重循環的幾種思路
事實上,Python的標准語法是不支持跳出多重循環的,所以只能利用一些技巧,大概的思路有:寫成函數、利用笛卡爾積、利用調試。
寫成函數
在Python中,函數運行到return這一句就會停止,因此可以利用這一特性,將功能寫成函數,終止多重循環,例如
def work(): for i in range(10): for j in range(10): if i+j > 5: return i,jprint work()
利用笛卡爾積
這種方法的思路就是,既然可以跳出單循環,我就將多重循環改寫為單循環,這可以利用itertools中的笛卡爾積函數proct,例如
from itertools import proctfor i,j in proct(range(10), range(10)): if i+j > 5: print i,j break
利用調試模式
笛卡爾積的方式很巧妙,也很簡潔,但它只能用於每次循環的集合都是獨立的情形,假如每層循環都與前一層緊密相關,就不能用這種技巧了。這時候可以用第一種方法,將它寫成函數,另外,還可以利用調試模式。這個利用了調試模式中,只要出現報錯就退出的原理,它偽裝了一個錯誤出來。
class Found(Exception): passtry: for i in range(10): for j in range(i): #第二重循環跟第一重有關 if i + j > 5: raise Foundexcept Found: print i, j
⑵ Excel的公式參照有不定數的同碼重復列,以設定的條件,依序讀取也有不定數的同碼重復的列
按你的需求,用excel公式不可能實現,H!B列和CP!D列有重復值是硬傷,兩張表這兩個欄位進行關聯後,記錄數將是笛卡爾積,而不是你要求的取B列中重復記錄個數。
用python去寫吧,更容易實現一些。