当检测到一个错误时,Python解释器就无法继续执行了,反而出现了一些错误的提示,这就是所谓的 “异常” ,也就是我们常说的BUG
异常演示:
1、异常处理:对可能出现的bug,进行提前准备、提前处理。
2、当我们的程序遇到了BUG,那么接下来有两种情况:
①整个程序因为一个BUG停止运行
②对BUG进行提醒,整个程序继续运行
3、捕获异常的作用:提前假设某处会出现异常,做好提前准备,当真的出现异常的时候,可以有后续手段
4、捕获常规异常的语法:
try:
可能发生错误的代码
except:
如果出现异常执行的代码
# 正常打开
# f = open("D:/code_Python/linux.txt", "r", encoding="UTF-8") # 文件不存在,会报错
# 捕获常规异常
try:
f = open("D:/code_Python/linux.txt", "r", encoding="UTF-8")
except:
print("出现异常了,因为文件不存在,我将open的模式,改为w模式去打开")
f = open("D:/code_Python/linux.txt", "w", encoding="UTF-8")
5、捕获指定异常的语法:
try:
print(name)
except NameError as e:
print("name变量名称未定义错误")
注意事项:
①如果尝试执行的代码的异常类型和要捕获的异常类型不一致,则无法捕获异常
②一般try下方只放一行尝试执行的代码
# 捕获指定异常
try:
print(name)
# 1 / 0 # 不会捕获
except NameError as e:
print("出现了变量未定义的异常")
print(e)
6、捕获多个异常的语法:
当捕获多个异常时,可以把要捕获的异常类型的名字,放到except后,并使用元组的方式进行书写。
try:
print(1 / 0)
except(NameError, ZeroDivisionError):
print("ZeroDivision错误...")
# 捕获多个异常
try:
print(name)
1 / 0
except (NameError, ZeroDivisionError) as e:
print("出现了变量未定义 或者 除以0的异常错误")
7、捕获所有异常的语法:
# 捕获所有异常
try:
# 1 / 0
# print(name)
f = open("D:/code_Python/python.txt", "r")
except Exception as e:
print("出现异常了")
8、异常else
try:
print(1)
except Exception as e:
print(e)
else:
print("我是else,是没有异常的时候执行的代码")
9、异常的finally
finally表示的是无论是否异常都要执行的代码,例如关闭文件。
try:
f = open("test.txt", "r")
except Exception as e:
f = open("test.txt", "w")
else:
print("没有异常,真开心)
finally:
f.close()
异常是具有传递性的
提示:当所有函数都没有捕获到异常的时候,程序就会报错
# 定义一个出现异常的方法
def func1():
print("func1 开始执行")
num = 1 / 0 # 肯定有异常,除以0的异常
print("func1 结束执行")
# 定义一个无异常的方法,调用上面的方法
def func2():
print("func2 开始执行")
func1()
print("func2 结束执行")
# 定义一个方法,调用上面的方法
def main():
try:
func2()
except Exception as e:
print(f"出现异常了,异常的信息是:{e}")
main()
1、Python 模块(Mudule),是一个 Python 文件,以 .py 结尾,模块能定义函数,类和变量,模块里也能包含可执行的代码。
2、模块的作用:python中有很多各种不同的模块,每一个模块都可以帮助我们快速的实现一些功能,比如实现和时间相关的功能就可以使用time模块。
3、模块在使用前需要先导入 导入的语法如下:
[from 模块名] import [模块 | 类 | 变量 | 函数 | *] [ as 别名]
常用的组合形式如:
· import 模块名
· from 模块名 import 类、变量、方法等
· from 模块名 import *
· import 模块名 as 别名
· from 模块名 import 功能名 as 别名
4、import 模块名
基本语法:
案例:导入time模块
5、from 模块名 import 功能名
基本语法:
案例:导入time模块中的sleep方法
6、from 模块名 import *
基本语法:
案例:导入time模块中所有的方法
7、as定义别名
基本语法:
案例:
1、制作自定义模块
一些个性化的模块,可以通过自定义模块来实现,也就是自己制作一个模块
案例:新建一个Python文件,命名为my_module1.py,并定义test函数
注意:每个Python文件都可以作为一个模块,模块的名字就是文件的名字,也就是说自定义模块名必须符合标识符命名规则。
注意事项:当导入多个模块时,且模块内有同名功能,当调用这个同名功能时,调用到的是后面导入的模块的功能。
2、测试模块
在实际开发中,当一个开发人员编写完一个模板后,为了让模块能够在项目中达到想要的效果,这个开发人员会自行在py文件中添加一些测试信息,例如,在my_module1.py文件中添加测试代码test(1, 1)
问题:
此时,无论是当前文件,还是其他已经导入了该模块的文件,在运行的时候都会自动执行 'test' 函数的调用
解决方案:
if __name__=="__main__" 表示,只有当程序是直接执行的才会进入if内部,如果是被导入的,则if无法进入
3、__all__变量(是一个列表)
如果一个模块文件中有 '__all__' 变量,当使用 'from xxx import *' 导入时,只能导入这个列表中的元素
1、什么是Python包:
从物理上看,包就是一个文件夹,在该文件夹下包含了一个__init__.py 文件,该文件夹可用于包含多个模块文件。
从逻辑上看,包的本质依然是模块。
包的作用:
当我们的模块文件越来越多时,包可以帮助我们管理这些模块,包的作用就是包含多个模块,但包的本质依然是模块。
2、快速入门
步骤如下:
①新建包 'my_package'
②新建包内模块: 'my_module1' 和 'my_module2'
③模块内代码如下
3、导入包
方式一:
方式二:
注意:必须在 '__init__.py' 文件中添加 '__all__ = []' ,控制允许导入的模块列表
包就是包含一堆的Python模块,而每个模块又内含许多的功能。所以,我们可以认为:一个包,就是一堆同类型功能的集合体。
1、在Python程序的生态中,有许多非常多的第三方包(非Python官方),可以极大的帮助我们提高开发效率,如:
· 科学计算中常用的:numpy包
· 数据分析中常用的:pandas包
· 大数据计算中常用的:pyspark、apache-flink包
· 图形可视化常用的:matplotlib、pyecharts
· 人工智能常用的:tensortflow
· 等
这些第三方的包,极大的丰富了Python的生态,提高了开发效率。
但是由于是第三方,所以Python没有内置,所以我们需要安装它们才可以导入使用。
2、安装第三方包 - pip
第三方包的安装非常简单,我们只需要使用Python内置的pip程序即可了。
pip install 包名称
3、pip的网络优化
由于pip是连接的国外的网站进行包的下载,所以有的时候会速度很慢。、
我们可以通过如下命令,让其连接国内的网站进行包的安装:
pip install -i https://pypi.tuna.tsinghua.edu.cn/simple 包名称
https://pypi.tuna.tsinghua.edu.cn/simple 是清华大学提供的一个网站,可供pip程序下载第三方包
4、安装第三方包 - PyCharm
问题解决:
# 字符串相关工具
def str_reverse(s):
return s[::-1]
def substr(s, x, y):
return s[x:y]
if __name__ == '__main__':
print(str_reverse("黑马程序员"))
print(substr("黑马程序员", 2, 5))
# 文件处理相关工具
def print_file_info(file_name):
f = None
try:
f = open(file_name, "r", encoding = "UTF-8")
content = f.read()
print("文件的内容如下:\n")
print(content)
except Exception as e:
print(f"程序出现异常了,原因是:{e}")
finally:
if f: # 如果变量是None,表示False,如果有任何内容,就是True
f.close()
def append_to_file(file_name, data):
f = open(file_name, "a", encoding = "UTF-8")
f.write(data)
f.write("\n")
f.close()
if __name__ == '__main__':
print_file_info("D:/code_Python/bill.txt")
append_to_file("D:\code_Python\bill.txt", "黑马程序员")
import my_utils.str_util
from my_utils import file_util
print(my_utils.str_util.str_reverse("黑马程序员"))
print(my_utils.str_util.substr("itheima", 0, 4))
file_util.append_to_file("D:\code_Python\bill.txt", "itheima")
file_util.print_file_info("D:\code_Python\bill.txt")