python高階程式設計讀書筆記(一)
python 高階程式設計讀書筆記,記錄以下基礎和高階用法
python2和python3相容處理
使用sys模組使程式python2和python3相容
import sysver=sys.version_info#(major=3, minor=6, micro=6)if ver<(3,0,0):# 3是版本號,0是此版本號,第二個0修訂號。 import urllib2else: import urllib 複製程式碼
獲取當前環境所用的python包
pip freeze複製程式碼
會發現輸出的所有的python包,包括python標準庫的,所以獨立的python執行環境很重要,使用virtualenv或者pipenv建立獨立的python環境很重要。
之後複製所有使用的模組到requirements.txt檔案裡。
requirements.txt 的用法
這個檔案含有當前專案使用的python包為了避免一個一個安裝專案中缺失的包我們一般用。
pip install -r requirements.txt複製程式碼
即可安裝當前專案使用的包。
使用pdb模組互動式除錯
import pdbpdb.set_trance()複製程式碼
命令 n:執行下一步,其他的命令可以通過
help pdb 複製程式碼
進行獲取。
zip均勻分配迭代物件
for i in zip(["name","sex","age"],["張三","男",25]): print(i)複製程式碼
輸出
('name', '張三')('sex', '男')('age', 25)複製程式碼
兩個列表轉化為字典的形式
print(dict(zip(["name","sex","age"],["張三","男",25])))複製程式碼
輸出
{'name': '張三', 'sex': '男', 'age': 25}複製程式碼
序列解包
a,b,c=("this","is","seq")a1,*b1,c1=("this","is","seq",'tuple')a2,b2,*c2=("this","is","seq",'tuple')print(a)print(b1)print(c2)複製程式碼
輸出
this['is', 'seq']['seq', 'tuple']複製程式碼
字典推導式
d={f"num{num}":num**2 for num in range(10)}print(d)複製程式碼
輸出
{'num0': 0, 'num1': 1, 'num2': 4, 'num3': 9, 'num4': 16, 'num5': 25, 'num6': 36, 'num7': 49, 'num8': 64, 'num9': 81}複製程式碼
for….else語句
在for後面加else的語句,表示是for迴圈自然結束的而不是因為break結束的。
for i in range(10): if i==6: breakelse: print("跳出迴圈")for i in range(10): if i==6: passelse: print("自然迴圈結束") 複製程式碼
輸出
自然迴圈結束複製程式碼
函式註解
def foo(num:4>5 and 6>7)->(6666): return num+1print(foo(5))複製程式碼
引數的冒號後計算註解值的表示式,->填入返回值型別
以上這種註解只會讓人糊塗沒什麼卵用。
描述符
class RevealAcess(object): def __init__(self, initval=None, name='var'): self.val = initval self.name = name def __get__(self, obj, objtype): print("Retrieving", self.name) return self.val def __set__(self, obj, val): print("updating", self.name) self.val = valclass MyClass(object): x = RevealAcess(10, 'var "x"') y = 5if __name__ == "__main__": m = MyClass() print(m.x) m.x = 20 m.x print(m.y)複製程式碼
輸出
Retrieving var "x"10updating var "x"Retrieving var "x"5複製程式碼
如果一個類的某個屬性有資料描述符(含有__get__,
__set__方法的類稱之為資料描述符),
通過上述的例子可以知道,每次讀取屬性的時候會呼叫 __get__方法
每次對屬性賦值的時候呼叫__set__方法,只實現了__get__的稱之為非資料描述符。
延遲求值屬性
import pymongoclass A(): def __init__(self): self._client = None def __get__(self, instance, owner): if self._client is None: print("建立mongodb連線") self._client = pymongo.MongoClient(host='127.0.0.1',port=27017,maxPoolSize=10) else: print('使用存在連線!') return self._clientclass B(): db=A()if __name__ == '__main__': m=B() print(m.db) print(m.db)複製程式碼
如果mongodb的連線已經建立就不重新建立了。單例模式的一種。例項之間共享屬性達到節省資源的目的。
property的使用
from requests_html import HTMLSessionclass Spider(): __slots__ = ['url', 'new_url', 'session'] # 凍結屬性 def __init__(self): self.url = "https://www.baidu.com" self.new_url = None self.session = HTMLSession() @property def get_url(self): return self.url @get_url.setter def get_url(self, key): self.url = f'{self.url}/s?wd={key}' def get_html(self): req = self.session.get(self.url) if req.status_code == 200: return req.textif __name__ == '__main__': s = Spider() s.get_url = 'python' print(s.get_html())複製程式碼
使用property裝飾器修飾函式get_url,在呼叫的時候就可以當屬性直接呼叫,
然後在此基礎上定義同名函式,使用同名函式裝飾器的setter方法修飾函式,可以實現賦值的功能。
更多工具使用以及python技巧,請關注公眾號:python學習開發。
如果您喜歡我的文章不防動動小手轉發一波,謝謝。由於人數超過100所以需要新增我微信:italocxa,然後拉您入群。