程序在运行过程中可能会出现一些错误。比如: 使用了不存在的索引,两个不同类型的数据相加…这些错误我们称之为异常。
处理异常 程序运行时出现异常,目的并不是让我们的程序直接终止!Python是希望在出现异常时,我们可以编写代码来对异常进行处理。
try语句
try:
代码块(可能出现错误的语句)
except 异常类型 as 异常名:
代码块(出现错误以后的处理方式)
except 异常类型 as 异常名:
代码块(出现错误以后的处理方式)
except 异常类型 as 异常名:
代码块(出现错误以后的处理方式)
....
else:
代码块(没出错时要执行的语句)
finally:
代码块(是否出错该代码块都会执行)
try是必须的 else有没有都可以
except和finally至少有一个
print('hello')
try:
# print(6/3)
print(6/0)
except:
print('出错了...')
else:
print('正常执行没错')
print('java')
当在函数中出现异常时,如果在函数中对异常进行了处理,则异常不会在进行传播。
如果函数中没有对异常进行处理,则异常会继续向函数调用传播,直到传递到全局作用域(主模块)
如果依然没有处理,则程序终止,并显示异常信息。
当程序运行过程中出现异常以后,所有异常信息会保存到一个异常对象中。而异常传播时,实际上就是异常对象抛给了调用处
# print(6/0)
def fn():
print('hello fn')
print(6/0) # 报错源
#fn() # 出现了两处异常
def fn2():
print('hello fn')
fn() # 传播1
def fn3():
print('hello fn')
fn2() # 传播2
fn3() # 传播3
print(ZeroDivisionError) #
print('异常出现前')
try:
# print(6/3)
print(6/0)
print(abc)
except NameError:
# 如果except后不跟任何内容,会捕获所有的内容
# 如果except后面跟着一个异常雷翔,则只会捕获该类型的异常
print('出现NameError...处理异常的逻辑')
except ZeroDivisionError:
print('ZeroDivisionError出现...处理异常的逻辑')
except Exception as e # Exception保存了出现的所有的异常类型
print('出现异常了',e,type(e))
else:
print('正常执行没错')
finally:
print('无论出现异常,都会执行')
print('异常出现后')
# try 是必须的 else可有可无
# except和finally至少有一个
文件(file)
通过Python程序来对计算机中的各种文件进行增删改查的操作 文件也叫I/O(Input/Output)
• 文件的操作步骤
open()有一个返回值。返回一个对象,这个对象就表示的是当前的文件
# open()
# file 要打开的文件名(路径)
file_name = 'demo.txt'
file_obj = open(file_name)
print(file_obj) #
调用close()方法来关闭文件
with…as 语句不用写close()来关闭。它自带关闭
file_name = 'demo.txt'
file_obj = open(file_name)
# 读取内容
# read()方法来读取文件的内容,把读取的文件以字符串返回
file_content = file_obj.read()
print(file_content)
# 关闭文件
file_obj.close()
# with...as语句
file_name = 'demo.txt'
with open(file_name) as file_obj:
print(file_obj.read()) # 一旦内部程序结束,文件自动关闭
print(file_obj.read()) # 文件已经关闭,故报错
标准的文件打开关闭写法
# with...as语句
file_name = 'demo.txt'
try:
with open(file_name) as file_obj:
print(file_obj.read()) # 一旦内部程序结束,文件自动关闭
except FileNotFoundError
print(f'{file_name}文件不存在')
• 通过read()来读取文件的内容
• 调用open()来打开一个文件,可以将文件分为2类
• open()打开文件时,默认是以文本文件的形式打开的
• open()默认的编码为None。所以处理文本文件时要指定编码
file_name = 'demo2.txt' # demo2.txt中的文件内容存储了中文字符
try:
with open(file_name,encoding = 'utf-8') as file_obj:
content = file_obj.read()
print(content)
except FileNotFoundError
print(f'{file_name}文件不存在')
通过read()读取文件内容时会将文件中所有的内容全部读取出来。如果对于读取的文件比较大的话。会一次性的将文件加载到内容中。容易导致内存泄露。所以对于较大的文件。不要直接调用read()
read()可以接收一个size作为的参数。该参数用来指定要读取字符的数量。默认值为-1.-1也就是要读取全部的内容
每次读取都会从上次读取到的位置开始。如果字符的数量小于size。则会读取所有的。如果读取到最后的文件。则会返回空串
readline() 该方法用来读取一行
readlines() 该方法用于一行一行的读取内容,它会一次性将读取到的内容封装到一个列表当中返回
file_name = 'demo2.txt' # demo2.txt中的文件内容存储了中文字符
try:
with open(file_name,encoding = 'utf-8') as file_obj:
# content = file_obj.read(-1)
content = file_obj.read(6)
content = file_obj.read(6) # 接着读
content = file_obj.read(6) # 接着读
print(content)
except FileNotFoundError
print(f'{file_name}文件不存在')
file_name = 'demo2.txt' # demo2.txt中的文件内容存储了中文字符
try:
with open(file_name,encoding = 'utf-8') as file_obj:
# content = file_obj.read(-1)
# 定义一个变量,指定每次读取的字符数量
chunk = 100
# 创建一个循环读取内容
while True:
content = file_obj.read(chunk)
# 退出循环
if not content:
break
print(content.end='')
print(content)
except FileNotFoundError
print(f'{file_name}文件不存在')
file_name = 'demo2.txt' # demo2.txt中的文件内容存储了中文字符
try:
with open(file_name,encoding = 'utf-8') as file_obj:
print(file_obj.readline(),end='')
print(file_obj.readline(),end='')
print(file_obj.readline())
r = file_obj.readlines()
print(r)
except FileNotFoundError
print(f'{file_name}文件不存在')
• write()来向文件中写入内容
• 使用open()函数打开文件时,必须要指定打开文件要做的操作(读r、写W、追加)。如果不指定操作类型,则默认是读取文件,而读取文件是不能向文件中写入
file_name = 'demo3.txt'
with open(file_name,'w',encoding = 'utf-8') as file_obj:
file_obj.write('课后好好学习\n')
file_obj.write('课后好好学习呀\n')
file_obj.write('课后好好学习啊\n')
file_obj.write(str(123)) # 写入的内容必须是str类型
r = file_obj.write(str(123)+'\n')
print(r) # 4
file_name = 'demo3.txt'
with open(file_name,'a',encoding = 'utf-8') as file_obj:
file_obj.write('课后好好学习\n')
file_name = 'demo3.txt'
with open(file_name,'rb',) as file_obj:
file_obj.write('课后好好学习\n')
file_name = 'demo3.mp3'
with open(file_name,'x',encoding = 'utf-8') as file_obj:
# 将读取的内容写出来
# 定义一个新文件
new_name = 'abc.mp3'
with open(new_name.'wb') as new_obj:
chunk = 1024 * 100
while True:
# 从已有的文件读取内容
content = file_obj.read(chunk)
# 内容读取结束,循环完毕
if not content:
break
new.obj.write(content)