今日內(nèi)容概述:
協(xié)程、正則表達(dá)式
昨日回顧
迭代器
iter next
生成器
yield 關(guān)鍵字 代碼執(zhí)行到 yield 就會(huì)停止
next 進(jìn)行解阻塞
列表推導(dǎo)式: a = [x for x in range(10)]
生成器表達(dá)式:把列表推導(dǎo)式的 [] 改成 ()
生成器函數(shù):加了 yield 的函數(shù)
今日內(nèi)容
gevent 庫(kù)
踩的坑:python3.7 版本對(duì)這個(gè)庫(kù)不太友好,重新?lián)Q成 python 3.6.4 的32位版本。
gevent 是對(duì) greenlet 庫(kù)進(jìn)行封裝,greenlet 是對(duì) yield 關(guān)鍵字進(jìn)行封裝
gevent.sleep() 在協(xié)程等待的時(shí)候,先去執(zhí)行下一個(gè)任務(wù)以此來(lái)實(shí)現(xiàn)多任務(wù)
from gevent import monkey
monkey.patch_all() # monkey 可以把代碼中所有的延時(shí)換成 gevent
gevent.joinall([]) 推薦這種方式
"""簡(jiǎn)單的爬蟲(chóng),使用協(xié)程并發(fā)來(lái)下載兩張斗魚(yú)圖片"""import urllib.requestimport geventfrom gevent import monkeymonkey.patch_all()def downloader(img_name, img_url): req = urllib.request.urlopen(img_url) img_content = req.read() with open(img_name, "wb") as f: f.write(img_content)def main(): gevent.joinall([ gevent.spawn(downloader, "3.jpg", "https://rpic.douyucdn.cn/appCovers/2017/09/22/1760931_20170922133718_big.jpg"), gevent.spawn(downloader, "4.jpg", "https://rpic.douyucdn.cn/appCovers/2017/09/17/2308890_20170917232900_big.jpg") ])if __name__ == '__main__': main()協(xié)程
協(xié)程依賴于線程,線程依賴于進(jìn)程。進(jìn)程消耗資源最大,線程其次,協(xié)程最小,正則
import re
ret = re.match(正則表達(dá)式,要匹配的數(shù)據(jù))
ret.group() # 提取匹配出來(lái)的數(shù)據(jù)
12下一頁(yè)>(免責(zé)聲明:本網(wǎng)站內(nèi)容主要來(lái)自原創(chuàng)、合作伙伴供稿和第三方自媒體作者投稿,凡在本網(wǎng)站出現(xiàn)的信息,均僅供參考。本網(wǎng)站將盡力確保所提供信息的準(zhǔn)確性及可靠性,但不保證有關(guān)資料的準(zhǔn)確性及可靠性,讀者在使用前請(qǐng)進(jìn)一步核實(shí),并對(duì)任何自主決定的行為負(fù)責(zé)。本網(wǎng)站對(duì)有關(guān)資料所引致的錯(cuò)誤、不確或遺漏,概不負(fù)任何法律責(zé)任。
任何單位或個(gè)人認(rèn)為本網(wǎng)站中的網(wǎng)頁(yè)或鏈接內(nèi)容可能涉嫌侵犯其知識(shí)產(chǎn)權(quán)或存在不實(shí)內(nèi)容時(shí),應(yīng)及時(shí)向本網(wǎng)站提出書(shū)面權(quán)利通知或不實(shí)情況說(shuō)明,并提供身份證明、權(quán)屬證明及詳細(xì)侵權(quán)或不實(shí)情況證明。本網(wǎng)站在收到上述法律文件后,將會(huì)依法盡快聯(lián)系相關(guān)文章源頭核實(shí),溝通刪除相關(guān)內(nèi)容或斷開(kāi)相關(guān)鏈接。 )