马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
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
|