一、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('账号')
- 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))