Python计算程序运行时间 |
您所在的位置:网站首页 › start_time › Python计算程序运行时间 |
方法1 代码语言:javascript复制import datetime starttime = datetime.datetime.now() #long running endtime = datetime.datetime.now() print (endtime - starttime).seconds方法 2 代码语言:javascript复制start = time.time() run_fun() end = time.time() print end-start方法3 代码语言:javascript复制start = time.clock() run_fun() end = time.clock() print end-start方法1和方法2都包含了其他程序使用CPU的时间,是程序开始到程序结束的运行时间。 方法3算只计算了程序运行的CPU时间 Python中有两个模块可以完成时间操作:time和datetime相比较而言datetime更强大以下分别是两个模块的具体信息 代码语言:javascript复制>>> 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']如果要获取微秒级别的时间差,可以利用以下代码 代码语言:javascript复制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的属性和方法 代码语言:javascript复制>>> 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位为微秒。 代码语言:javascript复制k.total_seconds() >>> k.total_seconds() 2303.277522 |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |