174 python計算程式執行時間

2021-08-21 01:46:30 字數 2760 閱讀 2989

方法1

import datetime

starttime = datetime.datetime.now()

#long running

endtime = datetime.datetime.now()

print (endtime - starttime).seconds

方法 2

start = time.time()

run_fun()

end = time.time()

print end-start

方法3

start = time.clock()

run_fun()

end = time.clock()

print end-start

方法1和方法2都包含了其他程式使用cpu的時間,是程式開始到程式結束的執行時間。

方法3算只計算了程式執行的cpu時間

以下分別是兩個模組的具體資訊

>>> dir(time)

['__doc__', '__name__', '__package__', 'accept2dyear', 'altzone', 'asctime', 'clock', 'ctime', 'daylight', 'gmtime',

'localtime', 'mktime', 'sleep', 'strftime', 'strptime', 'struct_time', 'time', 'timezone', 'tzname', 'tzset']

>>> dir(datetime.datetime)

['__add__', '__class__', '__delattr__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__gt__',

'__hash__', '__init__', '__le__', '__lt__', '__ne__', '__new__', '__radd__', '__reduce__', '__reduce_ex__', '__repr__',

'__rsub__', '__setattr__', '__sizeof__', '__str__', '__sub__', '__subclasshook__', 'astimezone', 'combine', 'ctime',

'date', 'day', 'dst', 'fromordinal', 'fromtimestamp', 'hour', 'isocalendar', 'isoformat', 'isoweekday', 'max', 'microsecond',

'min', 'minute', 'month', 'now', 'replace', 'resolution', 'second', 'strftime', 'strptime', 'time', 'timetuple', 'timetz', 'today',

'toordinal', 'tzinfo', 'tzname', 'utcfromtimestamp', 'utcnow', 'utcoffset', 'utctimetuple', 'weekday', 'year']

如果要獲取微秒級別的時間差,可以利用以下**

import datetime

begin = datetime.datetime.now()

end = datetime.datetime.now()

k = end - begin

print (end-begin).days # 0 天數

print (end-begin).total_seconds() # 30.029522 精確秒數

print (end-begin).seconds # 30 秒數

print (end-begin).microseconds # 29522 毫秒數

再看下k的屬性和方法

>>> dir(k)

['__abs__', '__add__', '__class__', '__delattr__', '__div__', '__doc__', '__eq__', '__floordiv__', '__format__', '__ge__',

'__getattribute__', '__gt__', '__hash__', '__init__', '__le__', '__lt__', '__mul__', '__ne__', '__neg__', '__new__', '__nonzero__',

'__pos__', '__radd__', '__rdiv__', '__reduce__', '__reduce_ex__', '__repr__', '__rfloordiv__', '__rmul__', '__rsub__', '__setattr__',

'__sizeof__', '__str__', '__sub__', '__subclasshook__', 'days', 'max', 'microseconds', 'min', 'resolution', 'seconds', 'total_seconds']

k為datetime.timedelta型別,以上是timedelta的所有的屬性和函式

利用以下**可以獲取以秒為單位的時間差,小數點後6位為微秒。

k.total_seconds()

>>> k.total_seconds()

2303.277522

python執行時間 計算Python程式執行時間

昨天寫了下迴圈的練習,不知道怎麼突發奇想的就想著要看看執行時間了。當時可能因為乙個簡單的迴圈給我複雜了吧。所以想知道哪個演算法是最快的。所以就想著想知道python程式的執行時間。初步解題 import time a str raw input 字串 b len a c 0while c print...

Python計算程式執行時間

原出處 方法1import datetime starttime datetime.datetime.now long running endtime datetime.datetime.now print endtime starttime seconds 方法 2 start time.time...

Python計算程式執行時間

方法1 import datetime starttime datetime.datetime now long running endtime datetime.datetime now print endtime starttime seconds方法 2 start time.time run...