这一题来自于python技能书 ~~~~~~~~~~~~~~~技能数
首先展示一下所需要的结果,下面将详细解说以下代码
代码:
# TODO 鸟欲高飞,必先展翅 # TODO 向前的人 :Jhon # todo 实现一个范围耗时统计类。 实现了 __enter__ 和 __exit__ 成员的类,可以通过 with as 语法使用,程序进入和离开范围的时候会自动调用 __enter__ 和 __exit__ 方法。 # -*- coding: UTF-8 -*- import time class TimeSpan: # TODO(You): 请正确实现计时器的__enter__和__exit成员 def __enter__(self): self.end = None self.start = time.time() def __exit__(self, exc_type, exc_val, exc_tb): self.end = time.time() print('耗时:{}毫秒'.format((self.end - self.start))) if __name__ == '__main__': with TimeSpan(): for i in range(0, 1000): print(i)
结果:首先来看一下这个题目的要求实现一个范围耗时统计类。 实现了 enter 和 exit 成员的类,可以通过 with as 语法使用,程序进入和离开范围的时候会自动调用 enter 和 exit 方法。也就是要你书写一个计数函数,而且此处需要程序进入和离开范围的时候会自动调用 enter 和 exit 方法,简而言之就是记录程序执行的来时时间和结束时间要计算程序开始和结束的时间当然少不了time模块了(import time)。time.time()就是记录当前时间,想要计算程序的执行时间只需要在程序开始时候记录一下时间(time.time()),程序结束时候记录一下时间(time.time()),计算一下时间差就是此程序的运行时间了【当然,因为程序调用方法的时间非常短,所以忽略不计】
注意此处 可以 with TimeSpan() as T:,这个知识取别名,方便调用,下面没有用到,所以可以删掉。如果只是单纯的计算程序的时间我认为直接在程序前后写上time.time()即可,没必这么复杂,所以这题的主要考察python内置方法的书写。除此之外,选项中还有两种正确的方法,在下面沾上
class TimeSpan: def __enter__(self): self.end = None self.start = time.time() return self def __exit__(self, exc_type, exc_val, exc_tb): self.end = time.time() print('耗时:{}毫秒'.format((self.end-self.start)))
class TimeSpan: def __enter__(self): self.start = time.time() def __exit__(self, exc_type, exc_val, exc_tb): self.end = time.time() print('耗时:{}毫秒'.format((self.end-self.start)))