文章目录
一、模块的简介和创建
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有没有都可以
except和finally至少有一个
六、文件操作
先看源码:
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基础课程已经完结,学的不错,哈哈哈
下一阶段的计划:大概率是刷题篇,加油

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





