你所不知道的Python奇技淫巧

2021-08-09 06:32:59 字數 3668 閱讀 3526

有時候你會看到很cool的python**,你驚訝於它的簡潔,它的優雅,你不由自主地讚嘆:竟然還能這樣寫。其實,這些優雅的**都要歸功於python的特性,只要你能掌握這些pythonic的技巧,你一樣可以寫出像詩一樣的python**。

你是不是經常對呼叫模組時輸入一長串模組索引感到頭疼?說實在的,數量少的時候或許還可以勉強忍受,一旦程式規模上去了,這也是一項不容小覷的工程。

#bad

import urllib.request

url = r''

req = urllib.request.request(url)

response = urllib.request.urlopen(req)

#good

form urllib import request

url = r''

req = request.request(url)

response = request.urlopen(req)

這樣是不是節省了一點時間呢?

但是這樣簡寫可能造成模組名重複的問題,如何解決呢?

from module_a import fun as a_fun

from module_b import fun as b_fun

這樣的方法還適用於模組名比較長的模組,筆者印象最深的就是beautifulsoup模組

from bs4 import beautifulsoup as bs

html = '''

......

'''soup = bs(html)

省時省力。

這是乙個非常有用的功能,可惜很少人知道。

當你在互動介面敲**,獲得乙個臨時結果,卻沒有用變數名去儲存它的時候,可以用"_"來獲取最近一次臨時結果。

>>> 1 + 1

2>>> _

2

在"_"中儲存最後輸出的值。這在互動式模式中是非常有用的,當你在過程中沒有儲存計算結果,或者你想看最後一步執行的輸出結果。

這是乙個老生常談的問題,當我們需要將數個字串合併的時候,習慣性的使用"+"作為連線字串的手段。

然而,由於不可變物件在記憶體中生成後無法修改,合併後的字串會重新開闢出一塊記憶體空間來儲存。這樣像滾雪球一樣,將記憶體快速消耗殆盡。

# bad

string = ['a','b','c','d','e','f','g','h']

deffun

(string)

: all_string = ''

for i in

string:

all_string += i

return all_string

# good

string = ['a','b','c','d','e','f','g,'h']

def fun(string):

all_string = '

'.join(string)

return all_string

它是python的內建函式,zip函式接受任意多個(包括0個和1個)序列作為引數,返回乙個包含tuple的list。zip()函式可以在很多場景簡化你的**。

矩陣的行列互換

# bad

a = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]

re_a = [[row[col] for row in a] for col in range(len(a))]

>>> [[1, 4, 7], [2, 5, 8], [3, 6, 9]]

# good

a = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]

re_a = list(zip(*a))

>>> [[1, 4, 7], [2, 5, 8], [3, 6, 9]]

交換dict的鍵值

# bad

a =

defreverse_dict

(a):

new_dict = {}

for k,v in m.items():

new_dict[v] = k

return new_dict

# good

a =

defreverse_dict

(a):

k = a.keys()

v = a.values()

new_dict = dict(zip(v, k))

return new_dict

合併list相鄰項

a = [1, 2, 3, 4, 5, 6]

list(zip( a[::2], a[1::2] ))

>>> [(1, 2), (3, 4), (5, 6)]

# bad

tmp = a

a = b

b = tmp

#good

a, b = b, a

a = [8, 23, 45, 12, 78]

for index, value

in enumerate(a):

print(index , value)

try:

pass

except (exceptiona,exceptionb,.....) as e:

pass

a = [1, 2, 3, 4, 5, 6]

list

(zip( *[iter(a)]*2 ))

>>> [(1, 2), (3, 4), (5, 6)]

a = ['a', 'b', 'c', 'd', 'e', 'f']

a_i = a.index(a)

>>> 0

#bad

a = 'python is a powerful languange.'

list_a = list(a)

list_a.reverse()

re_a = ''.join(list_a)

#good

a = 'python is a powerful languange.'

re_a = a[::-1]

x = 2if1

< x <3:

print(x)

>>> 2if

1< x >0:

print(x)

>>>

2

平時在使用類似檔案的流物件時,使用完畢後要呼叫close方法關閉。with…as語句提供了乙個非常方便的替代方法:open開啟檔案後將返回的檔案流物件賦值給f,然後在with語句塊中使用。with語句塊完畢之後,會隱藏地自動關閉檔案。

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

f.read()

crash = dict(zip(range(10 **0xa), range(10 **0xa)))
更多python相關技巧:/blog/

你所不知道的Python奇技淫巧

有時候你會看到很cool的python 你驚訝於它的簡潔,它的優雅,你不由自主地讚嘆 竟然還能這樣寫。其實,這些優雅的 都要歸功於python的特性,只要你能掌握這些pythonic的技巧,你一樣可以寫出像詩一樣的python 你是不是經常對呼叫模組時輸入一長串模組索引感到頭疼?說實在的,數量少的時...

你所不知道的 const

const 常量是不可修改的,也就是說only read,例如 const int nbuffsize 512 nbuffsize 0 error就是因為const 常量不能修改,所以定義時必須初始化預設在全域性作用域中定義的非const變數可以在整個程式中訪問,例如 int ncounter ex...

你所不知道的background

今天要說說css中background這個屬性裡面的大學問。在乙個宣告中設定所有的背景屬性 body 看到這串 你怕了嗎?知道他們都代表啥意思嘛?不要捉急,來看展開式。展開式 background color設定元素的背景顏色,不能設定到外邊距,可以繼承父級的背景顏色,預設為透明。backgroun...