day15作业

1. 建立一个汽车类Auto,包括轮胎个数,汽车颜色,车身重量,速度等属性,并通过不同的构造方法创建实例。至少要求 汽车能够加速 减速 停车。 再定义一个小汽车类CarAuto 继承Auto 并添加空调、CD属性,并且重新实现方法覆盖加速、减速的方法

class Auto:
    def __init__(self):
        self.tire_num = 2
        self.car_color = 'black'
        self.car_weight = '150kg'
        self.speed = '20km/h'

    def speed_up(self):
        return (self.car_color, str(self.tire_num)+'个轮子', self.car_weight+'的汽车'+'加速')

    def speed_cut(self):
        return (self.car_color, str(self.tire_num)+'个轮子', self.car_weight+'的汽车'+'减速')

    def stop_car(self):
        return (self.car_color, str(self.tire_num)+'个轮子', self.car_weight+'的汽车'+'停车')


class CarAuto(Auto):
    def __init__(self, air_condition, CD):
        super().__init__()
        self.air_conditon = air_condition
        self.CD = CD

    def speed_up(self):
        return (self.CD,self.air_conditon,self.car_color, str(self.tire_num)+'个轮子', self.car_weight+'的汽车'+'减速')

    def speed_cut(self):
        return (self.CD,self.air_conditon,self,self.car_color, str(self.tire_num)+'个轮子', self.car_weight+'的汽车'+'减速')

moto = Auto()
print(moto.__dict__)
print(moto.speed_cut())
print(moto.speed_up())
print(moto.stop_car())
car = CarAuto('30度', '成都')
print(car.__dict__)
print(car.speed_up())
print(car.speed_cut())

2. 创建一个Person类,添加一个类字段用来统计Perosn类的对象的个数

class Person:
    count = 0

    def __init__(self):  #创建一次对象自动调用魔法方法一次
        Person.count += 1


p1 = Person()
p2 = Person()
p3 = Person()
print(Person.count)

3. 创建一个动物类,拥有属性:性别、年龄、颜色、类型 ,

要求打印这个类的对象的时候以'/XXX的对象: 性别-? 年龄-? 颜色-? 类型-?/' 的形式来打印

class Animal:
    def __init__(self):
        self.sex = '-?'
        self.age = '-?'
        self.color = '-?'
        self.type = '-?'
a1 = Animal()
print('/'+str(a1.__class__)[17:-2],'对象:'+'性别'+a1.sex+'年龄'+a1.age+'颜色'+a1.color+'类型'+a1.type+'/')

方法2:

class Animal:
    def __init__(self):
        self.sex = '?'
        self.age = '?'
        self.color = '?'
        self.type = '?'

    def __str__(self):
        return '/{}对象:性别-{} 年龄-{} ' \
               '类型-{}/'.format(str(self.__class__)[17:-2], self.sex, self.age, self.color, self.type)

a1 = Animal()
print(a1)

4. 写一个圆类, 拥有属性半径、面积和周长;要求获取面积和周长的时候的时候可以根据半径的值把对应的值取到。但是给面积和周长赋值的时候,程序直接崩溃,并且提示改属性不能赋值

class ValueError(Exception):
    def __str__(self):
        return '该方法不能重写'

class Circle:
    pi = 3.1415926

    def __init__(self, r):
        self.r = r
        self._area = 0
        self._perimeter = 0

    @property
    def area(self):
        return Circle.pi*self.r*self.r

    @area.setter
    def area(self,value):
        raise ValueError

    @property
    def perimeter(self):
        return 2*Circle.pi*self.r

    @perimeter.setter
    def perimeter(self):
        raise ValueError



p1 = Circle(2)
print(p1.area)
# p1.area = 100
# print(p1.area)
p1.perimeter = 100
print(p1.perimeter)

5. 写一个扑克类, 要求拥有发牌和洗牌的功能(具体的属性和其他功能自己根据实际情况发挥)

import random
class Poker:
    count = 1
    @staticmethod
    def born_poker():
        list1 = []
        color = ['黑桃', '梅花', '红桃', '方块']
        num = list(range(2, 11))
        num1 = ('J', 'Q', 'K', 'A')
        num.extend(num1)
        for i in color:
            for j in num:
                list1.append([i,j])
                print(i,j, end=' ')
        list1.extend(['大王', '小王'])
        return list1

    def __init__(self,list1):
        self.list1 = list1

    def shuffle(self):
        random.shuffle(self.list1)
        return self.list1

    def deal1(self):
        print('\n==========第%s局=========' % Poker.count)
        print(p1.shuffle())
        print('\n底牌:', self.list1[:3])
        print('第一个人的牌:', self.list1[3:20])
        print('第二个人的牌:', self.list1[20:37])
        print('第三个人的牌:', self.list1[37:55])
        Poker.count += 1

    def richcard_card(self, play_poker=True):
        if not play_poker:
            return self.shuffle(), self.deal1()
        else:
            return self.deal1()


p1 = Poker(Poker.born_poker())
p1.born_poker()
p1.deal1()
p1.richcard_card()

6. (尝试)写一个类,其功能是:1.解析指定的歌词文件的内容 2.按时间显示歌词 提示:歌词文件的内容一般是按下面的格式进行存储的。歌词前面对应的是时间,在对应的时间点可以显示对应的歌词

import time


class Song:
    def __init__(self, minute, second, millisecond):
        self.minute = minute
        self.second = second
        self.millisecond = millisecond
        self.time1 = None
        self.lyric = None

    @staticmethod
    def read_lyric():  #这个对象方法负责读文本内容按行读
        with open('./lanlianhua', 'r', encoding='utf-8') as f:
            return f.readlines()

    def print_lyric(self):
        while self.minute < 3:
            self.millisecond += 1
            if self.millisecond == 60:
                self.second += 1
                self.millisecond = 0
            elif self.second == 60:
                self.minute += 1
                self.second = 0
            self.time1 = '['+str(self.minute).rjust(2, '0')+':'+str(self.second).rjust(2, '0')\
                         + '.'+str(self.millisecond).rjust(2, '0')+']'
            print(self.time1)    #每微妙开始读
            for self.lyric in Song.read_lyric():
                if self.time1 in self.lyric[:self.lyric.rfind(']')+1]:    #读到与文本相同时间歌词就打印
                    print(self.lyric[self.lyric.rfind(']')+1:])
                    time.sleep(0.8)
                    break


p1 = Song(0, 0, 0)
p1.print_lyric()
[00:00.20]蓝莲花   
[00:00.80]没有什么能够阻挡   
[00:06.53]你对自由地向往   
[00:11.59]天马行空的生涯  
[00:16.53]你的心了无牵挂   
[02:11.27][01:50.22][00:21.95]穿过幽暗地岁月   
[02:16.51][01:55.46][00:26.83]也曾感到彷徨   
[02:21.81][02:00.60][00:32.30]当你低头地瞬间  
[02:26.79][02:05.72][00:37.16]才发觉脚下的路   
[02:32.17][00:42.69]心中那自由地世界  
[02:37.20][00:47.58]如此的清澈高远   
[02:42.32][00:52.72]盛开着永不凋零   
[02:47.83][00:57.47]蓝莲花  

你可能感兴趣的:(day15作业)