鱼C论坛

 找回密码
 立即注册
查看: 2597|回复: 4

[已解决]Python:视频课程中的举例,计时器

[复制链接]
发表于 2021-3-17 09:55:36 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 Peteryo01223 于 2021-3-17 11:14 编辑

第44课,视频中举例如下:
  1. import time as t

  2. class MyTimer():
  3.     # 开始计时
  4.     def start(self):
  5.         self.start = t.localtime()
  6.         print('计时开始。。。')

  7.     # 停止计时
  8.     def stop(self):
  9.         self.stop = t.localtime()
  10.         self._calc() # 这里调用了计算方法,为何在上面 start中不用计算呢?
  11.         print('计时结束。')

  12.     # 内部方法,计算运行时间
  13.     def _calc(self):
  14.         self.lasted = []
  15.         self.prompt = '总共运行了'
  16.         for index in range(6): # 这句何意?range(6),是1、2、3、4、5的意思吧?index 有定义过是什么吗?
  17.             self.lasted.append(self.stop[index] - self.start[index])
  18.             self.prompt += str(self.lasted[index])

  19.         print(self.prompt)
  20.    
复制代码


提问:
1. 第12行code,为何定义stop时用了self._calc(),而定义start时,不用呢?
2. 第19行code,为何用数字 6 ,不用其它数值?index没有定义过吧?range(6),是1、2、3、4、5的意思,5次 for 循环在干嘛?

谢谢~
最佳答案
2021-3-17 13:40:09
本帖最后由 jackz007 于 2021-3-17 15:00 编辑

    答案就在 time . localtime() 返回的东西上,让我们看看返回了些什么
  1. >>> import time
  2. >>> print(time . localtime()[:6])
  3. (2021, 3, 17, 13, 37, 37)
  4. >>>
复制代码

    就是说,MyTimer 类中的属性 start 和 stop 是可迭代对象,通过循环切片,可以从中依次得到年、月、日、时、分、秒的数值。我想,不用再做进一步的解释了吧?

    可以把原代码改造一下,让它功能基本相同,却要简单和好理解一些,尤其是 _calc() 方法。
  1. import time

  2. class MyTimer():
  3.     # 开始计时
  4.     def start(self):
  5.         self . start = int(time . time())  # 自格林威治时间 1970年1月1日0时0分0秒起至今经历的时钟秒数
  6.         print('计时开始。。。')
  7.         print(time . localtime()[: 6])

  8.     # 停止计时
  9.     def stop(self):
  10.         self . stop = int(time . time())   # 自格林威治时间 1970年1月1日0时0分0秒起至今经历的时钟秒数
  11.         print('计时结束。')
  12.         print(time . localtime()[: 6])        

  13.     # 内部方法,计算运行时间
  14.     def _calc(self):
  15.         print(self . stop - self . start)

  16. s = MyTimer()
  17. s . start()
  18. for _ in range(888888888):
  19.     pass
  20. s . stop()
  21. s . _calc()
复制代码

        运行实况
  1. D:\0002.Exercise\Python>python tx.py
  2. 计时开始。。。
  3. (2021, 3, 17, 14, 35, 22)
  4. 计时结束。
  5. (2021, 3, 17, 14, 36, 26)
  6. 64

  7. D:\0002.Exercise\Python>
复制代码

        64 代表 start 和 stop 之间的时间间隔是 64 秒。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-3-17 10:03:06 | 显示全部楼层
计算运行时间 不是在停止时 计算  难道还是在开始时 计算
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-3-17 10:03:40 | 显示全部楼层
本帖最后由 wp231957 于 2021-3-17 10:07 编辑

index 是内部临时变量 不需要单独定义
range(6) 是代表要循环6次  index的值  分别取012345
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-3-17 13:40:09 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jackz007 于 2021-3-17 15:00 编辑

    答案就在 time . localtime() 返回的东西上,让我们看看返回了些什么
  1. >>> import time
  2. >>> print(time . localtime()[:6])
  3. (2021, 3, 17, 13, 37, 37)
  4. >>>
复制代码

    就是说,MyTimer 类中的属性 start 和 stop 是可迭代对象,通过循环切片,可以从中依次得到年、月、日、时、分、秒的数值。我想,不用再做进一步的解释了吧?

    可以把原代码改造一下,让它功能基本相同,却要简单和好理解一些,尤其是 _calc() 方法。
  1. import time

  2. class MyTimer():
  3.     # 开始计时
  4.     def start(self):
  5.         self . start = int(time . time())  # 自格林威治时间 1970年1月1日0时0分0秒起至今经历的时钟秒数
  6.         print('计时开始。。。')
  7.         print(time . localtime()[: 6])

  8.     # 停止计时
  9.     def stop(self):
  10.         self . stop = int(time . time())   # 自格林威治时间 1970年1月1日0时0分0秒起至今经历的时钟秒数
  11.         print('计时结束。')
  12.         print(time . localtime()[: 6])        

  13.     # 内部方法,计算运行时间
  14.     def _calc(self):
  15.         print(self . stop - self . start)

  16. s = MyTimer()
  17. s . start()
  18. for _ in range(888888888):
  19.     pass
  20. s . stop()
  21. s . _calc()
复制代码

        运行实况
  1. D:\0002.Exercise\Python>python tx.py
  2. 计时开始。。。
  3. (2021, 3, 17, 14, 35, 22)
  4. 计时结束。
  5. (2021, 3, 17, 14, 36, 26)
  6. 64

  7. D:\0002.Exercise\Python>
复制代码

        64 代表 start 和 stop 之间的时间间隔是 64 秒。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-3-17 17:57:30 From FishC Mobile | 显示全部楼层
wp231957 发表于 2021-3-17 10:03
index 是内部临时变量 不需要单独定义
range(6) 是代表要循环6次  index的值  分别取012345

谢谢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-26 01:18

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表