鱼C论坛

 找回密码
 立即注册
查看: 2185|回复: 5

[已解决]关于课后作业计时器修改的问题

[复制链接]
发表于 2020-3-22 22:28:15 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 yjptx121 于 2020-3-22 22:31 编辑

先附代码:
  1. import time as t

  2. class MyTimes():
  3.     def __init__(self):
  4.         self.lasted = 0.00
  5.         self.begin = 0
  6.         self.end = 0
  7.         self.prompt = '未开始计时'
  8.         self.default_time = t.perf_counter()

  9.     def __str__(self):
  10.         return self.prompt
  11.     __repr__ = __str__      # 返回字符串时会先调用 repr ,然后查找 __str__ , 最后会找到self.prompt

  12.     def __add__(self, other):
  13.         result = self.lasted + other.lasted
  14.         prompt = '总共运行了' + str(round(result, 2)) + '秒'
  15.         return prompt   # 返回字符串prompt

  16.     def set_timer(self, timer):     # 默认计时器
  17.         if timer == 't.perf_counter()':
  18.             self.default_time = t.perf_counter()
  19.         if timer == 't.process_time()':
  20.             self.default_time = t.process_time()
  21.         else:
  22.             print('输入无效!,请输入"t.perf_counter() 或 t.process_time"')

  23.     # 开始计时
  24.     def start(self):
  25.         self.begin = self.default_time      # 返回计时器的精准时间
  26.         self.prompt = '请先调用stop()停止计时!'
  27.         print('开始计时!')
  28.         print(self.begin)

  29.     # 计时停止
  30.    [color=Red]def stop(self):
  31.         if not self.begin:
  32.             print('请先调用start()开始计时!')
  33.         else:
  34.             self.end = self.default_time
  35.             self._calc()        # 在结束计时的同时会调用函数_cale()
  36.             print('结束计时!')
  37.             print(self.end)[/color]
  38. [/color]
  39.     # 计算两次时间差
  40.     def _calc(self):
  41.         self.lasted = self.end - self.begin
  42.         self.prompt = '总共运行了' + str(round(self.lasted, 2)) + '秒'
  43.         self.begin = 0
  44.         self.end = 0

  45. t1 = MyTimes()
  46. t1.start()
  47. t.sleep(1)
  48. t1.stop()
  49. print(t1)

复制代码

运行结果:
  1. 开始计时!
  2. 0.047633307
  3. 结束计时!
  4. 0
  5. 总共运行了0.0秒
复制代码

在调用stop()的时候,一直为0,就算不用默认参数,直接调用t.perf_count()一样也是0,不知道问题出在哪了,求指点
最佳答案
2020-3-23 13:11:50
  1. import time as t


  2. class MyTimes:
  3.     def __init__(self):
  4.         self.lasted = 0.00
  5.         self.begin = 0
  6.         self.end = 0
  7.         self.prompt = '未开始计时'
  8.         self.default_time = t.perf_counter    # 更改

  9.     def __str__(self):
  10.         return self.prompt

  11.     __repr__ = __str__  # 返回字符串时会先调用 repr ,然后查找 __str__ , 最后会找到 self.prompt

  12.     def __add__(self, other):
  13.         result = self.lasted + other.lasted
  14.         prompt = '总共运行了' + str(round(result, 2)) + '秒'
  15.         return prompt  # 返回字符串 prompt

  16.     def set_timer(self, timer):  # 默认计时器
  17.         if timer == 't.perf_counter()':
  18.             self.default_time = t.perf_counter    # 更改
  19.         if timer == 't.process_time()':
  20.             self.default_time = t.process_time    # 更改
  21.         else:
  22.             print('输入无效!,请输入"t.perf_counter() 或 t.process_time"')

  23.     # 开始计时
  24.     def start(self):
  25.         self.begin = self.default_time()    # 更改
  26.         self.prompt = '请先调用stop()停止计时!'
  27.         print('开始计时!')
  28.         print(self.begin)

  29.     # 计时停止
  30.     def stop(self):
  31.         if not self.begin:
  32.             print('请先调用start()开始计时!')
  33.         else:
  34.             self.end = self.default_time()    # 更改
  35.             self._calc()  # 在结束计时的同时会调用函数 _calc()
  36.             print('结束计时!')
  37.             print(self.end)

  38.     # 计算两次时间差
  39.     def _calc(self):
  40.         self.lasted = self.end - self.begin
  41.         self.prompt = '总共运行了' + str(round(self.lasted, 2)) + '秒'
  42.         self.begin = 0
  43.         self.end = 0


  44. t1 = MyTimes()
  45. t1.start()
  46. t.sleep(1)
  47. t1.stop()
  48. print(t1)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-3-23 12:25:43 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-23 13:11:50 | 显示全部楼层    本楼为最佳答案   
  1. import time as t


  2. class MyTimes:
  3.     def __init__(self):
  4.         self.lasted = 0.00
  5.         self.begin = 0
  6.         self.end = 0
  7.         self.prompt = '未开始计时'
  8.         self.default_time = t.perf_counter    # 更改

  9.     def __str__(self):
  10.         return self.prompt

  11.     __repr__ = __str__  # 返回字符串时会先调用 repr ,然后查找 __str__ , 最后会找到 self.prompt

  12.     def __add__(self, other):
  13.         result = self.lasted + other.lasted
  14.         prompt = '总共运行了' + str(round(result, 2)) + '秒'
  15.         return prompt  # 返回字符串 prompt

  16.     def set_timer(self, timer):  # 默认计时器
  17.         if timer == 't.perf_counter()':
  18.             self.default_time = t.perf_counter    # 更改
  19.         if timer == 't.process_time()':
  20.             self.default_time = t.process_time    # 更改
  21.         else:
  22.             print('输入无效!,请输入"t.perf_counter() 或 t.process_time"')

  23.     # 开始计时
  24.     def start(self):
  25.         self.begin = self.default_time()    # 更改
  26.         self.prompt = '请先调用stop()停止计时!'
  27.         print('开始计时!')
  28.         print(self.begin)

  29.     # 计时停止
  30.     def stop(self):
  31.         if not self.begin:
  32.             print('请先调用start()开始计时!')
  33.         else:
  34.             self.end = self.default_time()    # 更改
  35.             self._calc()  # 在结束计时的同时会调用函数 _calc()
  36.             print('结束计时!')
  37.             print(self.end)

  38.     # 计算两次时间差
  39.     def _calc(self):
  40.         self.lasted = self.end - self.begin
  41.         self.prompt = '总共运行了' + str(round(self.lasted, 2)) + '秒'
  42.         self.begin = 0
  43.         self.end = 0


  44. t1 = MyTimes()
  45. t1.start()
  46. t.sleep(1)
  47. t1.stop()
  48. print(t1)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-23 21:44:05 | 显示全部楼层

请教一下,在self.default_time = t.pert_count  这个语句中,如果不加()是否表示只代表一个参数,没有返回值,加了()则表示是一个函数,才会有返回值
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-24 08:05:39 | 显示全部楼层
yjptx121 发表于 2020-3-23 21:44
请教一下,在self.default_time = t.pert_count  这个语句中,如果不加()是否表示只代表一个参数,没有返 ...

加了括号就会直接调用函数了,不加括号不会调用函数
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-26 21:34:25 | 显示全部楼层
zltzlt 发表于 2020-3-24 08:05
加了括号就会直接调用函数了,不加括号不会调用函数

谢谢,我也意识到这个问题了,问题很白痴,望多多包涵
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-30 18:25

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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