实操

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

    def __init__(self, tyre=0, color='白色', weight=0, speed=0):
        self.tyre = tyre
        self.color = color
        self.weight = weight
        self.speed = speed

    def speed_up(self):
        """汽车的加速方法"""
        self.speed += 10
        return self.speed

    def speed_down(self):
        """汽车的减速方法"""
        self.speed = 0
        return self.speed

    def stop_car(self):
        self.speed_down()
        print('车停好了')


class CarAuto(Auto):
    """Auto子类"""

    def __init__(self, air_condition: str, cd: str):
        super().__init__()
        self.air_condition = air_condition
        self.cd = cd

    def speed_up(self):
        """CarAuto的加速方法"""
        self.speed += 12
        return self.speed

    def speed_down(self):
        """CarAuto的减速方法"""
        self.speed = 0
        return self.speed


ao = Auto(4, '白色', 400, 10)
carao = CarAuto('高级空调', '动感CD')
print(ao.speed_up())
print(ao.speed_down())

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

class Person:
    num = 0

    def __init__(self):
        Person.num += 1


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

3.创建一个动物类,拥有属性:性别、年龄、颜色、类型 ,
要求打印这个类的对象的时候以
'/XXX的对象: 性别-? 年龄-? 颜色-? 类型-?/'
的形式来打印

class Animal:
    """动物类"""

    def __init__(self, gender, age, color, type_):
        self.gender = gender
        self.age = age
        self.color = color
        self.type_ = type_

    def animal_print(self):
        """打印动物的信息"""
        print('%s的对象: 性别-%s 年龄-%d 颜色-%s 类型-%s' % (self.__class__, self.gender, self.age, self.color, self.type_))


animal = Animal('母', 18, '白色', '人妖')
animal.animal_print()

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

from math import pi


class ModifyError(Exception):
    """改错误的类"""
    def __str__(self):
        return '尝试修改只读属性的值——Attempts to modify the value of the read-only property'


class Circle:
    """圆类"""

    def __init__(self, radius):
        self._radius = radius
        self._perimeter = 2*pi*radius
        self._area = pi*radius**2

    @property
    def radius(self):
        return self._radius

    @radius.setter
    def radius(self, value):
        self._radius = value
        self._perimeter = 2*pi*value
        self._area = pi*value**2

    @property
    def perimeter(self):
        return self._perimeter

    @perimeter.setter
    def perimeter(self, value):
        raise ModifyError

    @property
    def area(self):
        return self._area

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


circle = Circle(3)
print(circle.perimeter)
print(circle.area)
# circle.perimeter = 1
circle.area = 1

5.(尝试)写一个类,其功能是:1.解析指定的歌词文件的内容
2.按时间显示歌词
提示:歌词文件的内容一般是按下面的格式进行存储的。歌词前面对应的是时间,在对应的时间点可以显示对应的歌词
[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]蓝莲花

class ReadLyric:
    """读取歌词文件的类。功能还不完善"""
    def __init__(self, time):
        # 这个时间是你要读取歌曲时间在几分钟之内
        self.time = time

    def read(self):
        with open('lyric.txt', encoding='utf-8') as f:
            temp = True
            time_add = 0
            while temp:
                time_temp = 0
                content = f.readline()
                temp1 = True
                while temp1:
                    time_add += 1
                    # print(time_add)

                    # 计算每句课次的时间点,只能转换成整型进行比较,因为浮点型在计算机里面精度会改变
                    time_temp = (int(content[1:3]) * 60 * 100 + int(content[4:6]) * 100 + int(content[7:9]))
                    try:
                        if content[10] == '[':
                            time_temp += (int(content[11:13]) * 60 * 100 + int(content[14:16]) * 100 + int(content[17:19]))
                        elif content[20] == '[':
                            time_temp += (int(content[21:23]) * 60 * 100 + int(content[24:26]) * 100 + int(content[27:29]))
                        elif content[30] == '[':
                            time_temp += (int(content[31:33]) * 60 * 100 + int(content[34:36]) * 100 + int(content[37:39]))
                        elif content[40] == '[':
                            time_temp += (int(content[41:43]) * 60 * 100 + int(content[44:46]) * 100 + int(content[47:49]))
                    except IndexError:
                        pass
                    finally:
                        if time_temp == time_add:
                            print(content[10:])
                            # print('这个时候时间点为:%s' % content[:10])
                            temp1 = False
                        if time_add == self.time*60*100:
                            temp = False

                    # print(time_temp)
                    # print(content[10:])

                # try:
                #
                # except:
                #     temp = False
                #     print('有错误')
            # print(f.readline()[10:])
            # print(f.readline()[:10])



read = ReadLyric(10)
read.read()
老师的版本
"""__author__ = 余婷"""


class Lyric:
    def __init__(self, word):
        self._time = 0
        self.word = word

    @property
    def time(self):
        return self._time

    @time.setter
    def time(self, value):
        # value = '[00:45.99'
        fen = float(value[1:3])
        miao = float(value[4:])
        self._time = fen*60 + miao

    def __repr__(self):
        return str(self.__dict__)


class LyricAnalysis:

    def __init__(self, name):
        self._name = name
        self.__all_lyric = []

    @property
    def name(self):
        return self._name

    @name.setter
    def name(self, value):
        self._name = value
        self.__all_lyric.clear()

    def __analysis_file(self):
        if not self.__all_lyric:
            print('=========去解析歌词===============')
            # 1.解析歌词文件中的内容
            with open('files/%s.txt' % self.name, encoding='utf-8') as f:
                while True:
                    # 读一行内容
                    line = f.readline()
                    # 切割字符串
                    lines = line.split(']')   # ['[02:11.27', '[01:50.22', '[00:21.95', '穿过幽暗地岁月\n']
                    # 遍历时间创建歌词对象
                    for time_str in lines[:-1]:
                        lyric_obj = Lyric(lines[-1])
                        lyric_obj.time = time_str
                        # print(lyric_obj.__dict__)
                        self.__all_lyric.append(lyric_obj)

                    if not line:
                        break
            # 2.对当前歌的歌词按时间排序
            self.__all_lyric.sort(reverse=True, key=lambda item: item.time)
            print(self.__all_lyric)

    def get_world(self, time):
        # 解析歌词文件
        self.__analysis_file()

        # 3.根据时间找对应的歌词
        for item in self.__all_lyric:
            if item.time < time:
                return item.word
        return '歌名'+self.name


l1 = LyricAnalysis('蓝莲花')
print(l1.get_world(30))
print(l1.get_world(10))
print(l1.get_world(10))

l1.name = '东风破'
print(l1.get_world(20))
print(l1.get_world(30))
print(l1.get_world(10))
print(l1.get_world(10))

蓝莲花.txt文件内容

[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]蓝莲花
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,590评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 86,808评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,151评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,779评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,773评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,656评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,022评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,678评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,038评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,659评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,756评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,411评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,005评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,973评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,053评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,495评论 2 343

推荐阅读更多精彩内容

  • 1.建立一个汽车类Auto,包括轮胎个数,汽车颜色,车身重量,速度等属性,并通过不同的构造方法创建实例。 至少要求...
    不语sun阅读 180评论 0 0
  • 0.定义一个学生类。有属性:姓名、年龄、成绩(语文,数学,英语)[每课成绩的类型为整数]方法: a. 获取学生的姓...
    rzlong阅读 154评论 0 1
  • 0.定义一个学生类。有属性:姓名、年龄、成绩(语文,数学,英语)[每课成绩的类型为整数] 方法: a. 获取学生的...
    Voyaserfuerte阅读 236评论 0 0
  • 0.定义一个学生类。有属性:姓名、年龄、成绩(语文,数学,英语)[每课成绩的类型为整数]方法: a. 获取学生的姓...
    DoubleKou阅读 132评论 0 0
  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 10,863评论 6 13