2021/4/7第十五次python结束课(模块、异常、文件)

本文详细介绍了Python中的模块化编程,包括模块的创建与使用,以及如何通过`import`进行模块导入。同时,文章深入探讨了异常处理,解释了异常的传播机制,并展示了如何通过`try-except`语句捕获和处理异常。在文件操作部分,讲解了文件的打开、关闭、读取和写入方法,特别强调了大文件读取的注意事项。此外,还讨论了二进制文件的读写操作。通过对这些基础知识的掌握,能有效提升Python编程能力。

一、模块的简介和创建

1.1模块

• 模块化指将一个完整的程序分解成一个个的小模块
• 通过将模块组合,来搭建出一个完整的程序
• 模块化的有点
• 方便开发
• 方便维护
• 模块可以复用


模块即py文件(实现跨文件传输)


1.2模块的创建

在Python当中一个py文件就是一个模块
在一个模块中引入外部模块 import 模块名(模块名就是py文件)
可以引入同一个模块多次,但是模块的实例只会创建一次
import 模块名 as 模块别名
在一个模块内部都有一个__name__。通过它我们可以获取模块的名字
如果py文件直接运行时,那么__name__默认等于字符串’main’。__name__属性值为__main__的模块是主模块。一个程序中只有一个主模块

二、模块的使用

访问模块中的变量 语法是 模块名.变量名
访问模块中的函数 语法是 模块名.函数名
访问模块中的对象 语法是 模块名.对象名
我们也可以引入模块中部分内容 语法 from 模块名 import 变量,变量…
还有一种引入方式 语法 from 模块名 import 变量 as 别名

总结:


import test1
import test1 as test
from test1 import fun/*(包含所有,变量、函数、类)#可以直接使用变量等

补充:
if name == ‘main’:

main函数程序的入口:函数不是在当前模块运行的程序,那么这个程序就不会运行

impt random
import time
import os
import sys

三、异常的简介

  • 程序在运行过程中可能会出现一些错误。比如: 使用了不存在的索引,两个不同类型的数据相加…这些错误我们称之为异常
  • 处理异常 程序运行时出现异常,目的并不是让我们的程序直接终止!Python是希望在出现异常时,我们可以编写代码来对异常进行处理
# 这是对异常进行一个捕获处理, 是程序不会报错而停止运行
try:
    # pass
    print(a)  # NameError(类名)
    print(1/0)  # ZeroDivisionError   注:因上一行a已经出错,这一行就不执行了
except Exception as e:    #Exception自动指向错误的类名
    print('出错了', e, type(e))
# except ZeroDivisionError:
#     print('除零错误')
else:
    print('这也没错啊')
finally:
    print('不管是否有异常,都会执行')

结果

出错了 name 'a' is not defined <class 'NameError'>
不管是否有异常,都会执行

四、异常的传播

  • 当在函数中出现异常时,如果在函数中对异常进行了处理,则异常不会在进行传播。如果函数中没有对异常进行处理,则异常会继续向函数调用传播。如果函数调用处处理了异常,则不再传播异常,如果没有处理则继续向调用处传播。直到传递到全局作用域(主模块)如果依然没有处理,则程序终止,并显示异常信息。
  • 当程序运行过程中出现异常以后,所有异常信息会保存到一个异常对象中。而异常传播时,实际上就是异常对象抛给了调用处
    处理函数中的异常(在函数中或调用处都可以进行异常处理)

五、异常对象

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

六、文件操作

先看源码:

def open(file, mode='r', buffering=None, encoding=None, errors=None, newline=None, closefd=True):

file是路径
encoding与文件的内容有关(如里面有汉字就要用utf-8)
mode与文件类型有关

6.1文件打开

• 文件(file) 通过Python程序来对计算机中的各种文件进行增删改查的操作 文件也叫I/O(Input/Output)
• 文件的操作步骤

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

文件会有一个返回值。返回一个对象,这个对象就表示的是当前的文件

6.2文件关闭

调用close()方法来关闭文件
with…as 语句不用写close()来关闭。它自带关闭

6.3文件读取

6.3.1读取文件

• 通过read()来读取文件的内容
• 调用open()来打开一个文件,可以将文件分为2种类型
• 一种 纯文本文件(使用utf-8编码编写的文件)
• 一种 二进制文件(图片 mp3 视频…)
• open()打开文件时,默认是以文本文件的形式打开的 open()默认的编码为None。所以处理文本文件时要指定编码


content = f.read(4)#给size传递参数,一次读取多少个字节
content = f.readline#一行一行的读取(手动)
content = f.readlines()#也是一行一行的读取,不过会读取完所有,并且存放到列表中(自动)


6.3.2较大文件的读取

通过read()读取文件内容时会将文件中所有的内容全部读取出来。如果对于读取的文件比较大的话。会一次性的将文件加载到内容中。容易导致内存泄露。所以对于较大的文件。不要直接调用read()
read()可以接收一个size作为的参数。该参数用来指定要读取字符的数量。默认值为-1.-1也就是要读取全部的内容
每次读取都会从上次读取到的位置开始。如果字符的数量小于size。则会读取所有的。如果读取到最后的文件。则会返回空串
readline() 该方法用来读取一行
readlines() 该方法用于一行一行的读取内容,它会一次性将读取到的内容封装到一个列表当中返回

6.4文件写入

• write()来向文件中写入内容
• 该方法可以分多次向文件写入内容
• 写入完成之后该方法会返回写入的字符的个数
• 使用open()函数打开文件时,必须要指定打开文件要做的操作(读、写、追加)。如果不指定操作类型,则默认是读取文件,而读取文件是不能向文件中写入
• r 表示只读
• w表示可以写。使用w写入文件时,如果文件不存在则会创建一个文件。如果文件存在则会覆盖原文件内容

6.5二进制文件的读写操作

  • 读取文本文件时,size是以字符为单位。读取二进制文件时,size是以字节为单位
  • 我们用wb来写入二进制文件
    补充:
    有关对象的销毁问题:
    函数(函数调用结束,函数里的局部变量就被销毁)
    结束运行(程序结束运行)
    文件打开与关闭(文件关闭,open函数创建的对象就被销毁)
    注:write()与read()都会记录位置

这期python基础课程已经完结,学的不错,哈哈哈
下一阶段的计划:大概率是刷题篇,加油

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

笔记本IT

您的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值