欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

10個Python小技巧你值得擁有

 更新時間:2018年09月29日 11:44:35   作者:愛你喲編程  
這篇文章主要介紹了10個Python小技巧,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下

列表推導(dǎo)式

你有一個list: bag = [1, 2, 3, 4, 5]

現(xiàn)在你想讓所有元素翻倍,讓它看起來是這個樣子: [2, 4, 6, 8, 10]

大多初學(xué)者,根據(jù)之前語言的經(jīng)驗會大概這樣來做

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的列表推導(dǎo)式 。

遍歷列表

還是上面的列表。如果可能盡量避免這樣做:

bag = [1, 2, 3, 4, 5] 
for i in range(len(bag)): 
 print(bag[i])

取而代之的應(yīng)該是這樣:

bag = [1, 2, 3, 4, 5] 
for i in bag: 
 print(i)

如果 x 是一個列表,你可以對它的元素進(jìn)行迭代。多數(shù)情況下你不需要各元素的索引,但如果你非要這樣做,那就用 enumerate 函數(shù)。它像下邊的樣子:

bag = [1, 2, 3, 4, 5] 
for index, element in enumerate(bag): 
 print(index, element)

非常直觀明了。

元素互換

如果你是從java或者C語言轉(zhuǎn)到Python來,可能會習(xí)慣于這樣:

a = 5 
b = 10
# 交換 a 和 b
tmp = a 
a = b 
b = tmp

但Python提供了一個更自然更好的方法!

a = 5 
b = 10 
# 交換a 和 b
a, b = b, a

初始化列表

假如你要一個是10個整數(shù)0的列表,你可能首先想到:

bag = [] 
for _ in range(10): 
 bag.append(0)

換個方式吧:

bag = [0] * 10

看,多優(yōu)雅。

注意:如果你列表包含了列表,這樣做會產(chǎn)生淺拷貝。

舉個例子:

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]]

“過早優(yōu)化是萬惡之源”問問自己,初始化一個列表是必須的嗎?

構(gòu)造字符串

你會經(jīng)常需要打印字符串。要是有很多變量,避免下面這樣:

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)

返回tuple元組

Python允許你在一個函數(shù)中返回多個元素,這讓生活更簡單。但是在解包元組的時候出出線這樣的常見錯誤:

def binary(): return 0, 1
result = binary() 
zero = result[0] 
one = result[1]

這是沒必要的,你完全可以換成這樣:

def binary(): return 0, 1
zero, one = binary()

要是你需要所有的元素被返回,用個下劃線 _ :

zero, _ = binary()

就是這么高效率!

訪問Dict字典

你也會經(jīng)常給 dicts 中寫入 key,value (鍵,值)。

如果你試圖訪問一個不存在的于 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)))

當(dāng)然你也可以用 setdefault 來代替。

這還用一個更簡單卻多費(fèi)點(diǎn)開銷的辦法:

bag = [2, 3, 1, 2, 5, 6, 7, 9, 2, 7] 
# {2: 3, 3: 1, 1: 1, 5: 1, 6: 1, 7: 2, 9: 1}
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 推導(dǎo)式。

countr = {num: bag.count(num) for num in bag}

這兩種方法開銷大是因為它們在每次 count 被調(diào)用時都會對列表遍歷。

使用庫

現(xiàn)有的庫只需導(dǎo)入你就可以做你真正想做的了。

還是說前面的例子,我們建一個函數(shù)來數(shù)一個數(shù)字在列表中出現(xiàn)的次數(shù)。那么,已經(jīng)有一個庫就可以做這樣的事情。

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]))

一些用庫的理由:

•代碼是正確而且經(jīng)過測試的。
•它們的算法可能會是最優(yōu)的,這樣就跑的更快。
•抽象化:它們指向明確而且文檔友好,你可以專注于那些還沒有被實現(xiàn)的。
•最后,它都已經(jīng)在那兒了,你不用再造輪子了。
•在列表中切片/步進(jìn)

你可以指定 start 的點(diǎn)和 stop 點(diǎn),就像這樣 list[start:stop:step] 。我們?nèi)〕隽斜碇械那?個元素:

bag = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] 
for elem in bag[:5]: 
 print(elem)

這就是切片,我們指定 stop 點(diǎn)是5,再停止前就會從列表中取出5個元素。

要是最后5個元素怎么做?

bag = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] 
for elem in bag[-5:]: 
 print(elem)

沒看明白嗎? -5 意味著從列表的結(jié)尾取出5個元素。

如果你想對列表中元素間隔操作,你可能會這樣做:

bag = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] 
for index, elem in enumerate(bag): 
 if index % 2 == 0: 
print(elem)

但是你應(yīng)該這樣來做:

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)

這就是列表中的步進(jìn)。 list[::2] 意思是遍歷列表同時兩步取出一個元素。

你可以用 list[::-1] 很酷的翻轉(zhuǎn)列表。

tab鍵還是空格

長時間來看,將tab和空格混在一起會帶來很多不必要的麻煩,你會看到 IndentationError: unexpected indent 。不管你選擇tab鍵還是空格鍵,你應(yīng)該在你的文件和項目中一直保持使用。

一個使用空格而不是tab的原因是,tab不是在所有編輯器中都一樣的。視呢所用的編輯器,tab可能會被當(dāng)作2到8個空格。

你也可以在寫代碼時用空格來定義tab。這樣你可以自己選擇用幾個空格來當(dāng)做tab。大多數(shù)Python用戶是用4個空格。

總結(jié)

以上所述是小編給大家介紹的10個Python小技巧你值得擁有,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • Python返回真假值(True or False)小技巧

    Python返回真假值(True or False)小技巧

    這篇文章主要介紹了Python返回真假值(True or False)小技巧,本文探討的是最簡潔的條件判斷語句寫法,本文給出了兩種簡潔寫法,需要的朋友可以參考下
    2015-04-04
  • python3使用logging包,如何把日志寫到系統(tǒng)的rsyslog中

    python3使用logging包,如何把日志寫到系統(tǒng)的rsyslog中

    這篇文章主要介紹了python3使用logging包,如何把日志寫到系統(tǒng)的rsyslog中的問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • appium中常見的幾種點(diǎn)擊方式

    appium中常見的幾種點(diǎn)擊方式

    本文主要介紹了appium中常見的幾種點(diǎn)擊方式,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • 基于PyTorch實現(xiàn)EdgeCNN的實戰(zhàn)教程

    基于PyTorch實現(xiàn)EdgeCNN的實戰(zhàn)教程

    本文我們將使用PyTorch來簡易實現(xiàn)一個EdgeCNN,不使用PyG庫,讓新手可以理解如何PyTorch來搭建一個簡易的圖網(wǎng)絡(luò)實例demo,感興趣的朋友跟隨小編一起看看吧
    2023-02-02
  • python 識別圖片中的文字信息方法

    python 識別圖片中的文字信息方法

    今天小編就為大家分享一篇python 識別圖片中的文字信息方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-05-05
  • PyTorch一小時掌握之圖像識別實戰(zhàn)篇

    PyTorch一小時掌握之圖像識別實戰(zhàn)篇

    這篇文章主要介紹了PyTorch一小時掌握之圖像識別實戰(zhàn)篇,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-09-09
  • Python中的pathlib.Path為什么不繼承str詳解

    Python中的pathlib.Path為什么不繼承str詳解

    這篇文章主要給大家介紹了關(guān)于Python中pathlib.Path為什么不繼承str的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用Python具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • 手動實現(xiàn)把python項目發(fā)布為exe可執(zhí)行程序過程分享

    手動實現(xiàn)把python項目發(fā)布為exe可執(zhí)行程序過程分享

    這篇文章主要介紹了手動實現(xiàn)把python項目發(fā)布為exe可執(zhí)行程序過程分享,本文使用C語言實現(xiàn)了一個簡潔的Python打包程序,需要的朋友可以參考下
    2014-10-10
  • python安裝與使用redis的方法

    python安裝與使用redis的方法

    這篇文章主要介紹了python安裝與使用redis的方法,分析了安裝與配置的具體步驟,并結(jié)合實例詳細(xì)分析了redis數(shù)據(jù)庫的具體使用技巧,需要的朋友可以參考下
    2016-04-04
  • Python讀取Pickle文件信息并計算與當(dāng)前時間間隔的方法分析

    Python讀取Pickle文件信息并計算與當(dāng)前時間間隔的方法分析

    這篇文章主要介紹了Python讀取Pickle文件信息并計算與當(dāng)前時間間隔的方法,涉及Python基于pickle模塊操作文件屬性相關(guān)實現(xiàn)技巧,需要的朋友可以參考下
    2019-01-01

最新評論