Dsh015 python基础编程--异常&文件

1、异常简介

  • 程序在运⾏过程中可能会出现⼀些错误。⽐如: 使用了没有赋值的变量,使⽤了不存在的索引,两个不 同类型的数据相加…这些错误我们称之为异常。
  • 程序运行过程中,一旦出现异常,将会导致程序立即终止,异常以后的代码不会执行了
  • 处理异常 程序运⾏时出现异常,⽬的并不是让我们的程序直接终⽌!Python 是希望在出现异常时,我们可以编写代码来对异常进⾏处理

‘’’
try语句
try:
代码块(可能出现错误的语句)
except 异常类型 as 异常名:
代码块(出现错误在之后的处理方式)
except 异常类型 as 异常名:
代码块(出现错误在之后的处理方式)

else:
代码块(没出错误要执行的语句)
finally:
代码块(该代码总会被执行)
try 是必须的 , else有没有都行
except和finally 至少有一个

‘’’

print('你好')
try:
    print(10/0)
except:
    print('兄弟,出错了!!')
else:
    print('程序正常执行,没有错误')
print('hello')
# 输出结果为:
你好
兄弟,出错了!!
hello
print('你好')
try:
    print(10/5)
except:
    print('兄弟,出错了!!')
else:
    print('程序正常执行,没有错误')
print('hello')
# 输出结果为:
你好
2.0
程序正常执行,没有错误
hello

2、异常的传播

  • 当在函数中出现异常时,如果在函数中对异常进⾏了处理,则异常不会在进⾏传播。如果函数中没有对异常进⾏处理,则异常会继续向函数调⽤传播。 如果函数调⽤处处理了异常,则不再传播异常,如果没有处理则继续向调⽤处传播。直到传递到全局作⽤域(主模块)如果依然没有处理,则程序终⽌,并显示异常信息。
  • 当程序运⾏过程中出现异常以后,所有异常信息会保存到⼀个异常对象中。 ⽽异常传播时,实际上就是异常对象抛给了调⽤处
def fn():
    print(10/0)
    print('fn')   
fn()  
 # 报错:
 Traceback (most recent call last):
  File "C:/demo/12 异常.py", line 40, in <module>
    fn()
  File "C:/demo/12 异常.py", line 38, in fn
    print(10/0)
ZeroDivisionError: division by zero

3、异常对象

  • except后面不跟任何的内容,它会捕获所有的异常
  • except后面跟着一个异常的类型,那么此时它就会捕获该类型的异常,比如NameError
  • except只执行捕获第一个发生的error
print('异常出现前')
try:
    print(a)
    print(10 / 0)
    
except NameError:
    print('出现NameError异常啦')
except ZeroDivisionError:
    print('出现ZeroDivisionError异常啦')
# 运行结果:
异常出现前
出现NameError异常啦
print('异常出现前')
try:

    print(10 / 0)
    print(a)
except NameError:
    print('出现NameError异常啦')
except ZeroDivisionError:
    print('出现ZeroDivisionError异常啦')
# 运行结果:
异常出现前
出现ZeroDivisionError异常啦
  • Exception是所有异常类的父类,如果except后面跟的是Exception它会捕获所有的异常
print('异常出现前')
try:

    print(10 / 0)
    print(a)
except Exception as e:
    print('出现异常时',e,type(e))
finally:
    print('不管异常,照常执行')
# 运行结果:
异常出现前
出现异常时 division by zero <class 'ZeroDivisionError'>
不管异常,照常执行

4、文件打开

  • ⽂件(file) 通过Python程序来对计算机中的各种⽂件进⾏增删改查的操作,也叫I/O(Input/Output)
  • ⽂件的操作步骤
    • 打开⽂件
    • 对⽂件进⾏各种操作(读、写)然后保存
    • 关闭⽂件
  • ⽂件会有⼀个返回值。返回⼀个对象,这个对象就表示的是当前的⽂件

open(file, mode=‘r’, buffering=None, encoding=None, errors=None, newline=None, closefd=True)
open()函数是有一个返回值,表示当前的文件对象
如果目标文件和当前文件是在同一目录下,则直接使用文件名即可

file_name = 'demo.txt'  # 目标文件和当前文件在同一目录
# file_name = r'E:\Project\base\day15\demo.txt' 目标文件和当前文件不在同一目录
file_obj = open(file_name)  # 打开对应的文件
print(file_obj)

5、关闭文件

  • 调⽤close()⽅法来关闭⽂件
file_name = 'demo.txt'
file_obj = open(file_name)
content = file_obj.read()
file_obj.close()
  • with…as 语句不⽤写close()来关闭。它⾃带关闭
    • 在with语句中可以直接使用file_obj来对文件进行操作
    • 一旦with语句中的代码块结束会自动close()
with open(file_name) as file_obj:
    print(file_obj.read())
file_name = 'hello.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编码编写的⽂件)
    • ⼀种 ⼆进制⽂件(图⽚、音频、视频…)
    • open()打开⽂件时,默认是以⽂本⽂件的形式打开的 open()默认的编码为None。所以处理⽂本⽂件时要指定编码
file_name = 'demo.txt'
file_obj = open(file_name)
content = file_obj.read()
print(content)
file_name = 'demo2.txt'
try:
    with open(file_name,encoding='utf-8') as file_obj:
    content = file_obj.read(5)
        content = file_obj.read(5)
        content = file_obj.read(5)
        content = file_obj.read(6)
        print(content)
        print(len(content))
except FileNotFoundError:
    print(f'{file_name} 文件不存在')

7、较大文件的读取

  • 通过read()读取⽂件内容时会将⽂件中所有的内容全部读取出来。如果对于读取的⽂件⽐较⼤的话。会⼀次性的将⽂件加载到内容中。容易导致内存泄 露。所以对于较⼤的⽂件。不要直接调⽤read()
  • read()可以接收⼀个size作为的参数。该参数⽤来指定要读取字符的数量。默 认值为-1.-1也就是要读取全部的内容
  • 每次读取都会从上次读取到的位置开始。如果字符的数量⼩于size。则会读 取所有的。如果读取到最后的⽂件。则会返回空串
file_name = 'demo.txt'
try:
    with open(file_name,encoding='utf-8') as file_obj:
        # 定义一个变量,来指定每次读取的大小
        chunk = 100
        # 创建一个循环来读取内容
        while True:
            content = file_obj.read(chunk)

            # 退出循环
            if not content:
                # 内容读取完毕
                break

            print(content)
except FileNotFoundError:
    print(f'{file_name} 文件不存在')
  • readline() 该⽅法⽤来读取⼀⾏
  • readlines() 该⽅法⽤于⼀⾏⼀⾏的读取内容,它会⼀次性将读取到的内容封装到⼀个列表当中返回
file_name = 'demo.txt'
with open(file_name) as file_obj:
    r = file_obj.readlines()
    print(r[0])

8、文件的写入

  • write()来向⽂件中写⼊内容
    • 该⽅法可以分多次向⽂件写⼊内容
    • 写⼊完成之后该⽅法会返回写⼊的字符的个数
  • 使⽤open()函数打开⽂件时,必须要指定打开⽂件要做的操作(读、写、追 加)。如果不指定操作类型,则默认是读取⽂件,⽽读取⽂件是不能向⽂件中 写⼊
    • r 表示只读 ,a 表示的是追加
    • w表示可以写。使⽤w写⼊⽂件时,如果⽂件不存在则会创建⼀个⽂件。 如果⽂件存在则会覆盖原⽂件内容
file_name = 'demo3.txt'
with open(file_name, 'a', encoding='utf-8') as file_obj:
    file_obj.write('大家好\n')
    file_obj.write('abc\n')

9、二进制文件写入

  • 读取⽂本⽂件时,size是以字符为单位。读取⼆进制⽂件时,size是以字节 为单位
  • 我们⽤wb来写⼊⼆进制⽂件,rb读取二进制文件
file_name = r'C:\Users\19214\Desktop\Kalimba.mp3'

with open(file_name,'rb') as file_obj:
    # print(file_obj.read(100))

    # 将读取的内容写出来
    new_name = 'abc.mp3'

    with open(new_name,'wb') as new_obj:
        # 定义读取的大小
        chuck = 1024 * 100

        while True:
            # 读取内容
            count = file_obj.read(chuck)

            # 内容读取完毕退出循环
            if not count:
                break

            # 将读取到的内容写入数据
            new_obj.write(count)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值