一.课程安排
二.课堂笔记
1.异常简介
- 程序在运行过程中可能会出现一些错误。比如: 使用了不存在的索引,两个不同类型的数据相加....这些错误我们称之为异常
- 异常以后的代码都不会执行
- 处理异常 程序运行时出现异常,目的并不是让我们的程序直接终止!Python是希望在出现异常时,我们可以编写代码来对异常进行处理
2.异常的传播
- 当在函数中出现异常时,如果在函数中对异常进行了处理,则异常不会在进行传播。如果函数中没有对异常进行处理,则异常会继续向函数调用传播。
- 如果函数调用处处理了异常,则不再传播异常,如果没有处理则继续向调用处传播。直到传递到全局作用域(主模块)如果依然没有处理,则程序终止,并显示异常信息。
- 当程序运行过程中出现异常以后,所有异常信息会保存到一个异常对象中。而异常传播时,实际上就是异常对象抛给了调用处
3.异常对象
1 try语句
2 try:
3 代码块(可能出现错误的语句)
4 except 异常类型 as 异常名:
5 代码块(出现错误以后的处理方式)
6 except 异常类型 as 异常名:
7 代码块(出现错误以后的处理方式)
8 except 异常类型 as 异常名:
9 代码块(出现错误以后的处理方式)
10 ....
11 else:
12 代码块(没出错时要执行的语句)
13
14 finally:
15 代码块(是否出错该代码块都会执行)
16 try是必须的 else有没有都可以
17 except和finally至少有一个
4.文件打开
- 文件(file) 通过Python程序来对计算机中的各种文件进行增删改查的操作 文件也叫I/O(Input/Output)
- 文件的操作步骤
- 打开文件
- 对文件进行各种操作(读、写)然后保存
- 关闭文件
- 文件会有一个返回值。返回一个对象,这个对象就表示的是当前的文件
5.关闭文件
file_name = 'demo.txt'
file_obj = open(file_name)
# # read()函数 用来读取文件的内容,它会将内容全部保存到一个字符串返回
content = file_obj.read()
print(content)
# # 关闭文件
# # 调用close()函数来关闭文件
file_obj.close()
- with...as 语句不用写close()来关闭。它自带关闭
# with...as...语句 不用写close()
file_name = 'demo.txt'
try:
with open(file_name) as file_obj:
print(file_obj.read())
except FileNotFoundError:
print(f'{file_name}文件不存在.....')
6.读取文件
- 通过read()来读取文件的内容
- 调用open()来打开一个文件,可以将文件分为2种类型
- 一种纯文本文件(使用utf-8编码编写的文件)
- 一种二进制文件(图片 mp3 视频...)
- open()打开文件时,默认是以文本文件的形式打开的 open()默认的编码
为None。所以处理文本文件时要指定编码
# 调用open()函数打开一个文件时,可以将文件分为2种类型
# 一种纯文本
# 一种是二进制文件
file_name = 'demo2.txt'
try:
with open(file_name,encoding='utf-8') as file_obj:
print(content)
except FileNotFoundError:
print(f'{file_name}文件不存在.....')
7.较大文件的读取
- 通过read()读取文件内容时会将文件中所有的内容全部读取出来。如果对于读取的文件比较大的话。会一次性的将文件加载到内容中。容易导致内存泄露。所以对于较大的文件。不要直接调用read()
- read()可以接收一个size作为的参数。该参数用来指定要读取字符的数量。默认值为-1.-1也就是要读取全部的内容
- 每次读取都会从上次读取到的位置开始。如果字符的数量小于size。则会读取所有的。如果读取到最后的文件。则会返回空串
- readline() 该方法用来读取一行
- readlines() 该方法用于一行一行的读取内容,它会一次性将读取到的内容封装到一个列表当中返回
file_name = 'demo.txt'
try:
with open(file_name,encoding='utf-8') as file_obj:
# 定义一个变量 来保存结果
file_content = ''
# 定义一个变量 指定每次读取的大小
chunk = 100
# 创建一个循环来读取内容
while True:
content = file_obj.read(chunk)
# 检查是否读完文件
if not content:
# 内容读取完毕退出循环
break
# print(content,end='')
file_content += content
except FileNotFoundError:
print(f'{file_name}文件不存在.....')
print(file_content,end='')
8.文件的写入
- write()来向文件中写入内容
- 该方法可以分多次向文件写入内容
- 写入完成之后该方法会返回写入的字符的个数
- 使用open()函数打开文件时,必须要指定打开文件要做的操作(读、写、追加)。如果不指定操作类型,则默认是读取文件,而读取文件是不能向文件中写入
- r 表示只读
- w表示可以写。使用w写入文件时,如果文件不存在则会创建一个文件。如果文件存在则会覆盖原文件内容
file_name = 'demo4.txt'
with open(file_name,'x',encoding='utf-8') as file_obj:
# write()来向文件中写入内容
# 如果操作的是一个文本文件的时候,则需要传递一个字符串作为参数
# r表示只读
# w表示可以写
# a表示追加
# x 表示用来创建新的文件,如有文件不存在则创建,如果存在就报错
# FileExistsError: [Errno 17] File exists: 'demo.txt'
# file_obj.write('nice to meet you') # io.UnsupportedOperation: not writable
file_obj.write('abc\n')
file_obj.write('def')
file_obj.write('wxy')
r = file_obj.write(str(123)+'\n') # TypeError: write() argument must be str, not int
print(r)
9.二进制文件写入
- 读取文本文件时,size是以字符为单位。读取二进制文件时,size是以字节为单位
- 我们用wb来写入二进制文件
file_name = r'C:\Users\9100F-7\Desktop\Kalimba.mp3' # 取一个需要复制的文件地址
# 读取模式
# t 读取文本文件(默认值)
# b 读取二进制文件
with open(file_name,'rb') as file_obj:
# print(file_obj.read(100)) # UnicodeDecodeError: 'gbk' codec can't decode byte 0xd1 in position 165: illegal multibyte sequence
# 将读取到的内容写出来
# 定义一个新的文件
new_name = 'abc.mp3'
with open(new_name,'wb') as new_obj:
# 定义每次读取的大小
chuck = 1024 * 100
while True:
# 读取数据
content = file_obj.read(chuck)
# 判断是否读取完毕
if not content:
break
# 将内容写到新的文件当中
new_obj.write(content)
10. Python内置的OS模块
import os
# print(os.listdir())
# r = os.getcwd() # 获取当前的目录
# os.mkdir('abc') # 创建文件夹
os.rmdir('abc')
# print(r)