“慣例”這個詞指的是“習慣的做法玛追,常規(guī)的辦法披诗,一貫的做法”,與這個詞對應的英文單詞叫“idiom”宰缤。由于Python跟其他很多編程語言在語法和使用上還是有比較顯著的差別颂翼,因此作為一個Python開發(fā)者如果不能掌握這些慣例,就無法寫出“Pythonic”的代碼慨灭。下面我們總結了一些在Python開發(fā)中的慣用的代碼朦乏。
1.讓代碼既可以被導入又可以被執(zhí)行。
if __name__ == '__main__':
2. 用下面的方式判斷邏輯“真”或“假”氧骤。
if x:
if not x:
好的代碼:
name = 'jackfrued'
fruits = ['apple', 'orange', 'grape']
owners = {'1001': '駱昊', '1002': '王大錘'}
if name and fruits and owners:
print('I love fruits!')
不好的代碼:
name = 'jackfrued'
fruits = ['apple', 'orange', 'grape']
owners = {'1001': '駱昊', '1002': '王大錘'}
if name != '' and len(fruits) > 0 and owners != {}:
print('I love fruits!')
3. 善于使用in運算符呻疹。
if x in items: # 包含
for x in items: # 迭代
好的代碼:
name = 'Hao LUO'
if 'L' in name:
print('The name has an L in it.')
不好的代碼:
name = 'Hao LUO'
if name.find('L') != -1:
print('This name has an L in it!')
4. 不使用臨時變量交換兩個值。
a, b = b, a
5. 用序列構建字符串筹陵。
好的代碼:
chars = ['j', 'a', 'c', 'k', 'f', 'r', 'u', 'e', 'd']
name = ''.join(chars)
print(name) # jackfrued
不好的代碼:
chars = ['j', 'a', 'c', 'k', 'f', 'r', 'u', 'e', 'd']
name = ''
for char in chars:
name += char
print(name) # jackfrued
6. EAFP優(yōu)于LBYL刽锤。
EAFP - Easier to Ask Forgiveness than Permission.
LBYL - Look Before You Leap.
好的代碼:
d = {'x': '5'}
try:
value = int(d['x'])
print(value)
except (KeyError, TypeError, ValueError):
value = None
不好的代碼:
d = {'x': '5'}
if 'x' in d and isinstance(d['x'], str) \
and d['x'].isdigit():
value = int(d['x'])
print(value)
else:
value = None
7. 使用enumerate進行迭代。
好的代碼:
fruits = ['orange', 'grape', 'pitaya', 'blueberry']
for index, fruit in enumerate(fruits):
print(index, ':', fruit)</pre>
不好的代碼:
fruits = ['orange', 'grape', 'pitaya', 'blueberry']
index = 0
for fruit in fruits:
print(index, ':', fruit)
index += 1</pre>
8. 用生成式生成列表惶翻。
好的代碼:
data = [7, 20, 3, 15, 11]
result = [num * 3 for num in data if num > 10]
print(result) # [60, 45, 33]
不好的代碼:
data = [7, 20, 3, 15, 11]
result = []
for i in data:
if i > 10:
result.append(i * 3)
print(result) # [60, 45, 33]
9. 用zip組合鍵和值來創(chuàng)建字典姑蓝。
好的代碼:
keys = ['1001', '1002', '1003']
values = ['駱昊', '王大錘', '白元芳']
d = dict(zip(keys, values))
print(d)
不好的代碼:
keys = ['1001', '1002', '1003']
values = ['駱昊', '王大錘', '白元芳']
d = {}
for i, key in enumerate(keys):
d[key] = values[i]
print(d)
說明:這篇文章的內容來自于網絡,有興趣的讀者可以閱讀原文吕粗。纺荧、;