亚洲 国产精品 日韩-亚洲 激情-亚洲 欧美 91-亚洲 欧美 成人日韩-青青青草视频在线观看-青青青草影院

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > Python上下文管理器

Python上下文管理器

來(lái)源:千鋒教育
發(fā)布人:xqq
時(shí)間: 2023-11-07 19:37:35 1699357055

本節(jié)嚴(yán)格意義上并非新的重定向方式,而是利用Pyhton上下文管理器優(yōu)化上節(jié)的代碼實(shí)現(xiàn)。借助于上下文管理器語(yǔ)法,可不必向重定向使用者暴露sys.stdout。

首先考慮輸出抑制,基于上下文管理器語(yǔ)法實(shí)現(xiàn)如下:

importsys,cStringIO,contextlib

classDummyFile:

defwrite(self,outStr):pass

@contextlib.contextmanager

defMuteStdout():

savedStdout=sys.stdout

sys.stdout=cStringIO.StringIO()#DummyFile()

try:

yield

exceptException:#捕獲到錯(cuò)誤時(shí),屏顯被抑制的輸出(該處理并非必需)

content,sys.stdout=sys.stdout,savedStdout

printcontent.getvalue()#;raise

#finally:

sys.stdout=savedStdout

使用示例如下:

withMuteStdout():

print"I'llshowupwhenisexecuted!"#不屏顯不寫(xiě)入

raise#屏顯上句

print"I'mhidingmyselfsomewhere:)"#不屏顯

再考慮更通用的輸出重定向:

importos,sys

fromcontextlibimportcontextmanager

@contextmanager

defRedirectStdout(newStdout):

savedStdout,sys.stdout=sys.stdout,newStdout

try:

yield

finally:

sys.stdout=savedStdout

使用示例如下:

defGreeting():print'Hello,boss!'

withopen('out.txt',"w+")asfile:

print"I'mwritingtoyou..."#屏顯

withRedirectStdout(file):

print'Ihopethisletterfindsyouwell!'#寫(xiě)入文件

print'Checkyourmailbox.'#屏顯

withopen(os.devnull,"w+")asfile,RedirectStdout(file):

Greeting()#不屏顯不寫(xiě)入

print'Ideserveapayraise:)'#不屏顯不寫(xiě)入

print'DidyouhearwhatIsaid?'#屏顯

可見(jiàn),with內(nèi)嵌塊里的函數(shù)和print語(yǔ)句輸出均被重定向。注意,上述示例不是線程安全的,主要適用于單線程。

當(dāng)函數(shù)被頻繁調(diào)用時(shí),建議使用裝飾器包裝該函數(shù)。這樣,僅需修改該函數(shù)定義,而無(wú)需在每次調(diào)用該函數(shù)時(shí)使用with語(yǔ)句包裹。示例如下:

importsys,cStringIO,functools

defMuteStdout(retCache=False):

defdecorator(func):

@functools.wraps(func)

defwrapper(*args,**kwargs):

savedStdout=sys.stdout

sys.stdout=cStringIO.StringIO()

try:

ret=func(*args,**kwargs)

ifretCache==True:

ret=sys.stdout.getvalue().strip()

finally:

sys.stdout=savedStdout

returnret

returnwrapper

returndecorator

若裝飾器MuteStdout的參數(shù)retCache為真,外部調(diào)用func()函數(shù)時(shí)將返回該函數(shù)內(nèi)部print輸出的內(nèi)容(可供屏顯);若retCache為假,外部調(diào)用func()函數(shù)時(shí)將返回該函數(shù)的返回值(抑制輸出)。

MuteStdout裝飾器使用示例如下:

@MuteStdout(True)

defExclaim():print'Iamproudofmyself!'

@MuteStdout()

defMumble():print'Ilackconfidence...';return'sad'

printExclaim(),Exclaim.__name__#屏顯'Iamproudofmyself!Exclaim'

printMumble(),Mumble.__name__#屏顯'sadMumble'

在所有線程中,被裝飾函數(shù)執(zhí)行期間,sys.stdout都會(huì)被MuteStdout裝飾器劫持。而且,函數(shù)一經(jīng)裝飾便無(wú)法移除裝飾。因此,使用該裝飾器時(shí)應(yīng)慎重考慮場(chǎng)景。

接著,考慮創(chuàng)建RedirectStdout裝飾器:

defRedirectStdout(newStdout=sys.stdout):

defdecorator(func):

defwrapper(*args,**kwargs):

savedStdout,sys.stdout=sys.stdout,newStdout

try:

returnfunc(*args,**kwargs)

finally:

sys.stdout=savedStdout

returnwrapper

returndecorator

使用示例如下:

file=open('out.txt',"w+")

@RedirectStdout(file)

defFunNoArg():print'Noargument.'

@RedirectStdout(file)

defFunOneArg(a):print'Oneargument:',a

defFunTwoArg(a,b):print'Twoarguments:%s,%s'%(a,b)

FunNoArg()#寫(xiě)文件'Noargument.'

FunOneArg(1984)#寫(xiě)文件'Oneargument:1984'

RedirectStdout()(FunTwoArg)(10,29)#屏顯'Twoarguments:10,29'

printFunNoArg.__name__#屏顯'wrapper'(應(yīng)顯示'FunNoArg')

file.close()

注意FunTwoArg()函數(shù)的定義和調(diào)用與其他函數(shù)的不同,這是兩種等效的語(yǔ)法。此外,RedirectStdout裝飾器的最內(nèi)層函數(shù)wrapper()未使用"functools.wraps(func)"修飾,會(huì)丟失被裝飾函數(shù)原有的特殊屬性(如函數(shù)名、文檔字符串等)。

以上內(nèi)容為大家介紹了Python上下文管理器,希望對(duì)大家有所幫助,如果想要了解更多Python相關(guān)知識(shí),請(qǐng)關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
Python編程規(guī)范的重要性

首先談一下注釋:注釋不止是為了自己以后看的更清楚,還是為了以后的開(kāi)發(fā)人員所準(zhǔn)備的,其實(shí)一段時(shí)間后,當(dāng)需要對(duì)程序做一些修改或者是改正某個(gè)...詳情>>

2023-11-07 22:37:35
Python 基本語(yǔ)句

1.條件語(yǔ)句在進(jìn)行邏輯判斷時(shí),我們需要用到條件語(yǔ)句,Python提供了if、elif、else來(lái)進(jìn)行邏輯判斷。格式如下所示:if判斷條件1:執(zhí)行語(yǔ)句1...elif...詳情>>

2023-11-07 22:30:23
Python重命名和刪除文件

python的os模塊提供了幫你執(zhí)行文件處理操作的方法,比如重命名和刪除文件。要使用這個(gè)模塊,你必須先導(dǎo)入它,然后才可以調(diào)用相關(guān)的各種功能。re...詳情>>

2023-11-07 20:49:35
python 序列化及其相關(guān)模塊

什么是序列化對(duì)象?我們把對(duì)象(變量)從內(nèi)存中編程可存儲(chǔ)或傳輸?shù)倪^(guò)程稱之為序列化,在python中稱為pickle,其他語(yǔ)言稱之為serialization,marshal...詳情>>

2023-11-07 20:42:23
python生成器函數(shù)

為什么叫生成器函數(shù)?因?yàn)樗S著時(shí)間的推移生成了一個(gè)數(shù)值隊(duì)列。一般的函數(shù)在執(zhí)行完畢之后會(huì)返回一個(gè)值然后退出,但是生成器函數(shù)會(huì)自動(dòng)掛起,然...詳情>>

2023-11-07 20:31:35
人妻无码熟妇乱又视频| 女人被爽到呻吟GIF动态图 | YW尤物AV无码国产在线观看| 大战丰满无码人妻50P免费| 国产亚洲精品A在线观看APP| 久章草在线毛片视频播放| 人人妻人人爽人人人少妇| 无码专区人妻诱中文字幕| 亚洲一区二区三区蜜桃| XXXX性XX另类Ⅹ中国HD| 国产农村乱人伦精品视频| 久久夜色撩人精品国产小说| 日韩成人av网站| 亚洲国产成人久久综合碰碰| AVTT天堂网久久精品| 国产精品亚洲成在人线| 麻豆果冻传媒2021精品传媒一| 日文文本乱码高清| 亚洲熟妇无码av叧娄本色 | 国产乱色国产精品免费视频| 久久婷婷综合缴情亚洲狠狠_| 群体交乱之放荡娇妻| 性少妇JEALOUSVUE成熟| 8090私人影院| 国产女主播高潮在线播放| 免费A级毛片无码无遮挡| 玩肥熟老妇BBWXXX视频| 一本大道香蕉大L在线吗视频| 成人午夜精品久久久久久久| 精品推荐国产AV剧情| 日本乱偷人妻中文字幕在线| 亚洲久悠悠色悠在线播放| 波多野结衣HD在线观看| 极品少妇高潮XXXXX| 久草玖玖玖爱在线资源| ZOZ○ZO女人和另类ZOZ0| 国产日韩AV免费无码一区二区| 男女性高爱潮免费网站| 西西人体大胆午夜啪啪| 99国产欧美另娄久久久精品 | 教官在我腿间疯狂驰聘视频| 人人妻人人澡人人爽人人蜜臀 | 少妇ASS浓PICSXXXXB| 一二三四免费观看在线6| 国产成人艳妇AA视频在线| 免费观看18禁无遮挡真人网站| 香蕉久久一区二区不卡无毒影院| CHINESE国产老熟女| 精品少妇无码AV无码专区蜜臀| 日韩精品极品视频在线观看免费| 一本大道无码日韩精品影视丶| 国产果冻豆传媒麻婆精东影视| 女人脱精光直播APP下载| 亚洲AV永久无码区成人网站 | 人人妻人人妻人人片色AV| 亚洲午夜成人精品无码| 国产精品成熟老妇女| 欧美日韩在线视频一区二区| 亚洲熟女综合一区二区三区| 国产精品妇女一二三区| 人C交ZZZ0OOZZZ000| 一区二区三区在线 | 欧| 国产熟睡乱子伦视频在线观看| 人妻中文字幕乱人伦在线| 又黄又无遮挡AAAAA毛片| 国产一起色一起爱| 射精专区一区二区朝鲜| CHRISTMAS农村夫妻HO| 久久久久久人妻一区精品| 小雪尝禁果又粗又大的动态视频| 成人精品一区二区三区网站 | 教室内污辱女教师BD高清在线观看| 三级特黄60分钟在线播放2| 8Ⅹ8X擦拨擦拨成人免费视频| 精品免费久久久久久久| 天天爽天天狠久久久综合麻豆 | 国产三级久久久精品麻豆三级| 日本亚洲欧美一区二区麻豆| ◇一本大道香蕉中文在线| 精品无码人妻一区二区免费蜜桃| 无码H黄肉动漫在线观看| 草木影视在线视频免费观看| 男阳茎进女阳道啪啪| 亚洲香蕉一本大道在线| 国精产品一二二区视早餐有限| 少妇高潮惨叫久久久久久电影 | 人人爽人人澡人人高潮| 777成了乱人视频| 久久久久亚洲AV成人片乱码| 亚洲国产AⅤ成人精品无吗| 国产麻花豆剧传媒精品MV在线| 少妇被粗大的猛烈的进出69影院 | 中文字幕JUL975老公不在| 精品无人区一线二线三线区别| 亚洲AV日韩综合一区尤物| 国产精品盗摄!偷窥盗摄| 色老99久久精品偷偷鲁| 把腿张开老子臊烂你的小说| 欧美激情ⅩXXXX免费视频| 18禁又污又黄又爽的网站| 久久无码成人影片| 亚洲综合网国产精品一区| 精品国产乱码久久久久久蜜桃| 亚洲AV成人无码一区在线观看| 国产精品扒开腿做爽爽爽| 国产精品久久久久JK制服| 女人18毛片A级毛片| 亚洲一区波多野结衣在线APP | 宝贝腿开大一点你真湿H| 欧美老妇激情BBBWWBBW| AV无码东京热亚洲男人的天堂 | 精品午夜福利1000在线观看| 亚洲精品无码久久久久APP| 娇妻呻吟黑人又粗又大视频| 天天做天天爱天天爽综合网 | 99久久久国产精品免费牛牛| 大肉大捧一进一出好爽视频| 开心久久婷婷综合中文字幕| 天天狠天天透天干天干| 亚洲最大成人AV在线天堂网| 国产99视频精品免费视看9| 男人J桶进女人P无遮挡的图片| 性少妇SEX麻豆HD中国| WWW久久无码天堂MV| 久久综合九色综合97欧美| 亚洲不卡无码WWW一区二区三区| 成午夜福利人试看120秒| 免费AV片在线观看网址KAN什| 99RE6热视频这里只精品首页| 国产又黄又潮娇喘视频在线观看| 婷婷丁香五月激情综合| 中文字幕丰满乱子无码视频 | 国产精品久久久久久影视| 漂亮人妻中文字幕丝袜| 中文字幕丰满乱子伦无码专区 | 国产精品爽爽VA在线观看| 无码人妻丰满热妇又大又粗| 国产偷国产偷亚洲高清人| 亚洲AV午夜福利精品一区人妖| 嘿咻嘿咻男女免费专区| 亚洲熟妇色XXXXXX爽| 麻花豆传媒剧国产MV在线上-| 51CG10 吃瓜 爆料| 人人澡人人澡人人看添AV| 高潮喷吹一区二区在线观看| 无码精品人妻一区二区三区漫画 | 国产无套内射普通话对白| 亚洲精品成人在线| 麻豆一区二区三区精品视频| IJZZIJZZIJ亚洲大全| 手机看片福利永久| 国产自无码视频在线观看| 亚洲无日韩码精品| 欧美人与动牲交免费观看视频| 大尺度一对一视频聊天软件| 午夜成人无码片在线观看影院| 护士扒下内裤让我爽一夜| 真实国产乱子伦精品一区二区三区 | 国产成人午夜性A一级毛片老女人| 午夜男女爽爽羞羞影院在线观看| 精品乱子伦一区二区三区| 47147大但人文艺术| 日本最新免费二区三区| 国产欧美精品一区二区色综合 | 亚洲VA久久久噜噜噜久久| 久久久久国产亚洲AV麻豆| WWW.らだ天堂中文在线| 无码人妻熟妇av又粗又大| 久久久99精品成人片| YY影院电视剧大全| 午夜宅男在线永久免费观看网| 久久久久精品国产AV麻豆| 宝贝你夹得太紧了我都要断了| 无人区码一码二码三码区别图片| 久久精品熟女亚州AV麻豆| 巴西大肥熟女毛茸茸| 亚洲AV乱码中文一区二区三区 | 欧美致敬很多经典的黑白MV| 国产精品久久无码一区| 一下子挺进浓密的黑森林| 日产精品一卡2卡三卡4卡乱码| 国内精品伊人久久久久AV影院| 中文字幕人妻一区二区三区| 日韩视频一二三区2021| 精品卡一卡三卡四卡AⅤ新区| AV无码精品一区二区三区宅噜噜| 我和闺蜜在公交被八个人挤倒| 久久天堂AV女色优精品| 岛国AV动作片免费观看| 亚洲裸男GAY自慰网站| 人妻夜夜爽天天爽| 激情综合丁香五月| JAPANESEⅩⅩⅩHD日本| 亚洲AV无码久久精品蜜桃播放| 男女性高爱潮是免费国产| 国产精品高清一区二区三区人妖| 中文乱码字幕高清一区二区 | 国产精品亚洲欧美大片在线观看| 在线看片无码永久免费AV| 我和公GONG在厨房日本电影|