成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

你所不知道的Python技巧|系列1

開(kāi)發(fā) 后端
這些優(yōu)雅的代碼都要?dú)w功于Python的特性,只要你能掌握這些Pythonic的技巧,你一樣可以寫(xiě)出像詩(shī)一樣的Python代碼。

有時(shí)候你會(huì)看到很Cool的Python代碼,你驚訝于它的簡(jiǎn)潔,它的優(yōu)雅,你不由自主地贊嘆:竟然還能這樣寫(xiě)。其實(shí),這些優(yōu)雅的代碼都要?dú)w功于Python的特性,只要你能掌握這些Pythonic的技巧,你一樣可以寫(xiě)出像詩(shī)一樣的Python代碼。

[[315754]]

1.導(dǎo)入模塊

你是不是經(jīng)常對(duì)調(diào)用模塊時(shí)輸入一長(zhǎng)串模塊索引感到頭疼?說(shuō)實(shí)在的,數(shù)量少的時(shí)候或許還可以勉強(qiáng)忍受,一旦程序規(guī)模上去了,這也是一項(xiàng)不容小覷的工程。 

  1. import urllib.request  
  2. url = r'http://www.landsblog.com'  
  3. req = urllib.request.Request(url)  
  4. response = urllib.request.urlopen(req)  
  5. form urllib import request  
  6. url = r'http://www.landsblog.com'  
  7. req = request.Request(url)  
  8. response = request.urlopen(req) 

這樣是不是節(jié)省了一點(diǎn)時(shí)間呢?

但是這樣簡(jiǎn)寫(xiě)可能造成模塊名重復(fù)的問(wèn)題,如何解決呢? 

  1. from module_a import fun as a_fun  
  2. from module_b import fun as b_fun 

這樣的方法還適用于模塊名比較長(zhǎng)的模塊,筆者印象最深的就是BeautifulSoup模塊 

  1. from bs4 import BeautifulSoup as BS  
  2. html = '' 
  3.        <html>  
  4.             ......  
  5.        </html>  
  6.        '''  
  7. soup = BS(html) 

省時(shí)省力。

2.關(guān)于 "_" ##

這是一個(gè)非常有用的功能,可惜很少人知道。

當(dāng)你在交互界面敲代碼,獲得一個(gè)臨時(shí)結(jié)果,卻沒(méi)有用變量名去保存它的時(shí)候,可以用"_"來(lái)獲取最近一次臨時(shí)結(jié)果。 

  1. >>> 1 + 1  
  2.  
  3. >>> _  

在"_"中存儲(chǔ)最后輸出的值。這在交互式模式中是非常有用的,當(dāng)你在過(guò)程中沒(méi)有保存計(jì)算結(jié)果,或者你想看最后一步執(zhí)行的輸出結(jié)果。

3.合并字符串

這是一個(gè)老生常談的問(wèn)題,當(dāng)我們需要將數(shù)個(gè)字符串合并的時(shí)候,習(xí)慣性的使用"+"作為連接字符串的手段。

然而,由于不可變對(duì)象在內(nèi)存中生成后無(wú)法修改,合并后的字符串會(huì)重新開(kāi)辟出一塊內(nèi)存空間來(lái)存儲(chǔ)。這樣像滾雪球一樣,將內(nèi)存快速消耗殆盡。 

  1. # Bad  
  2. string = ['a','b','c','d','e','f','g','h']  
  3. def fun(string):  
  4.     all_string = ''  
  5.     for i in string:  
  6.         all_string += i  
  7.     return all_string  
  8. # Good  
  9. string = ['a','b','c','d','e','f','g,'h']  
  10. def fun(string):  
  11.     all_string = ''.join(string)  
  12.     return all_string 

4.強(qiáng)大的zip()

它是Python的內(nèi)建函數(shù),zip函數(shù)接受任意多個(gè)(包括0個(gè)和1個(gè))序列作為參數(shù),返回一個(gè)包含tuple的list。zip()函數(shù)可以在很多場(chǎng)景簡(jiǎn)化你的代碼。 

  1. ## 矩陣的行列互換  
  2. # Bad  
  3. a = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]  
  4. re_a = [[row[col] for row in a] for col in range(len(a))]  
  5. >>> [[1, 4, 7], [2, 5, 8], [3, 6, 9]]  
  6. # Good  
  7. a = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]  
  8. re_a = list(zip(*a))  
  9. >>> [[1, 4, 7], [2, 5, 8], [3, 6, 9]]  
  10. ## 交換dict的鍵值  
  11. a = {'a': 1, 'b': 2, 'c': 3, 'd': 4}  
  12. def reverse_dict(a):  
  13.     new_dict = {}  
  14.     for k,v in m.items():  
  15.         new_dict[v] = k  
  16.     return new_dict 
  17. a = {'a': 1, 'b': 2, 'c': 3, 'd': 4}  
  18. def reverse_dict(a):  
  19.     k = a.keys()  
  20.     v = a.values()  
  21.     new_dict = dict(zip(v, k))  
  22.     return new_dict  
  23. ## 合并list相鄰項(xiàng)  
  24. a = [1, 2, 3, 4, 5, 6]  
  25. list(zip( a[::2], a[1::2] ))  
  26. >>> [(1, 2), (3, 4), (5, 6)] 

5.變量值交換 

  1. tmp = a  
  2. a = b  
  3. b = tmp  
  4. a, bb = b, a 

6.在循環(huán)中獲取索引(數(shù)組下標(biāo))? 

  1. a = [8, 23, 45, 12, 78]  
  2. for index, value in enumerate(a):  
  3. print(index , value) 

7.如何在只用一行捕獲多個(gè)異常? 

  1. try:  
  2.     pass  
  3. except (ExceptionA,ExceptionB,.....) as e:  
  4.     pass 

8.把列表分割成同樣大小的塊? 

  1. a = [1, 2, 3, 4, 5, 6]  
  2. list(zip( *[iter(a)]*2 ))  
  3. >>> [(1, 2), (3, 4), (5, 6)] 

9.如何查找列表中某個(gè)元素的下標(biāo)? 

  1. a = ['a', 'b', 'c', 'd', 'e', 'f']  
  2. aa_i = a.index(a)  
  3. >>> 0 

10.如何快速反轉(zhuǎn)字符串?

  1. a = 'Python is a powerful languange.'  
  2. listlist_a = list(a)  
  3. list_a.reverse()  
  4. re_a = ''.join(list_a)  
  5. a = 'Python is a powerful languange.'  
  6. re_a = a[::-1] 

11.數(shù)值比較 

  1. x = 2  
  2. if 1< x <3:  
  3.     print(x)  
  4. >>> 2  
  5. if 1< x >0:  
  6.     print(x)  
  7. >>> 2 

12.優(yōu)雅的打開(kāi)文件

平時(shí)在使用類(lèi)似文件的流對(duì)象時(shí),使用完畢后要調(diào)用close方法關(guān)閉。with…as語(yǔ)句提供了一個(gè)非常方便的替代方法:open打開(kāi)文件后將返回的文件流對(duì)象賦值給f,然后在with語(yǔ)句塊中使用。with語(yǔ)句塊完畢之后,會(huì)隱藏地自動(dòng)關(guān)閉文件。 

  1. with open('nothing.txt','r') as f:  
  2.     f.read() 

13.和你的內(nèi)存說(shuō)再見(jiàn) 

  1. crash = dict(zip(range(10 **0xA), range(10 **0xA)))  

 

責(zé)任編輯:龐桂玉 來(lái)源: 馬哥Linux運(yùn)維
相關(guān)推薦

2017-10-10 13:58:38

前端CSS濾鏡技巧

2020-01-29 19:40:36

Python美好,一直在身邊Line

2021-01-05 11:22:58

Python字符串代碼

2023-12-21 14:40:09

Python編程語(yǔ)言

2017-12-15 13:44:22

2020-08-11 11:20:49

Linux命令使用技巧

2017-12-25 13:26:36

CNN深度學(xué)習(xí)網(wǎng)絡(luò)

2020-08-05 12:17:00

C語(yǔ)言代碼分配

2018-11-25 10:08:44

阿里巴巴技術(shù)開(kāi)源

2022-12-07 08:16:50

Vue 3技巧數(shù)組

2015-08-13 09:03:14

調(diào)試技巧

2017-03-02 14:05:42

AndroidAndroid Stu調(diào)試技巧

2018-09-02 15:43:56

Python代碼編程語(yǔ)言

2021-01-29 13:22:58

Swagger版本OpenAPI

2018-01-26 08:26:35

RAID陣列組成

2013-09-09 09:59:39

虛擬化云計(jì)算

2020-07-28 08:26:34

WebSocket瀏覽器

2020-06-12 09:20:33

前端Blob字符串

2017-07-21 09:48:45

SQL索引查詢

2010-03-03 16:26:10

ubantu使用技巧
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 一区二区三区亚洲视频 | 精品国产1区2区3区 在线国产视频 | 91精品国产91久久综合桃花 | 不卡一区二区三区四区 | 日韩欧美精品 | 91久久久精品国产一区二区蜜臀 | 午夜天堂精品久久久久 | 一级黄色av电影 | 黑人精品欧美一区二区蜜桃 | 91久色| 国产精品福利在线观看 | 国产综合网址 | 午夜成人免费视频 | 成人久草| 色香蕉在线 | 91精品国产一区二区三区 | 欧美成人精品一区二区三区 | 日韩在线一区二区三区 | 国产91一区二区三区 | 天天色天天色 | 99pao成人国产永久免费视频 | 亚洲男人的天堂网站 | h片在线看 | 国产一区二区在线免费观看 | 99国产精品久久久久 | 欧美成人一区二区三区片免费 | 一级毛片在线播放 | 黄色片视频网站 | 天天操夜夜操 | 亚洲一区欧美一区 | av第一页 | www视频在线观看 | av一级在线观看 | 国产在线一区二区三区 | 国产精品久久久久久久久久久新郎 | 天天爱天天操 | 国产a区 | 极品国产视频 | 国产精品欧美一区二区三区不卡 | 国产黄色免费网站 | 亚洲人在线 |