Day13-15类、对象与魔法方法

类、对象与魔法方法

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秒
计时结束!
'''
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值