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

分享Python開(kāi)發(fā)中要注意的十個(gè)小貼士

 更新時(shí)間:2016年08月30日 08:49:18   投稿:daisy  
不管是python開(kāi)發(fā)還是其他什么語(yǔ)言的開(kāi)發(fā),如果在開(kāi)發(fā)中我們能掌握一些有用的貼士和技巧,那么肯定會(huì)大大提高我們的開(kāi)發(fā)效率,今天小編和大家分享的就是python開(kāi)發(fā)中,一些初學(xué)這門(mén)語(yǔ)言常常會(huì)犯的錯(cuò)誤,一起來(lái)看看吧。

大家請(qǐng)注意:這篇文中假設(shè)我們都用的是Python 3

1. 列表推導(dǎo)式

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

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

大多初學(xué)者,根據(jù)之前語(yǔ)言的經(jīng)驗(yàn)會(huì)大概這樣來(lái)做

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

但是有更好的方法:

bag = [elem * 2 for elem in bag]

很簡(jiǎn)潔對(duì)不對(duì)?這叫做Python的列表推導(dǎo)式。

2. 遍歷列表

繼續(xù),還是上面的列表。

如果可能盡量避免這樣做:

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

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

非常直觀明了。

3. 元素互換

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

a = 5 
b = 10

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

但Python提供了一個(gè)更自然更好的方法!

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

夠漂亮吧?

4. 初始化列表

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

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

換個(gè)方式吧:

bag = [0] * 10

看,多優(yōu)雅。

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

舉個(gè)例子:

bag_of_bags = [[0]] * 5 # [[0], [0], [0], [0], [0]] 
bag_of_bags[0][0] = 1 # [[1], [1], [1], [1], [1]]

Oops!所有的列表都改變了,而我們只是想要改變第一個(gè)列表。

改一改啦:

bag_of_bags = [[0] for _ in range(5)] 
# [[0], [0], [0], [0], [0]]

bag_of_bags[0][0] = 1 
# [[1], [0], [0], [0], [0]]

同時(shí)記?。?/p>

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

5. 構(gòu)造字符串

你會(huì)經(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)

額,這看起來(lái)多亂呀?你可以用個(gè)漂亮簡(jiǎn)潔的方法來(lái)代替, .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. 返回tuples(元組)

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

def binary(): 
 return 0, 1

result = binary() 
zero = result[0] 
one = result[1]

這是沒(méi)必要的,你完全可以換成這樣:

def binary(): 
 return 0, 1

zero, one = binary()

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

zero, _ = binary()

就是這么高效率!

7. 訪問(wèn)Dicts(字典)

你也會(huì)經(jīng)常給dicts中寫(xiě)入keypair(鍵,值)。

如果你試圖訪問(wèn)一個(gè)不存在的于dictkey,可能會(huì)為了避免KeyError錯(cuò)誤,你會(huì)傾向于這樣做:

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()是個(gè)更好的辦法。

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來(lái)代替。

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

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

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

這兩種方法開(kāi)銷大是因?yàn)樗鼈冊(cè)诿看?code>count被調(diào)用時(shí)都會(huì)對(duì)列表遍歷。

8 使用庫(kù)

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

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

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

一些用庫(kù)的理由:

      1、代碼是正確而且經(jīng)過(guò)測(cè)試的。

      2、它們的算法可能會(huì)是最優(yōu)的,這樣就跑的更快。

      3、抽象化:它們指向明確而且文檔友好,你可以專注于那些還沒(méi)有被實(shí)現(xiàn)的。

      4、最后,它都已經(jīng)在那兒了,你不用再造輪子了。

9. 在列表中切片/步進(jìn)

你可以指定start的點(diǎn)和stop點(diǎn),就像這樣list[start:stop:step]

我們?nèi)〕隽斜碇械那?個(gè)元素:

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

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

要是最后5個(gè)元素怎么做?

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

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

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

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)該這樣來(lái)做:

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]意思是遍歷列表同時(shí)兩步取出一個(gè)元素。

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

10. tab鍵還是空格鍵

長(zhǎng)時(shí)間來(lái)看,將tab和空格混在一起會(huì)造成災(zāi)難,你會(huì)看到IndentationError: unexpected indent。不管你選擇tab鍵還是空格鍵,你應(yīng)該在你的文件和項(xiàng)目中一直保持使用。

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

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

總結(jié)

以上就是為大家總結(jié)的Python開(kāi)發(fā)中要注意的小貼士,希望對(duì)大家學(xué)習(xí)和使用python能有所幫助,如果有疑問(wèn)可以留言交流。

相關(guān)文章

  • Python基礎(chǔ)教程之NumPy庫(kù)的使用詳解

    Python基礎(chǔ)教程之NumPy庫(kù)的使用詳解

    NumPy(Numerical Python)是一個(gè)用于處理數(shù)組的Python庫(kù),學(xué)習(xí)機(jī)器學(xué)習(xí)的過(guò)程中先學(xué)會(huì)使用NumPy是非常重要的,所以本文就給大家詳細(xì)介紹一下如何使用NumPy庫(kù),需要的小伙伴跟著小編一起來(lái)看看吧
    2023-07-07
  • 8個(gè)Python必備的PyCharm插件(附下載地址)

    8個(gè)Python必備的PyCharm插件(附下載地址)

    Python是一種廣泛使用的編程語(yǔ)言,PyCharm是最受歡迎的Python IDE之一,本文就來(lái)介紹一下8個(gè)Python必備的PyCharm插件,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-01-01
  • Python中刪除文件的幾種方法實(shí)例

    Python中刪除文件的幾種方法實(shí)例

    這篇文章主要給大家介紹了關(guān)于Python中刪除文件的幾種方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • python批量處理多DNS多域名的nslookup解析實(shí)現(xiàn)

    python批量處理多DNS多域名的nslookup解析實(shí)現(xiàn)

    這篇文章主要介紹了python批量處理多DNS多域名的nslookup解析實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • Python 給屏幕打印信息加上顏色的實(shí)現(xiàn)方法

    Python 給屏幕打印信息加上顏色的實(shí)現(xiàn)方法

    這篇文章主要介紹了Python 給屏幕打印信息加上顏色的實(shí)現(xiàn)方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-04-04
  • 在Python中,不用while和for循環(huán)遍歷列表的實(shí)例

    在Python中,不用while和for循環(huán)遍歷列表的實(shí)例

    今天小編就為大家分享一篇在Python中,不用while和for循環(huán)遍歷列表的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-02-02
  • python共軛梯度法特征值迭代次數(shù)討論

    python共軛梯度法特征值迭代次數(shù)討論

    這篇文章主要介紹了python共軛梯度法特征值迭代次數(shù)討論,想了解共軛梯度法的同學(xué),需要著重看一下
    2021-04-04
  • Python實(shí)現(xiàn)按照指定要求逆序輸出一個(gè)數(shù)字的方法

    Python實(shí)現(xiàn)按照指定要求逆序輸出一個(gè)數(shù)字的方法

    這篇文章主要介紹了Python實(shí)現(xiàn)按照指定要求逆序輸出一個(gè)數(shù)字的方法,涉及Python針對(duì)字符串的遍歷、判斷、輸出等相關(guān)操作技巧,需要的朋友可以參考下
    2018-04-04
  • python?selenium保存圖片最好的兩種方法

    python?selenium保存圖片最好的兩種方法

    大家好,本篇文章主要講的是python?selenium保存圖片最好的兩種方法,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下
    2022-01-01
  • 基于Python實(shí)現(xiàn)拆分和合并GIF動(dòng)態(tài)圖

    基于Python實(shí)現(xiàn)拆分和合并GIF動(dòng)態(tài)圖

    這篇文章主要介紹了Python拆分和合并GIF動(dòng)態(tài)圖,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-10-10

最新評(píng)論