>通用格式 if語句一般形式如下: if : elif : else: 另外需要注意的是,Python中是沒有switch/case語句的 while循環(huán) while語句是Python語言中最通用的迭代結(jié)構(gòu),簡而言之,只要頂端測試一直計算到真值,就會重復(fù)執(zhí)行一個語句塊。 >>一般格" />
>>通用格式
if語句一般形式如下:
if: elif : else:
另外需要注意的是,Python中是沒有switch/case語句的
while循環(huán)
while語句是Python語言中最通用的迭代結(jié)構(gòu),簡而言之,只要頂端測試一直計算到真值,就會重復(fù)執(zhí)行一個語句塊。
>>一般格式
while: else: >>break,continue,pass和循環(huán)else
break
跳出最近所在的循環(huán)(跳過整個循環(huán)語句)。
continue
跳到最近所在循環(huán)的開頭處(來到循環(huán)的首行)。
pass
什么事也不做,只是空占位符語句。
循環(huán)else塊
只有當(dāng)前循環(huán)正常離開時才會執(zhí)行(也就是沒有碰到break語句)
>>一般循環(huán)格式
加入break和continue語句后,while的一般格式變?yōu)?
while: if :break if :continue else: >>pass
pass語句是無運算的占位符,當(dāng)語法需要語句并且還沒有任何實用的語句可寫時,就可以使用它。
>>循環(huán)else
在while語句中加入else和C/C++中的語法不太一樣,這里詳細(xì)說明一下。else后面的代碼只有當(dāng)循環(huán)正常結(jié)束時才會執(zhí)行,如果是用break跳出循環(huán)的,這部分代碼就不會運行,具體看一個求質(zhì)數(shù)的例子:
x = y // 2 while x > 1: if y % x == 0: print(y,'has factor',x) break x -= 1 else: print(y,'is prime')
再看一個對比的例子,沒有使用else的情況:
found=False while x and not found: if (matchx[0]): print('Ni') found=True else: x=x[1:] if not found: print('not found') 使用else后的情況: while x: if (match(x[0])): print('Ni') break else: print('not found')
for循環(huán)
for循環(huán)在Python中是一個通用的序列迭代器:可以遍歷任何有序的序列對象內(nèi)元素。for語句可以用于字符串、列表、元組、其他內(nèi)置可迭代對象。
>>一般格式
forin
此處的else的作用和while語句中的一樣。另外需要注意的是,當(dāng)Python運行for循環(huán)時,會逐個將序列對象中的元素賦值給目標(biāo),然后為每個元素執(zhí)行循環(huán)體。
編寫循環(huán)的技巧
內(nèi)置range函數(shù):返回一系列連續(xù)增加的整數(shù),可作為for中的索引
內(nèi)置zip函數(shù):返回并行元素的元組的列表,可用于在for中遍歷數(shù)個數(shù)列
>>循環(huán)計數(shù)器:while和range
range
當(dāng)range函數(shù)只有一個參數(shù)時,會返回從零算起的整數(shù)列表,但其中不包括該參數(shù)的值。如果傳進(jìn)兩個參數(shù),那第一個參數(shù)是上邊界,第二個參數(shù)是下邊界。如果傳進(jìn)三個參數(shù)時,第三個參數(shù)表示步進(jìn)值。
range提供了一種簡單的方法,重復(fù)特定次數(shù)的動作:
for i in range(5): print(i,'Pythons')
相應(yīng)的C++代碼則是:
int i; for(i = 0;i < 5;++i) { std::cout<
>>并行遍歷:zip和map
zip會取得一個或多個序列為參數(shù),然后返回元組的列表,將這些序列中的并排的元素配成對。
L1=[1,2,3,4] L2=[5,6,7,8] list(zip(L1,L2))
上述代碼的執(zhí)行結(jié)果是:
[(1,5),(2,6),(3,7),(4,8)]
當(dāng)參數(shù)的長度不同時,zip會以最短序列的長度為準(zhǔn)來截斷所得到的元組。
使用zip構(gòu)造字典:
keys=['spam','eggs','totast'] values=[1,2,5] D = dict(zip(keys,values))
>>產(chǎn)生偏移和元素:enumerate
enumerate函數(shù)一個比較新的內(nèi)置函數(shù),它能同時返回元素值和偏移值:
s='spam' for (offset,item) in enumerate(s): print(item,'appears at offset',offset)
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com