鱼C论坛

 找回密码
 立即注册
查看: 2775|回复: 7

[已解决]第44讲,MyTimer计时器问题求教

[复制链接]
发表于 2018-4-25 21:44:10 | 显示全部楼层 |阅读模式

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

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

x
  1. import time as t

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

  7.     #停止计时
  8.     def stop(self):
  9.         self.stop = t.localtime()
  10.         self._calc()
  11.         print('停止计时')
  12.         
  13.     #内部方法:计算运行时间
  14.     def _calc(self):
  15.         self.lasted = []
  16.         self.prompt ='总共运行了'
  17.         for index in range(6):
  18.             self.lasted.append(self.stop[index] - self.start[index])
  19.             self.prompt += str(self.lasted[index])

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


运行后出现错误
>>> t1=MyTimer()
>>> t1.start()
记时开始
>>> t1.stop()
Traceback (most recent call last):
  File "<pyshell#17>", line 1, in <module>
    t1.stop()
  File "F:\小甲鱼练习\44-计时器.py", line 13, in stop
    self._calc()
  File "F:\小甲鱼练习\44-计时器.py", line 21, in _calc
    self.lasted.append(self.stop[index] - self.start[index])
TypeError: 'method' object is not subscriptable
>>>


最佳答案
2018-4-25 23:02:25
hi 原因如下

第6行代码笔误,self.star = t.localtime() ,应该为 :self.start = t.localtime() ,修改后调试通过

>>> a = MyTimer()
>>> a.start()
记时开始
>>> a.stop()
总共运行了000003
停止计时
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-4-25 22:04:17 | 显示全部楼层
函数名和属性重了,换名字,用begin,end之类
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-4-25 22:12:34 | 显示全部楼层
塔利班 发表于 2018-4-25 22:04
函数名和属性重了,换名字,用begin,end之类

不是吧,小甲鱼的课程里都是一样的啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-4-25 22:17:39 | 显示全部楼层
塔利班 发表于 2018-4-25 22:04
函数名和属性重了,换名字,用begin,end之类

改了的确不出问题了,但是为啥课程里没事呢???
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-25 23:02:25 | 显示全部楼层    本楼为最佳答案   
hi 原因如下

第6行代码笔误,self.star = t.localtime() ,应该为 :self.start = t.localtime() ,修改后调试通过

>>> a = MyTimer()
>>> a.start()
记时开始
>>> a.stop()
总共运行了000003
停止计时
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-4-26 10:23:44 | 显示全部楼层
thexiosi 发表于 2018-4-25 23:02
hi 原因如下

第6行代码笔误,self.star = t.localtime() ,应该为 :self.start = t.localtime() ,修改 ...

感谢,新人总是敲错代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-26 11:08:46 | 显示全部楼层
wj465596344 发表于 2018-4-26 10:23
感谢,新人总是敲错代码

没事

调试的时候,加几个print语句,很容易定位出错误的 :)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-2-16 11:13:23 | 显示全部楼层
self.prompt += str(self.lasted[index])这行代码为什么这么写,prompt不是提示内容吗,还有self.lasted[index]意思不是把lasted列表中的内容挨个索引一遍吗,那是要把后面时间元组中的数减完然后和前面那个提示符相加吗?最后程序跑出来时间超过20秒的话就返回的是  >>> t1+t2         '总共运行了1分钟-22秒'
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-1 00:51

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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