类、对象与魔法方法
类
1.定义
属性+方法?
103页
1、以下类定义中哪些是类属性,哪些是实例属性?
class C:
num = 0 # 类属性
def __init__(self):
self.x = 4 #实例属性
self.y = 5 #实例属性
C.count = 6 #类属性
2、怎么定义私有⽅法?
定义私有变量只需要在变量名或函数名前加上“__”两个下划线,那么这个函数或变量就会为私有的了。
3、尝试执行以下代码,并解释错误原因:
class C:
def myFun():
print('Hello!')
c = C()
c.myFun()
类的方法与普通的函数区别:它们必须有一个额外的第一个参数名称(对应于该实例,即该对象本身),按照惯例它的名称是 self。
代码缩进问题导致调用类出现错误。
4、按照以下要求定义一个游乐园门票的类,并尝试计算2个成人+1个小孩平日票价。
平日票价100元 周末票价为平日的120% 儿童票半价
class Ticket():
week_a = 100
weekend_a = 120
week_c = 50
weekend_c = 60
def __init__(self, adult, child, d):
self.adult = adult
self.child = child
self.d = d
def cost(self):
if (self.d == 'week'):
self.c = self.adult * self.week_a + self.child * self.week_c
if (self.d == 'weekend'):
self.c = self.adult * self.weekend_a + self.child * self.weekend_c
print(self.c)
A = Ticket(2, 1, 'week')
A.cost()
139页
1、上面提到了许多魔法方法,如 new,init, str,rstr,getitem,setitem 等
等,请总结它们各自的使用方法。
new__对当前类进行了实例化,并将实例返回,传给__init__的self。但是,执行了__new,并不一定会进入__init,只有__new__返回了,当前类cls的实例,当前类的__init__才会进入。
init(self[, …]) 构造器,当一个实例被创建的时候调用的初始化方法.
str(self):当你打印一个对象的时候,触发__str__当你使用%s格式化的时候,触发__str__ str强转数据类型的时候,触发__str__
repr(self):repr是str的备胎有__str__的时候执行__str__,没有实现__str__的时候,执行__repr__
repr(obj)内置函数对应的结果是__repr__的返回值当你使用%r格式化的时候 触发__repr__
getitem(self, key)定义获取容器中元素的行为,相当于self[key]。
setitem(self, key, value)定义设置容器中指定元素的行为,相当于self[key] = value。
2、利用python做一个简单的定时器类
要求:
1.定制一个计时器的类。 2. start 和 stop 方法代表启动计时和停止计时。 3. 假设计时器对象 t1 , print(t1) 和直接调用 t1 均显示结果。 4. 当计时器未启动或已经停止计时时,调用 stop 方法会给予温馨的提示。 5. 两个计时器对象可以进行相加: t1+t2 。 6. 只能使用提供的有限资源完成。
import time as t
class Time_count:
def __init__(self):
self.unit = ['年','月','日','时','分','秒']
self.prompt = "未开始计时"
self.lasted = []
self.begin = 0
self.end = 0
# 开始
def start(self):
self.begin = t.localtime()
self.prompt = "提示:请先调用stop()开始计时"
print("计时开始!")
# 停止
def stop(self):
if not self.begin:
print("提示:请先调用start()开始计时")
else:
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])
print(self.prompt)
self.begin = 0
self.end = 0
a = Time_count()
a.start()
t.sleep(2) #延时函数
a.stop()
'''
计时开始!
计时结果为:2秒
计时结束!
'''