|
|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 mika666 于 2017-1-8 14:52 编辑
请问各位,为何我在Shell中像小甲鱼视频里那样直接输入't1+t2',会打印一个似乎是路径的东西?
只有用print t1+t2才能正确打印,是否由于我使用的是python 2.7的关系呢?
>>> t1=MyTimer()
>>> t2=MyTimer()
>>> t1.start()
计时开始...
>>> t1.stop()
计时结束...
>>> t1
总共运行了4秒
>>> t2.start()
计时开始...
>>> t2.stop()
计时结束...
>>> t2
总共运行了1分钟-56秒
>>> t1+t2
'\xd7\xdc\xb9\xb2\xd4\xcb\xd0\xd0\xc1\xcb1\xb7\xd6\xd6\xd3-52\xc3\xeb'
>>> print(t1+t2)
总共运行了1分钟-52秒
PS:代码如下:同视频里应当是一模一样的
- import time as t
- class MyTimer():
- def __init__(self):
- self.unit=['年','月','日','小时','分钟','秒']
- self.prompt ='未开始计时'
- self.lasted=[]
- self.begin=0
- self.end=0
-
- def __str__(self):
- return self.prompt
- __repr__=__str__
- def __add__(self,other):
- prompt='总共运行了'
- result=[]
- for index in range(6):
- result.append(self.lasted[index]+other.lasted[index])
- if result[index]:
- prompt +=(str(result[index])+self.unit[index])
- return prompt
- #开始计时
- def start(self):
- self.begin=t.localtime()
- self.prompt ='提示:请先调用stop()停止计时'
- print '计时开始...'
- #停止计时
- def stop(self):
- if not self.begin:
- print('提示:请先调用start()进行计时')
- self.end=t.localtime()
- self._calc()
- print '计时结束...'
- #内部方法计算运行时间
- def _calc(self):
- self.lasted=[]
- self.prompt='总共运行了'
- for index in range(6):
- self.lasted.append(self.end[index]-self.begin[index])
- if self.lasted[index]:
- self.prompt +=(str(self.lasted[index])+self.unit[index])
- self.begin=0
- self.end=0
复制代码 |
|