前言
本文主要給大家總結介紹了關于Python的一些基礎技巧,分享出來供大家參考學習,下面話不多說了,來一起看看詳細的介紹吧。
1.startswith()和endswith()參數可以是元組
當檢測字符串開頭或結尾時,如果有多個檢測值,可以用元組作為startswith()和endswith()參數:
# badif image.endswith('.jpg') or image.endswith('.png') or image.endswith('.gif'): pass# goodif image.endswith(('.jpg', '.png', '.gif')): pass# badif url.startswith('http:') or url.startswith('https:') or url.startswith('ftp:'): pass# goodif url.startswith(('http:', 'https:', 'ftp:')): pass2.enumerate()設置start參數做為索引起始值
當用enumerate()迭代同時要得到索引時,可以設置start參數作為索引起始值:
# badfor index, v in enumerate(data): print(index+1, v)# goodfor index, v in enumerate(data, start=1): print(index, v)
3.對切片命名
當代碼中到處都是硬編碼的切片索引時,我們的代碼將變得無法閱讀。可以對切片命名解決此問題:
record = '....................100.................513.25......'# badcost = int(record[20:23]) * float(record[40:46])# goodSHARES = slice(20, 23)PRICE = slice(40, 46)cost = int(record[SHARES]) * float(record[PRICE])
作為一條基本準則,代碼中如果有很多硬編碼的索引值,將導致可讀性合可維護性都不佳。一般來說,內置的slice()函數會創建一個切片對象,可以用在任何允許進行切片操作的地方。例如:
>>> items = [0, 1, 2, 3, 4, 5, 6]>>> a = slice(2, 4)>>> items[2:4][2, 3]>>> items[a][2, 3]>>> items[a] = [-2, -3]>>> items[0, 1, -2, -3, 4, 5, 6]>>> del items[a]>>> items[0, 1, 4, 5, 6]>>>
4.上下文管理器可以同時管理多個資源
假設你要讀取一個文件的內容,經過處理以后,寫入到另一個文件。你能寫出pythonic的代碼,所以你使用了上下文管理器,滿意地的寫出了下面這樣的代碼:
 with open('input.txt', 'r') as source: with open('output.txt', 'w') as target:  target.write(source.read())你已經做的很好了,但是上下文管理器可以同時管理多個資源,上面這段代碼還可以這樣寫:
 with open('input.txt', 'r') as source, open('output.txt', 'w') as target:  target.write(source.read())5.else子句
Python中的else子句不僅能在if語句中使用,還能在for、while、和try語句中使用。
在for循環或是while循環正常運行完畢時(而不是通過break語句或是return語句或是異常退出循環),才會運行else塊。
舉個例子:
>>> for i in range(3):...  print(i)... else:...  print('Iterated over everything')... 012Iterated over everything>>>如上,for循環正常結束,所以運行了后面的else塊。
>>> for i in range(3):...  if i == 2:...   break...  print(i)... else:...  print('Iterated over everything')... 01>>>由此可以看出,for循環如果沒有正常運行完畢(如上面是break結束循環的),是不會運行后面的else塊。
僅當try塊中沒有異常拋出時才運行else塊。一開始,你可能覺得沒必要在try/except塊中使用else子句。畢竟,在下述代碼片段中,只有dangerous_call()不拋出異常,after_call()才會執行,對吧?
try: dangerous_call() after_call()except OSError: log('OSError...')然而,after_call()不應該放在try塊中。為了清晰明確,try塊中應該只包括拋出預期異常的語句。因此,向下面這樣寫更好:
try: dangerous_call()except OSError: log('OSError...')else: after_call()現在很明確,try塊防守的是dangerous_call()可能出現的錯誤,而不是after_call()。而且很明顯,只有try塊不拋出異常,才會執行after_call()。但要注意一點,else子句拋出的異常不會由前面的except子句處理,也就是說此時after_call()如果拋出異常,將不會被捕獲到。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。
新聞熱點
疑難解答