黄视频网站在线免费观看-黄视频网站在线看-黄视频网站在线观看-黄视频网站免费看-黄视频网站免费观看-黄视频网站免费

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > Python自定義計時函數

Python自定義計時函數

來源:千鋒教育
發布人:xqq
時間: 2023-11-07 20:20:47 1699359647

python標準庫提供的cProfile/profile模塊,計時輸出信息較多。本節將介紹其他幾種精度略低但簡單易用的計時工具。根據代碼粒度不同,將其分為三類。

1.1整個程序計時

Unix/Linux系統中,可用time命令簡單地統計整個程序的耗時。例如:

[wangxiaoyuan_@localhostPyTest]$timepythonBCLineCounter.pybulk

FileLinesCodeLinesCommentLinesEmptyLinesCommentPercent

1545010437326425380.24

real0m2.803s

user0m1.124s

sys0m0.052s

統計值real表示程序運行的實際耗時,user表示程序執行用戶態代碼(內核外)耗費的CPU時間,sys表示程序在內核態運行所耗費的CPU時間(即調用特定內核函數的耗時)。若user和sys時間之和小于real時間,表明程序為I/O密集型(I/Obound),即程序的性能問題很可能與等待I/O有關。

time命令的詳細描述參見《Linux用戶態程序計時方式詳解》。

1.2代碼片段計時

代碼片段計時分為函數計時和語句塊計時。這兩種計時均可使用Python標準庫timeit模塊,該模塊的詳細介紹參見官方幫助。

本小節將使用timeit模塊的timeit()方法,即timeit(stmt='pass',setup='pass',timer=,number=1000000)。其中,參數stmt為待計時的目標代碼;setup為執行代碼的準備工作(通常是import之類的語句),不計入時間;timer在Windows系統中為time.clock(),Linux系統中則為time.time(),取默認值即可;number指示stmt重復執行的次數。該方法返回執行stmt代碼number遍所用的時間,單位為秒,float類型。

除timeit()方法外,對于特定函數的計時,可使用裝飾器(decorator);對于語句塊計時,則可使用上下文管理器(contextmanager)。

以裝飾器為例:

importfunctools,sys,time

defFuncTimer(repeats=10000):

defdecorator(func):

@functools.wraps(func)

defwrapper(*args,**kwargs):

#Windows系統中clock()粒度為毫秒,time()粒度為1/60秒;

#Unix系統中clock()粒度為1/100秒,time()精度較其更高。

ifsys.platform=="win32":

timerFunc=time.clock

else:

timerFunc=time.time

try:

startTime=timerFunc()

foriinrange(repeats):

ret=func(*args,**kwargs)

finally:#當目標函數發生異常時,仍舊輸出計時信息

endTime=timerFunc()

print'%s.%s()=>'%(func.__module__,func.__name__),

print'TimeElasped:%.3fmsec,repeated%dtime(s).'\

%(((endTime-startTime)*1000.0),repeats)

returnret

returnwrapper

returndecorator

運行如下代碼,對比自定義裝飾器FuncTimer與timeit模塊計時效果:

@FuncTimer(10)

defDecoratedFunc():

L=[]

foriinrange(100):L.append(i)

defRawFunc():

L=[]

foriinrange(100):L.append(i)

DecoratedFunc()

importtimeit;print'%.6fsec'%timeit.timeit(stmt=RawFunc,number=10)

輸出如下:

__main__.DecoratedFunc()=>TimeElasped:0.164msec,repeated10time(s).

0.000174sec

可見,計時效果非常接近。

注意,FuncTimer裝飾器內根據系統選用不同的計時器,這是考慮到time.clock()的精度因系統平臺而異。在Unix/Linux系統中,該方法返回當前所耗的CPU時間;而在Windows系統中,該方法基于Win32函數QueryPerformanceCounter(),返回從首次調用待計時函數起所經歷的掛鐘時間(wallclocktime),精度較time.time()更高。相比而言,timeit方法中使用的缺省計時器總是測量掛鐘時間,這也意味著關于某函數的計時可能會受到同一計算機上運行的其他進程的影響。

time.clock()計時器的平臺差異性參考以下示例(假定所在腳本名為Timing.py):

@FuncTimer(5)

defSqrtTiming(loops):

importmath

try:

frommathimportfsum#Python2.6+

returnfsum([math.sqrt(x)forxinrange(loops)])

exceptImportError:#Python2.5-

returnsum([math.sqrt(x)forxinrange(loops)])

@FuncTimer(1)

defSleepTiming():

time.sleep(2)

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

foriinrange(10000):

file.write('helloworld!')

SqrtTiming(100000)

SleepTiming()

在Windows系統控制臺和IDLEShell里的運行結果如下:

E:\PyTest>Timing.py

SqrtTiming()=>TimeElasped:150.124msec,repeated5time(s).

SleepTiming()=>TimeElasped:2155.140msec,repeated1time(s).

__main__.SqrtTiming()=>TimeElasped:151.809msec,repeated5time(s).

__main__.SleepTiming()=>TimeElasped:2185.594msec,repeated1time(s).

>>>importTiming

Timing.SqrtTiming()=>TimeElasped:148.892msec,repeated5time(s).

Timing.SleepTiming()=>TimeElasped:2223.157msec,repeated1time(s).

在Linux系統中運行結果與之類似。若將timerFunc改為time.clock(),則計時輸出為:

[wangxiaoyuan_@localhost~]$timepythonTiming.py

__main__.SqrtTiming()=>TimeElasped:320.000msec,repeated5time(s).

__main__.SleepTiming()=>TimeElasped:330.000msec,repeated1time(s).

real0m2.381s

user0m0.332s

sys0m0.019s

可見,time.sleep(2)并未計入SleepTiming()耗時,導致計時結果與real時間相差很大。

對于代碼片段計時,以上下文管理器為例:

importcontextlib,sys,time

@contextlib.contextmanager

defBlockTimer(label='Block'):

ifsys.platform=="win32":timerFunc=time.clock

else:timerFunc=time.time

startTime=timerFunc()

try:

yield

finally:

endTime=timerFunc()

print'%s=>'%label,

print'TimeElasped:%.3fmsec.'\

%((endTime-startTime)*1000.0)

基于BlockTimer測量代碼片段的示例如下:

withBlockTimer('cPickle'):

fromcPickleimportdumps,loads

s=dumps([x*2.4forxinrange(100000)])

loads(s)

withBlockTimer('json'):

fromjsonimportdumps,loads

s=dumps([x*2.4forxinrange(100000)])

loads(s)

運行結果如下:

cPickle=>TimeElasped:237.569msec.

json=>TimeElasped:181.714msec.

可見,對于浮點型對象,json模塊執行速度比cPickle模塊更快。

當然,借助timeit模塊也可對代碼片段計時。例如:

fromtimeitimporttimeit

sep='fromcPickleimportdumps,loads'

stp='s=dumps([x*2forxinrange(100000)]);loads(s)'

print'cPickle:%.6fsec'%timeit(stmt=stp,setup=sep,number=1)

sej='fromjsonimportdumps,loads'

stj='s=dumps([x*2forxinrange(100000)]);loads(s)'

print'json:%.6fsec'%timeit(stmt=stj,setup=sej,number=1)

本例改為整型對象,且模塊導入語句不計入總耗時。運行結果如下:

cPickle:0.100775sec

json:0.064752sec

可見,對于整型對象,json模塊執行速度也比cPickle模塊快。

以上內容為大家介紹了Python自定義計時函數,希望對大家有所幫助,如果想要了解更多Python相關知識,請關注IT培訓機構:千鋒教育。http://www.e7g2kmi.cn/


tags: python培訓
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
亚洲精品永久一区| 久久久久久久男人的天堂| 精品视频一区二区| 日韩在线观看免费完整版视频| 成人免费观看的视频黄页| 国产精品12| 青青青草影院 | 欧美a级片视频| 欧美另类videosbestsex视频 | 九九久久99| 亚洲www美色| 亚洲不卡一区二区三区在线| 久久国产精品自由自在| 99色视频在线| 欧美1卡一卡二卡三新区| 国产伦久视频免费观看 视频| 99色精品| 美女免费精品视频在线观看| 国产伦理精品| 欧美a级v片不卡在线观看| 精品久久久久久综合网| 国产a免费观看| 国产网站在线| 天天做人人爱夜夜爽2020| 国产麻豆精品免费密入口| 日本特黄特色aaa大片免费| 日本免费看视频| 91麻豆国产福利精品| 欧美激情伊人| 亚洲精品永久一区| 91麻豆爱豆果冻天美星空| 99久久精品费精品国产一区二区| 成人免费观看视频| 国产91视频网| 欧美a级片视频| 九九久久国产精品| 国产91丝袜高跟系列| 香蕉视频亚洲一级| 国产亚洲精品aaa大片| 黄视频网站免费看| 国产国产人免费视频成69堂| 午夜激情视频在线观看| 国产视频在线免费观看| 久久久成人网| 欧美a级成人淫片免费看| 在线观看成人网| 欧美国产日韩久久久| 999久久久免费精品国产牛牛| 青青青草影院 | 亚洲精品中文一区不卡 | 精品久久久久久中文| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 日韩女人做爰大片| 亚洲www美色| 精品视频一区二区| 国产一区二区精品| 亚洲 激情| 可以免费看毛片的网站| 国产国语对白一级毛片| 99久久精品国产麻豆| 亚洲女初尝黑人巨高清在线观看| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 精品国产一级毛片| 国产成人欧美一区二区三区的| 久久99青青久久99久久| 久久成人亚洲| 日韩女人做爰大片| 国产精品1024永久免费视频 | 国产一区二区精品在线观看| 成人免费观看男女羞羞视频| 日韩在线观看视频免费| 999精品视频在线| 国产精品免费久久| 人人干人人草| 二级片在线观看| 精品久久久久久综合网| 欧美大片一区| 久久国产一久久高清| 日韩字幕在线| 国产极品白嫩美女在线观看看| 久久99中文字幕| 久草免费资源| 韩国三级视频在线观看| 亚洲第一页乱| 精品美女| 国产视频一区二区三区四区| 久久精品免视看国产明星| 国产伦精品一区二区三区在线观看 | 九九久久99| 久久久久久久网| 人人干人人草| 一级毛片视频播放| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 香蕉视频三级| 国产精品1024永久免费视频 | 四虎影视精品永久免费网站| 可以免费看污视频的网站| 亚洲精品永久一区| 久草免费在线观看| 97视频免费在线观看| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 亚洲精品久久玖玖玖玖| 亚洲 男人 天堂| 国产亚洲免费观看| 九九热精品免费观看| 精品国产一区二区三区久久久狼 | 亚欧成人毛片一区二区三区四区| 黄视频网站在线免费观看| 亚洲女人国产香蕉久久精品| 午夜在线亚洲| 免费一级片网站| 精品视频在线观看视频免费视频 | 你懂的日韩| 国产综合91天堂亚洲国产| 国产亚洲免费观看| 欧美1卡一卡二卡三新区| 国产一区免费观看| 国产成人精品综合在线| 精品视频在线观看视频免费视频 | 国产视频一区二区三区四区| 欧美激情在线精品video| 国产视频一区二区在线播放| 免费国产在线观看| 九九热精品免费观看| 日韩中文字幕在线观看视频| 韩国三级视频网站| 亚洲 国产精品 日韩| 国产成人精品综合| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 国产激情视频在线观看| 999久久狠狠免费精品| 国产精品自拍亚洲| 国产一级生活片| 你懂的福利视频| 99热精品在线| 国产精品免费久久| 青青青草影院 | 四虎影视精品永久免费网站| 国产视频网站在线观看| 国产一区免费观看| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 日韩在线观看网站| 午夜欧美成人久久久久久| 中文字幕一区二区三区精彩视频| 一级女性大黄生活片免费| 久久精品店| 欧美1卡一卡二卡三新区| 免费国产一级特黄aa大片在线| 免费一级生活片| 国产伦精品一区二区三区无广告| 亚洲精品久久久中文字| 九九干| 欧美大片a一级毛片视频| 日韩一级黄色大片| 成人免费观看网欧美片| 亚洲精品影院| 国产亚洲精品成人a在线| 999久久66久6只有精品| 国产亚洲精品aaa大片| 深夜做爰性大片中文| 日韩在线观看视频黄| 精品久久久久久中文字幕2017| 成人免费观看视频| 欧美a级成人淫片免费看| 日韩在线观看视频免费| 韩国毛片免费大片| 青青久久精品| 国产不卡高清在线观看视频| 国产网站免费观看| 精品视频在线观看一区二区三区| 欧美另类videosbestsex视频 | 久久国产一区二区| 精品久久久久久免费影院| 国产精品1024永久免费视频| 国产激情一区二区三区| 国产综合91天堂亚洲国产| 午夜久久网| 超级乱淫黄漫画免费| 欧美激情中文字幕一区二区| 成人免费高清视频| 日韩在线观看免费完整版视频| 国产美女在线观看| 日韩中文字幕一区| 亚洲女初尝黑人巨高清在线观看| 国产美女在线一区二区三区| 欧美大片一区| 二级片在线观看| 日韩中文字幕一区| 高清一级毛片一本到免费观看| 黄色短视屏| 韩国三级视频在线观看| 黄色福利片| 黄视频网站在线免费观看| 色综合久久天天综线观看| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 一本高清在线| 免费一级片网站| 国产不卡精品一区二区三区| 四虎久久影院| 一级女性大黄生活片免费|