Python入门之路(15)

Python 入门之路(15)

异常

异常的简介

程序在运行过程中可能会出现一些错误。比如: 使用了不存在的索引,两个不同类型的数据相加…这些错误我们称之为异常。

处理异常 程序运行时出现异常,目的并不是让我们的程序直接终止!Python是希望在出现异常时,我们可以编写代码来对异常进行处理。

try语句

try语句
    try:
        代码块(可能出现错误的语句)
    except 异常类型 as 异常名:
        代码块(出现错误以后的处理方式)
    except 异常类型 as 异常名:
        代码块(出现错误以后的处理方式)
    except 异常类型 as 异常名:
        代码块(出现错误以后的处理方式)
    ....
    else:
        代码块(没出错时要执行的语句)
        
    finally:
        代码块(是否出错该代码块都会执行)
     try是必须的 else有没有都可以
     exceptfinally至少有一个
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)

• 文件的操作步骤

  1. 打开文件
  2. 对文件进行各种操作(读、写)然后保存
  3. 关闭文件

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类

  1. 一种 纯文本文件(使用utf-8编码编写的文件)
  2. 一种 二进制文件(图片 mp3 视频…)

• 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()来向文件中写入内容

  1. 该方法可以分多次向文件写入内容
  2. 写入完成之后该方法会返回写入的字符的个数

• 使用open()函数打开文件时,必须要指定打开文件要做的操作(读r、写W、追加)。如果不指定操作类型,则默认是读取文件,而读取文件是不能向文件中写入

  1. r 表示只读
  2. w表示可以写。使用w写入文件时,如果文件不存在则会创建一个文件。如果文件存在则会覆盖原文件内容
  3. a表示追加内容
  4. x用来新建文件,如果不存在则创建,如存在则报错
  5. b二进制文件 rb读取二进制文件 wb写入二进制文件
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') 

二进制文件的操作(图片 mp3 视频)

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)

你可能感兴趣的:(Python基础,python)