Python 中的 if 子句由三部分組成: 關鍵字本身,用于判斷結果真假的條件表達式, 以及當表達式為真或者非零時執行的代碼塊。if 語句的語法如下:
if expression:
? ? expr_true_suite
單個 if 語句可以通過使用布爾操作符 and , or 和 not實現多重判斷條件或是否定判斷條件。
如果一個復合語句(例如 if 子句, while 或 for 循環)的代碼塊僅僅包含一行代碼, 那么它可以和前面的語句寫在同一行上:if make_hard_copy: send_data_to_printer()。
2.else語句
如果 if 語句的條件表達式的結果布爾值為假, 那么程序將執行 else 語句后的代碼:
if expression:
? ? expr_true_suite
else:
? ? expr_false_suite
Python 的縮進使用強制使代碼正確對齊, 讓程序員來決定 else 屬于哪一個 if . 限制您的選擇從而減少了不確定性。
3.elif(即else-if)語句
elif 是 Python 的 else-if 語句, 它檢查多個表達式是否為真, 并在為真時執行特定代碼塊中的代碼。if 語句后最多只能有一個 else語句, 但可以有任意數量的 elif 語句。
if expression1:
? ? expr1_true_suite
elif expression2:
? ? expr2_true_suite
elif expressionN:
? ? exprN_true_suite
else:
? ? none_of_the_above_suite
4.條件表達式(即“三元操作符”)
語法為:X if C else Y ,C為條件表達式,X 是 C 為 True 時的結果, Y 是 C 為 False 時的結果。
5.while語句
while 循環的語法如下:
while expression:
? ? suite_to_repeat
while 循環的 suite_to_repeat 子句會一直循環執行,直到 expression 值為布爾假。
while True:#無限循環
? ??suite_to_repeat
6.for語句
for 循環會訪問一個可迭代對象(例如序列或是迭代器)中的所有元素, 并在所有條目都處理過后結束循環。它的語法如下:
for iter_var in iterable:
? ? suite_to_repeat
每次循環,iter_var 迭代變量被設置為可迭代對象(序列, 迭代器, 或者是其他支持迭代的對象)的當前元素, 提供給 suite_to_repeat 語句塊使用。
迭代序列有三種基本方法:
1)通過序列項迭代;


1 >>> nameList = ['Walter', "Nicole", 'Steven', 'Henry'] 2 >>> for eachName in nameList: 3 ... print eachName, "Lim" 4 ... 5 Walter Lim 6 Nicole Lim 7 Steven Lim 8 Henry Lim
2)通過序列索引迭代;


1 >>> nameList = ['Cathy', "Terry", 'Joe', 'Heather', 2 'Lucy'] 3 >>> for nameIndex in range(len(nameList)): 4 ... print "Liu,", nameList[nameIndex] 5 ... 6 Liu, Cathy 7 Liu, Terry 8 Liu, Joe 9 Liu, Heather 10 Liu, Lucy
使用 range() 我們可以得到用來迭代 nameList 的索引數列表;使用切片/下標操作符( [ ] ),就可以訪問對應的序列對象。
3)使用項和索引迭代;


1 >>> nameList = ['Donn', 'Shirley', 'Ben', 'Janice', 2 ... 'David', 'Yen', 'Wendy'] 3 >>> for i, eachLee in enumerate(nameList): 4 ... print "%d %s Lee" % (i+1, eachLee) 5 ... 6 1 Donn Lee 7 2 Shirley Lee 8 3 Ben Lee 9 4 Janice Lee 10 5 David Lee 11 6 Yen Lee 12 7 Wendy Lee
?Python 提供了兩種不同的方法來調用 range() . 完整語法要求提供兩個或三個整數參數:
range(start, end, step =1)
range() 會返回一個包含所有 k 的列表, 這里 start <= k < end , 從 start 到 end , k 每次遞增 step . step 不可以為零,否則將發生錯誤。如果只給定兩個參數,而省略 step, step 就使用默認值 1 。
range()簡略語法:range(end) 和?range(start, end)。
核心筆記: 為什么 range() 不是只有一種語法?
range(start=0, end, step =1) # 錯誤
這個語法不可以使用兩個參數調用. 因為 step 要求給定 start . 換句話說, 你不能只傳遞end 和 step 參數. 因為它們會被解釋器誤認為是 start 和 end 。
與序列相關的內建函數:sorted(), reversed(), enumerate(), zip()。sorted() 和 zip() )返回一個序列(列表), 而另外兩個函數( reversed() 和 enumerate() )返回迭代器(類似序列)。


1 >>>albums = ('Poe', 'Gaudi', 'Freud', 'Poe2') 2 >>> years = (1976, 1987, 1990, 2003) 3 >>> for album in sorted(albums): 4 ... print album, 5 ... 6 Freud Gaudi Poe Poe2 7 >>> 8 >>> for album in reversed(albums): 9 ... print album, 10 ... 11 Poe2 Freud Gaudi Poe 12 >>> 13 >>> for i, album in enumerate(albums): 14 ... print i, album 15 ... 16 0 Poe 17 1 Gaudi 18 2 Freud 19 3 Poe2 20 >>> 21 >>> for album, yr in zip(albums, years): 22 ... print yr, album 23 ... 24 1976 Poe 25 1987 Gaudi 26 1990 Freud 27 2003 Poe2
7.break語句
Python 中的 break 語句可以結束當前循環然后跳轉到下條語句,break 語句可以用在 while 和 for 循環中。
8.continue 語句
核心筆記: continue 語句
當遇到continue 語句時, 程序會終止當前循環,并忽略剩余的語句, 然后回到循環的頂端. 在開始下一次迭代前,如果是條件循環, 我們將驗證條件表達式.如果是迭代循環,我們將驗證是否還有元素可以迭代. 只有在驗證成功的情況下, 才會開始下一次迭代。
continue可以被用在 while 和 for 循環里。


1 valid = False 2 count = 3 3 while count > 0: 4 input = input("enter password") 5 # check for valid passwd 6 for eachPasswd in passwdList: 7 if input == eachPasswd: 8 valid = True 9 break 10 if not valid: # (or valid == 0) 11 print "invalid input" 12 count -= 1 13 continue 14 else: 15 break
9.pass 語句
Python 提供了 pass 語句, 它不做任何事情 - 即 NOP , ( No OPeration , 無操作) 我們從匯編語言中借用這個概念。pass 同樣也可作為開發中的小技巧, 標記你后來要完成的代碼。例如:
def foo_func():pass 或是 if user_choice == 'do_calc':pass else:pass
10. 再談 else 語句
在循環中使用時, else子句只在循環完成后執行, 也就是說 break 語句也會跳過 else 塊。


1 #!/usr/bin/env python 2 3 def showMaxFactor(num): 4 count = num / 2 5 while count > 1: 6 if num % count == 0: 7 print('largest factor of %d is %d' % (num, count)) 8 break 9 count -= 1 10 else: 11 print num, "is prime" 12 13 for eachNum in range(10, 21): 14 showMaxFactor(eachNum)
11.迭代器和 iter() 函數
迭代器為類序列對象提供了一個類序列的接口。它們是一組數據結構,你可以利用它們的索引從0 開始一直"迭代" 到序列的最后一個條目. 用"計數"的方法迭代序列是很簡單的. Python 的迭代無縫地支持序列對象, 而且它還允許程序員迭代非序列類型, 包括用戶定義的對象。
為什么要迭代器?
? 提供了可擴展的迭代器接口.
? 對列表迭代帶來了性能上的增強.
? 在字典迭代中性能提升.
? 創建真正的迭代接口, 而不是原來的隨機對象訪問.
? 與所有已經存在的用戶定義的類以及擴展的模擬序列和映射的對象向后兼容
? 迭代非序列集合(例如映射和文件)時, 可以創建更簡潔可讀的代碼.
如何迭代?
迭代器就是有一個 next() 方法的對象, 而不是通過索引來計數。 當你或是一個循環機制(例如 for 語句)需要下一個項時, 調用迭代器的 next() 方法就可以獲得它。條目全部取出后,會引發一個 StopIteration 異常, 這并不表示錯誤發生,只是告訴外部調用者, 迭代完成。
reversed() 內建函數將返回一個反序訪問的迭代器;enumerate() 內建函數同樣也返回迭代器;另外兩個新的內建函數, any() 和 all(),如果迭代器中某個/所有條目的值都為布爾真時,則它們返回值為真。
使用迭代器:
1)序列(for 循環會自動調用迭代器的 next() 方法(以及監視StopIteration 異常))


1 >>> myTuple = (123, 'xyz', 45.67) 2 >>> i = iter(myTuple) 3 >>> i.next() 4 123 5 >>> i.next() 6 'xyz' 7 >>> i.next() 8 45.67 9 10 fetch = iter(seq) 11 while True: 12 try: 13 i = fetch.next() 14 except StopIteration: 15 break 16 do_something_to(i)
2)字典
字典和文件是另外兩個可迭代的 Python 數據類型. 字典的迭代器會遍歷它的鍵(keys)。語句 for eachKey in myDict.keys() 可以縮寫為 for eachKey in myDict。
3)文件
文件對象生成的迭代器會自動調用 readline() 方法。這樣, 循環就可以訪問文本文件的所有行,也可以使用更簡單的 for eachLine in myFile。
記住:在迭代可變對象的時候修改它們并不是個好主意。
一個序列的迭代器只是記錄你當前到達第多少個元素, 所以如果你在迭代時改變了元素, 更新會立即反映到你所迭代的條目上.在迭代字典的 key 時, 你絕對不能改變這個字典. 使用字典的 keys() 方法是可以的, 因為keys() 返回一個獨立于字典的列表. 而迭代器是與實際對象綁定在一起的, 它將不會繼續執行下去。


1 >>> myDict = {'a': 1, 'b': 2, 'c': 3, 'd': 4} 2 >>> for eachKey in myDict: 3 ... print eachKey, myDict[eachKey] 4 ... del myDict[eachKey] 5 ... a 1 6 Traceback (most recent call last): 7 File "", line 1, in ? 8 RuntimeError: dictionary changed size during iteration
如何創建迭代器?
對一個對象調用 iter() 就可以得到它的迭代器. 它的語法如下:
iter(obj)
iter(func, sentinel )
如果你傳遞一個參數給 iter() , 它會檢查你傳遞的是不是一個序列, 如果是, 那么很簡單:根據索引從 0 一直迭代到序列結束. 另一個創建迭代器的方法是使用類。如果是傳遞兩個參數給 iter() , 它會重復地調用 func , 直到迭代器的下個值等于sentinel 。
12.列表解析
列表解析的語法:[expr for iter_var in iterable]
這個語句的核心是 for 循環, 它迭代 iterable 對象的所有條目. 前邊的 expr 應用于序列的每個成員, 最后的結果值是該表達式產生的列表. 迭代變量并不需要是表達式的一部分。
列表解析還提供了一個擴展版本的語法:[expr for iter_var in iterable if cond_expr],這個語法在迭代時會過濾/捕獲滿足條件表達式 cond_expr 的序列成員。
矩陣樣例:
>>> [(x+1,y+1) for x in range(3) for y in range(5)]
[(1, 1), (1, 2), (1, 3), (1, 4), (1, 5), (2, 1), (2, 2), (2,
3), (2, 4), (2, 5), (3, 1), (3, 2), (3, 3), (3, 4), (3, 5)]
磁盤文件樣例:
可以通過 for line in data 迭代文件內容,不過, 除了這個, 我們還可以把每行分割( split )為單詞, 然后我們可以像這樣計算單詞個數:
>>> f = open('hhga.txt', 'r')
>>> len([word for line in f for word in line.split()])
91
快速地計算文件大小
import os
>>> os.stat('hhga.txt').st_size
499L
假定文件中至少有一個空白字符, 我們知道文件中有少于 499 個非空字符. 我們可以把每個單詞的長度加起來, 得到和:
>>> f.seek(0)
>>> sum([len(word) for line in f for word in line.split()])
408
13.生成器表達式
生成器表達式是列表解析的一個擴展。生成器是特定的函數, 允許你返回一個值, 然后"暫停"代碼的執行, 稍后恢復。列表解析的一個不足就是必要生成所有的數據, 用以創建整個列表. 這可能對有大量數據的迭代器有負面效應. 生成器表達式通過結合列表解析和生成器解決了這個問題。
列表解析:
[expr for iter_var in iterable if cond_expr]
生成器表達式:
(expr for iter_var in iterable if cond_expr)
生成器表達式并不真正創建數字列表, 而是返回一個生成器,這個生成器在每次計算出一個條目后,把這個條目“產生”(yield)出來. 生成器表達式使用了"延遲計算"(lazy evaluation), 所以它在使用內存上更有效.
磁盤文件樣例:
>>> sum(len(word) for line in data for word in line.split()) ? ? ##sum() 函數(它的參數不僅可以是列表,還可以是可迭代對象,比如生成器表達式)
408
交叉配對例子:


1 rows = [1, 2, 3, 17] 2 3 def cols(): # example of simple generator 4 yield 56 5 yield 2 6 yield 1 7 8 x_product_pairs = ((i, j) for i in rows for j in cols()) 9 10 >>> for pair in x_product_pairs: 11 ... print pair 12 ... 13 (1, 56) 14 (1, 2) 15 (1, 1) 16 (2, 56) 17 (2, 2) 18 (2, 1) 19 (3, 56) 20 (3, 2) 21 (3, 1) 22 (17, 56) 23 (17, 2) 24 (17, 1)
重構樣例:
讀取文件的行的首選方法應該是這樣:(readlines() 會讀取文件的所有行)


1 f = open('/etc/motd', 'r') 2 longest = 0 3 allLines = f.readlines() 4 f.close() 5 for line in allLines: 6 linelen = len(line.strip()) 7 if linelen > longest: 8 longest = linelen 9 return longest