日韩999_亚洲第一色网站_性色av一区二区_一级做a爱片性色毛片高清_日韩欧美中文字幕在线观看_国产一级片

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

手機站
千鋒教育

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

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

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

當前位置:首頁  >  技術干貨  > 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.neohoutdoors.com/


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
主站蜘蛛池模板: 亚洲天天综合色制服丝袜在线 | 色大18成网站www在线观看 | 亚洲国产网 | 欧洲视频 | 欧美13一14周岁a在线播放 | 久久精品毛片 | 欧美在线网站 | 国产一级插插插 | 依人九九 | 理论片久久 | 国产成+人+亚洲+欧美+日韩 | 在线观看中文字幕 | 一级作爱视频免费观看 | 日韩在线不卡视频 | 日本三级日产三级国产三级 | 国产一起色一起爱 | 伊人久久综合视频 | 久久久久久夜精品精品免费 | 欧美一级成人影院免费的 | 日本黄在线| 欧美一卡二卡三卡 | 韩国的黄色片 | 久草免费福利视频 | 两个人看的www免费高清 | 青青艹视频在线 | 天天干成人网 | 久久精品视频免费观看 | 激情综合在线观看 | 久久大综合| 国产亚洲精品第一综合linode | 国产传媒在线播放 | 欧美性xxxx巨大黑人猛 | 欧区一欧区二欧区三免费 | 日本不卡高清视频 | 国内国内在线精品视频 | 精品欧美成人高清视频在线观看 | 欧美色综合网站 | 久久综合九色综合欧美狠狠 | 日本视频高清 | 国产jizzjizz视频 | 国产夜夜春|