對新學習Python的小夥伴來說,既感受到了短程式碼的開心,也更願意用到一些簡短的Python寫法,下麵是我使用Python過程總收集的一些技巧,希望對你有所幫助。
1. 串列推導式
你有一個list:bag = [1, 2, 3, 4, 5]
現在你想讓所有元素翻倍,讓它看起來是這個樣子:[2, 4, 6, 8, 10]
大多初學者,根據之前語言的經驗會大概這樣來做
bag = [1, 2, 3, 4, 5]
for i in range(len(bag)):
bag[i] = bag[i] * 2
但是有更好的方法:
bag = [elem * 2 for elem in bag]
很簡潔對不對?這叫做Python的串列推導式。
點選Trey Hunner’s tutorial[1]檢視更多關於串列推導式的介紹。
2. 遍歷串列
繼續,還是上面的串列。
如果可能儘量避免這樣做:
bag = [1, 2, 3, 4, 5]
for i in range(len(bag)):
print(bag[i])
取而代之的應該是這樣:
bag = [1, 2, 3, 4, 5]
for i in bag:
print(i)
如果x是一個串列,你可以對它的元素進行迭代。多數情況下你不需要各元素的索引,但如果你非要這樣做,那就用enumerate函式。它像下邊的樣子:
bag = [1, 2, 3, 4, 5]
for index, element in enumerate(bag):
print(index, element)
非常直觀明瞭。
3. 元素互換
如果你是從java或者C語言轉到Python來,可能會習慣於這樣:
a = 5
b = 10
# 交換 a 和 b
tmp = a
a = b
b = tmp
但Python提供了一個更自然更好的方法!
a = 5
b = 10
# 交換a 和 b
a, b = b, a
夠漂亮吧?
4. 初始化串列
假如你要一個是10個整數0的串列,你可能首先想到:
bag =
for _ in range(10):
bag.append(0)
換個方式吧:
bag = [0] * 10
看,多優雅。
註意:如果你串列包含了串列,這樣做會產生淺複製。
舉個例子:
bag_of_bags = [[0]] * 5 # [[0], [0], [0], [0], [0]]
bag_of_bags[0][0] = 1 # [[1], [1], [1], [1], [1]]
Oops!所有的串列都改變了,而我們只是想要改變第一個串列。
改一改啦:
bag_of_bags = [[0] for _ in range(5)]
# [[0], [0], [0], [0], [0]]
bag_of_bags[0][0] = 1
# [[1], [0], [0], [0], [0]]
同時記住:
“過早最佳化是萬惡之源”
問問自己,初始化一個串列是必須的嗎?
5. 構造字串
你會經常需要列印字串。要是有很多變數,避免下麵這樣:
name = “Raymond”
age = 22
born_in = “Oakland, CA”
string = “Hello my name is ” + name + “and I’m ” + str(age) + ” years old. I was born in ” + born_in + “.”
print(string)
額,這看起來多亂呀?你可以用個漂亮簡潔的方法來代替,.format。
這樣做:
name = “Raymond”
age = 22
born_in = “Oakland, CA”
string = “Hello my name is {0} and I’m {1} years old. I was born in {2}.”.format(name, age, born_in)
print(string)
好多了!
6. 傳回
Python允許你在一個函式中傳回多個元素,這讓生活更簡單。但是在解包元組的時候出出線這樣的常見錯誤:
def binary:
return 0, 1
result = binary
zero = result[0]
one = result[1]
這是沒必要的,你完全可以換成這樣:
def binary:
return 0, 1
zero, one = binary
要是你需要所有的元素被傳回,用個下劃線_:
zero, _ = binary
就是這麼高效率!
7. 訪問
你也會經常給dicts中寫入key,pair(鍵,值)。
如果你試圖訪問一個不存在的於dict的key,可能會為了避免KeyError錯誤,你會傾向於這樣做:
countr = {}
bag = [2, 3, 1, 2, 5, 6, 7, 9, 2, 7]
for i in bag:
if i in countr:
countr[i] += 1
else:
countr[i] = 1
for i in range(10):
if i in countr:
print(“Count of {}: {}”.format(i, countr[i]))
else:
print(“Count of {}: {}”.format(i, 0))
但是,用get是個更好的辦法。
countr = {}
bag = [2, 3, 1, 2, 5, 6, 7, 9, 2, 7]
for i in bag:
countr[i] = countr.get(i, 0) + 1
for i in range(10):
print(“Count of {}: {}”.format(i, countr.get(i, 0)))
當然你也可以用setdefault來代替。
這還用一個更簡單卻多費點開銷的辦法:
bag = [2, 3, 1, 2, 5, 6, 7, 9, 2, 7]
countr = dict([(num, bag.count(num)) for num in bag])
for i in range(10):
print(“Count of {}: {}”.format(i, countr.get(i, 0)))
你也可以用dict推導式。
countr = {num: bag.count(num) for num in bag}
這兩種方法開銷大是因為它們在每次count被呼叫時都會對串列遍歷。
8. 使用庫
現有的庫只需匯入你就可以做你真正想做的了。
還是說前面的例子,我們建一個函式來數一個數字在串列中出現的次數。那麼,已經有一個庫就可以做這樣的事情。
from collections import Counter
bag = [2, 3, 1, 2, 5, 6, 7, 9, 2, 7]
countr = Counter(bag)
for i in range(10):
print(“Count of {}: {}”.format(i, countr[i]))
一些用庫的理由:
程式碼是正確而且經過測試的。
它們的演演算法可能會是最優的,這樣就跑的更快。
抽象化:它們指向明確而且檔案友好,你可以專註於那些還沒有被實現的。
最後,它都已經在那兒了,你不用再造輪子了。
9. 在串列中切片/步進
你可以指定start的點和stop點,就像這樣list[start:stop:step]。我們取出串列中的前5個元素:
bag = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
for elem in bag[:5]:
print(elem)
這就是切片,我們指定stop點是5,再停止前就會從串列中取出5個元素。
要是最後5個元素怎麼做?
bag = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
for elem in bag[-5:]:
print(elem)
沒看明白嗎?-5意味著從串列的結尾取出5個元素。
如果你想對串列中元素間隔操作,你可能會這樣做:
bag = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
for index, elem in enumerate(bag):
if index % 2 == 0:
print(elem)
但是你應該這樣來做:
bag = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
for elem in bag[::2]:
print(elem)
# 或者用 ranges
bag = list(range(0,10,2))
print(bag)
這就是串列中的步進。list[::2]意思是遍歷串列同時兩步取出一個元素。
你可以用list[::-1]很酷的翻轉串列。
10. tab鍵還是空格鍵
長時間來看,將tab和空格混在一起會造成災難,你會看到IndentationError: unexpected indent。不管你選擇tab鍵還是空格鍵,你應該在你的檔案和專案中一直保持使用。
一個使用空格而不是tab的原因是,tab不是在所有編輯器中都一樣的。視呢所用的編輯器,tab可能會被當作2到8個空格。
你也可以在寫程式碼時用空格來定義tab。這樣你可以自己選擇用幾個空格來當做tab。大多數Python使用者是用4個空格。
更多Python好文請點選【閱讀原文】哦
↓↓↓