day16-正则表达式和作业:总结

一、recode

1.文件操作
a.操作流程: 打开文件(open) --- 操作文件 --- 关闭文件(close)
with open() as 文件变量名:
文件操作

open(文件路径,打开方式,encoding=编码方式)

b.打开方式
r/br/rb :
w/bw/wb/a : 文件路径不存在会自动创建那个文件

c.编码方式
文本编码,二进制不能去设置!!

d.读(read)、写(write)

e.json文件/json数据
json数据的格式:只有一个数据,并且类型必须是json支持的数据类型
数据类型及其表现:数组、对象(字典)、数字、字符串、布尔、null
[元素1,元素2...]、{key1:value1,key2:value2...}、190/12.78/-1、"abc"、true/false、null
python对json的支持:
load(文件对象): 获取json文件中的数据,并且转换成相应python数据
loads(json格式的字符串): 将字符串转换成python数据
dump(): 将python数据转换成json数据然后再写到json文件中
dumps():将python数据转换成json格式的字符串

f.数据本地化和持久化
比如将数据number的值转数据本地化
先从本地去取值 --> 对取出来的值进行处理 --> 再将新的值存到本地

2.异常捕获
try:
需要捕获异常的代码
except:
异常发生
finally:
不管异常是否发生,都执行

a.except: 捕获所有异常 b.except 类型名: 捕获指定的异常(这个结构可以出现多次)c.except (类型名1, 类型名2...):

抛出异常
raise 异常类型

异常类型:要求必须是Exception的子类

3.类和对象
1概念
类:具有相同功能和属性的对象的集合(抽象的)
对象:类的实例(具体)

2)类的声明
class 类名(父类):
类的说明文档
类的内容

3)**创建对象
a.格式:对象 = 类名()
b.通过调用构造方法创建对象的时候,会自动调用init方法去对对象进行初始化
c.init方法的传参

4)属性
对象属性:
a.init方法中声明,self.属性名 = 值
b.通过对象去使用
c.对象属性的增删(了解), 获取对象属性的值和修改对象属性值(掌握)---> 对象.属性

类的字段:
a.直接声明在类中的变量
b.通过类去使用 --> 类.字段

私有化、保护类型(getter和setter)等 ----> 能掌握最好

5)方法
对象方法:
a.直接声明在类的方法
b.自带一个self参数(self不需要传参,指向当前对象)
c.对象方法通过对象调用
d.需要使用对象的属性才用对象方法

类方法:
a.@classmethod修饰
b.自带一个cls参数(cls不需要传参,指向当前类)
c.类方法通过类调用
d.需要使用类的字段的时候使用类方法

静态方法:
a.@staticmethod修饰
b.没有自带参数
c.通过类来调用
d.不需要对象属性的时候就可以使用

**本质上,python中的类可以调用类中所有的方法

import json

class Person:
    number = 10
    def __new__(cls, *args, **kwargs):
        print('创建对象')

    def __init__(self, a, b):
        self.name = '张三'
        print('初始化对象', a, b)

    def eat(self):
        print('%s:abc' % self.name)

p1 = Person(10, 20)

二、类的补充:

import Person
from Time import Date

1.多继承(了解)
python中的类支持多继承,但是不建议使用。
多继承继承的时候,子类可以拥有所有父类的所有的方法和类的字段,但是只能继承第一个父类的对象属性

2.多态
多态指的是一种事物有多种形态
有继承就有多态:不同类继承自同一个类,其实就是对这个共同的父类的不同的形态。继承后对方法的重写也是多态的表现。

3.封装、继承、多态
封装:一个类可以通过不同的方法对不同的通能进行封装。通过属性对不同的数据进行封装。
继承:通过继承可以让子类拥有父类的属性和方法

4.包
将多个模块封装到一起,就是包。包就是有一个默认文件init.py的文件夹

a.import 包.模块

import download.saveData
download.saveData.save_data_json('abc')

b.from 包 import 模块

from download import downloadData
downloadData.http_downoad('一人之下')

c.from 包.模块 import 方法/变量/类

from download.saveData import insert_db
insert_db('账号')
  1. raise 错误类型
    raise可以让程序主动崩溃,一般用于调试
    raise:关键字
    错误类型:必须是一个类,并且这个类是Exception的子类

====================1.抛出异常=======================

class YTError(Exception):
    name = ''
    # 通过str魔法方法来设置错误提示信息
    # __str__的本质,就是定义类和对象的打印的内容
    def __str__(self):
        return '余氏错误!%s' % YTError.name

num = 11
if num % 2:
    YTError.name = '奇数错误!'
else:
    YTError.name = '偶数错误!'

raise YTError

===================2.多继承======================

class Animal(object):
    def __init__(self, age=0, name='小动物'):
        self.age = age
        self.name = name

    def eat(self):
        print('%s在吃东西' % self.name)


class Fly:
    def __init__(self, height=0):
        self.max_height = height

    def fly(self):
        # print('最大能飞:%d米' % self.max_height)
        print('飞起来')

让Bird同时继承Animal类和Fly类

class Bird(Fly, Animal):
    def eat(self):
        print('在吃虫子')
    pass

    bird1 = Bird()
    # print(bird1.name, bird1.age)
    print(bird1.max_height)
    bird1.eat()
    bird1.fly()

    Person.name = '李四'
    Person.eat()

三、作业:

==================1.电脑类=================

class Computer:
    """电脑类"""
    def __init__(self, brand='联想', color='黑色', memory=0):
        self.brand = brand
        self.color = color
        self.memory = memory

    @staticmethod
    def play_game(game):
        print('玩儿%s' % game)

    @staticmethod
    def code():
        print('写python代码')

    @staticmethod
    def watch_video(video):
        print('在看%s' % video)


com1 = Computer(memory=512)
# 查
print(com1.color)
print(getattr(com1, 'color', '白色'))
# 改
com1.brand = '戴尔'
setattr(com1, 'brand', '华硕')
# 增
# com1.size = 13.5
setattr(com1, 'size', 15)
print(com1.size)
# 删
del com1.size
delattr(com1, 'memory')

=====================2.人和狗====================

class Dog:
    """狗"""
    def __init__(self, name1='', color1='', age1=0):
        self.name = name1
        self.color = color1
        self.age = age1

    def shout(self):
        print('%s在汪汪叫!' % self.name)


class Person:
    """人"""
    def __init__(self, name='', age=0):
        self.name = name
        self.age = age
        self.dog = None   # dog属性的值必须是Dog类的对象

    def took_dog(self):
        # 能遛狗的前提是自己有狗
        if not self.dog:
            print('没有~溜自己吧!')
            return
        print('%s牵着%s在玩儿~' % (self.name, self.dog.name))


p1 = Person('小明')
p1.age = 18
p1.dog = Dog('大黄', '黄色', 2)
p1.took_dog()

===================3.学生和班级================

class Student:
    """学生"""
    def __init__(self, name, age=0, id=''):
        self.name = name
        self.age = age
        self.id = id

    def response(self):
        """答到"""
        print('%s,到!' % self.name)

    def show_info(self):
        print('姓名:%s 年龄:%d 学号:%s' % (self.name, self.age, self.id))


class Class:
    """班级"""
    def __init__(self, name):
        self.students = []  # 这个列表的元素是学生对象
        self.name = name
        self.__count = 0

    def add_student(self):
        """添加学生"""
        name = input('姓名:')
        age = input('年龄:')
        # 学号
        self.__count += 1
        id = 'stu' + str(self.__count).rjust(3, '0')

        # 创建学生对象
        stu = Student(name, int(age), id)

        # 将学生保存到班级中
        self.students.append(stu)

    def del_student(self):
        """删除学生"""
        del_name = input('请输入要删除的学生名字:')

        is_del = False
        # 遍历列表拿到的是学生对象
        for stu in self.students[:]:
            if stu.name == del_name:
                self.students.remove(stu)
                print('删除成功!')
                is_del = True

        if not is_del:
            print('没有该学生!')

    def call_names(self):
        """点名"""
        for stu in self.students:
            print(stu.name)
            stu.response()


class1 = Class('python1806')
# 添加学生
for _ in range(5):
    class1.add_student()
# 删除学生
class1.del_student()
# 点名
class1.call_names()

=====================4.数学类========================

class Math:
    pi = 3.14159265358
    e = 2.7

    @staticmethod
    def sum_double(num1, num2):
        return num1 + num2

    @classmethod
    def circle_area(cls, r):
        return cls.pi * r**2

五、歌词解析:

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

    def __str__(self):
        return '%.2f %s' % (self.time, self.word)

    def __gt__(self, other):
        return self.time > other.time


class LyricAnalysis:
    """歌词解析类"""
    # 创建解析器对象的时候告诉我这个解析器是要解析哪首歌
    def __init__(self, song_name):
        # 保证一个歌词解析器对象对应一首歌
        self.song_name = song_name
        # 一首歌对应一个容器
        self.all_lyric = []
        # 解析歌词
        self.__collect_lyric()

    def __get_time_word(self, content):
        """提取歌词和时间"""
        contents = content.split(']')
        # 词
        word = contents[-1]
        for time in contents[:-1]:
            # 将时间转换秒
            times = time[1:].split(':')
            fen = float(times[0])
            miao = float(times[1])
            new_time = fen*60 + miao
            # 根据时间和词创建歌词对象
            lyric = Lyric(new_time, word)
            # 保存歌词对象
            self.all_lyric.append(lyric)

    def __collect_lyric(self):
        """将时间和词提取出来"""
        # 读歌词文件中的内容
        try:
            with open('./files/%s.txt' % self.song_name, 'r', encoding='utf-8') as f:
                # 一行一行的读
                line = f.readline()
                while line:
                    # 将每一行中的内容的词和时间弄出来
                    self.__get_time_word(line)
                    line = f.readline()
                # 排序
                self.all_lyric.sort(reverse=True)

                # for lyric in self.all_lyric:
                #     print(lyric)

        except FileNotFoundError:
            print('文件不存在')

    def get_word(self, time):
        """根据时间获取歌词"""
        for lyric in self.all_lyric:
            if lyric.time <= time:
                return lyric.word


an1 = LyricAnalysis('蓝莲花')
print(an1.get_word(120))

你可能感兴趣的:(day16-正则表达式和作业:总结)