下面是十個Python中頗有用的貼士和技巧。其中一些是初學這門語言經常會犯的錯誤。java
注意:假設咱們都用的是Python 3python
你有一個list:bag = [1, 2, 3, 4, 5]
web
如今你想讓全部元素翻倍,讓它看起來是這個樣子:[2, 4, 6, 8, 10]
算法
大多初學者,根據以前語言的經驗會大概這樣來作django
bag = [1, 2, 3, 4, 5] for i in range(len(bag)): bag[i] = bag[i] * 2
可是有更好的方法:app
bag = [elem * 2 for elem in bag]
很簡潔對不對?這叫作Python的列表推導式。編輯器
點擊Trey Hunner’s tutorial查看更多關於列表推導式的介紹。函數
繼續,仍是上面的列表。學習
若是可能儘可能避免這樣作:測試
bag = [1, 2, 3, 4, 5] for i in range(len(bag)): bag[i] = bag[i] * 2
取而代之的應該是這樣:
bag = [elem * 2 for elem in bag]
若是x是一個列表,你能夠對它的元素進行迭代。多數狀況下你不須要各元素的索引,但若是你非要這樣作,那就用enumerate函數。它像下邊的樣子:
bag = [1, 2, 3, 4, 5] for i in range(len(bag)): print(bag[i])
很是直觀明瞭。
若是你是從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
夠漂亮吧?
假如你要一個是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]]
同時記住:
「過早優化是萬惡之源」 問問本身,初始化一個列表是必須的嗎?
你會常常須要打印字符串。要是有不少變量,避免下面這樣:
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)
好多了!
tuples
(元組)Python容許你在一個函數中返回多個元素,這讓生活更簡單。可是在解包元組的時候出出線這樣的常見錯誤:
def binary(): return 0, 1 result = binary() zero = result[0] one = result[1]
這是不必的,你徹底能夠換成這樣:
def binary(): return 0, 1 zero, one = binary()
要是你須要全部的元素被返回,用個下劃線_:
zero, _ = binary()
就是這麼高效率!
Dicts
(字典)你也會常常給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
被調用時都會對列表遍歷。
現有的庫只需導入你就能夠作你真正想作的了。
仍是說前面的例子,咱們建一個函數來數一個數字在列表中出現的次數。那麼,已經有一個庫就能夠作這樣的事情。
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]))
一些用庫的理由:
代碼是正確並且通過測試的。 它們的算法可能會是最優的,這樣就跑的更快。 抽象化:它們指向明確並且文檔友好,你能夠專一於那些尚未被實現的。 最後,它都已經在那兒了,你不用再造輪子了。
你能夠指定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]
很酷的翻轉列表。
長時間來看,將tab和空格混在一塊兒會形成災難,你會看到IndentationError: unexpected indent
。無論你選擇tab鍵仍是空格鍵,你應該在你的文件和項目中一直保持使用。
一個使用空格而不是tab的緣由是,tab不是在全部編輯器中都同樣的。視呢所用的編輯器,tab可能會被看成2到8個空格。
你也能夠在寫代碼時用空格來定義tab。這樣你能夠本身選擇用幾個空格來當作tab。大多數Python用戶是用4個空格。
你們在學python的時候確定會遇到不少難題,以及對於新技術的追求,這裏推薦一下咱們的Python學習扣qun:784758214,這裏是python學習者彙集地!!同時,本身是一名高級python開發工程師,從基礎的python腳本到web開發、爬蟲、django、數據挖掘等,零基礎到項目實戰的資料都有整理。送給每一位python的小夥伴!每日分享一些學習的方法和須要注意的小細節