一文搞懂python异常处理、模块与包


Posted in Python onJune 26, 2021

一 异常处理

1.什么是异常

Error(错误)是系统中的错误,程序员是不能改变的和处理的,如系统崩溃,内存空间不足,方法调用栈溢等。遇到这样的错误,建议让程序终止。
Exception(异常)表示程序可以处理的异常,可以捕获且可能恢复。遇到这类异常,应该尽可能处理异常,使程序恢复运行,而不应该随意终止异常。

2常见异常

IndentationError: 缩进错误
KeyboardInterrupt:  Ctrl+C被按下
UnboundLocalError : 有同名的全局变量
d = {'name':'westos'}
print(d['age'])   # KeyError
 
with open('hello.txt') as f:   # FileNotFoundError
    pass
AttributeError 、IOError 、ImportError 、IndexError、
SyntaxError、TypeError、ValueError、KeyError、NameError

3 异常处理机制

一文搞懂python异常处理、模块与包

 Python 的异常机制主要依赖 try 、except 、else、finally 和 raise 五个关键字。

    try 关键字后缩进的代码块简称 try 块,它里面放置的是可能引发异常的代码;
    except 关键字对应异常类型和处理该异常的代码块;
    多个 except 块之后可以放一个 else 块,表明程序不出现异常时还要执行 else 块;
    finally 块用于回收在 try 块里打开的物理资源,异常机制会保证 finally 块总被执行;
    raise 用于引发一个实际的异常,raise 可以单独作为语句使用,引发一个具体的异常对象

除了处理实际的错误条件之外,对于异常还有许多其它的用处。在标准 Python 库中一个普通的用法就是试着导入一个模块,然后检查是否它能使用。导入一个并不存在的模块将引发一个 ImportError 异常。
 

#异常处理机制:
  #  else:没有异常时,执行的内容
    #finally: 总会执行的内容
 
 
try:
    a = 1
    print(b)
except NameError as e:
    print('0-name error')
except KeyError:
    print('4-key error')
except Exception as e:
    print('1-exception')
else:
    print('2-no error')
finally:
    print('3-run code')

4 触发异常

Python 允许程序自行引发异常,自行引发异常使用 raise 语句来完成。
raise语句中 Exception 是异常的类型(例如,NameError)参数标准异常中任一种,
args 是自已提供的异常参数。
raise [Exception [, args [, traceback]]]
 

age = int(input('age:'))
if 0<age<150:
    print(age)
else:
    # 抛出异常
    raise ValueError("年龄必须在0~150之间")

5 自定义异常

用户自定义异常都应该继承 Exception 基类或 Exception 的子类,在自定义异常类时基本不需要书写更多的代码,只要指定自定义异常类的父类即可。

# 自定义的异常
class AgeError(ValueError):
    pass

age = int(input('age:'))
if 0<age<150:
    print(age)
else:
    # 抛出异常
    raise AgeError("年龄必须在0~150之间")
    ```

二 模块与包

1.模块

一文搞懂python异常处理、模块与包

一文搞懂python异常处理、模块与包

 一文搞懂python异常处理、模块与包

 1.1在pycharm中建立一个python文件hello.py

"""
hello模块的说明文档
"""
digits = '0123456789'
 
def login():
    print('login.......')
 
# __all__当用户使用from module import *时,需要导入的内容。
__all__ = ['digits']
 
# 当模块内部执行时,需要执行的代码。 当模块被导入,则不执行。
if __name__ == '__main__':
    print(__name__)
    # 当在模块内部执行__name__的值为__main__.
    # 当模块被导入时,__name__的值为hello(模块名)

1.2. 注意: 自定义的python文件的文件名一定不要和已有的模块冲突。

1.3. 导入模块实质上是加载并执行模块的内容。

1.4. 导入模块的几种方式:

import  hello
print(hello.digits)
hello.login()

1.5. 模块的其他信息

import sys
print(sys.path) # 模块的查询路径

import hello
print(dir(hello)) # 查看hello模块可以使用的变量和函数…

print(hello.__doc__)# 查看模块的说明文档
print(hello.__file__) # 显示模块的绝对路径
print(hello.__name__) # __name__当模块被导入时,显示的是模块的名称
 

name的特殊用法

import  hello
"""
digits = '0123456789'
def login():
    print('login.......')
print(__name__)  # 当在模块内部执行__name__的值为__main__.
"""

2.包

包将有联系的模块组织在一起,有效避免模块名称冲突问题,让应用组织结构更加清晰。
一个普通的python应用程序目录结构:

2.1. 包实质上是包含__init__.py文件的目录。

2.2. 导入包实质是在做什么? 执行包里面的__init__.py的内容。

2.3. 导入包的方式:

sdk目录下包含的文件:

1.huawei.py
内容:
def create_ecs(): print('创建华为云') def delete_ecs(): print("删除华为云")

2.aili.py
 def create_ecs():
  print('创建阿里云')

def delete_ecs():
  print("删除阿里云")

3._init_.py
from . import  ali
from . import  huawei

from sdk import  ali
from sdk import  huawei
 
ali.create_ecs()
huawei.create_ecs()
 
import  sdk
sdk.ali.create_ecs()
sdk.huawei.create_ecs()

2.4.模块的分类

time模块

import  time
print(time.time())  # 计算时间戳
print(time.ctime()) # 字符串的时间, Sun Feb  7 17:09:55 2021
tuple_time = time.localtime()  # 元组类型的时间
print(tuple_time.tm_year)

datetime

from datetime import date, datetime, timedelta
print(date.today())  # 获取今天的日期
print(datetime.now())  # 获取当前时间2021-02-07 17:13:17.170345
print(date.today() + timedelta(days=3))  # 获取3天后的日期
print(date.today() - timedelta(days=3))  # 获取3天前的日期
print(datetime.now() + timedelta(minutes=10))  # 获取10分钟之后的时间信息
print(datetime.now() - timedelta(minutes=10))  # 获取10分钟之前的时间信息

 random

import  random
print(random.random())  # 生成0-1之间的小数
print(random.randint(1, 10)) # 生成1-10之间的整数
print(random.choice(['li', 'happy', 'fi'])) # 随机选择一个元素
print(random.sample(['ll', 'ff', 'oo'], 2)) # 随机选择n(n=2)个元素
print(random.choices(['ll', 'ff', 'oo'], weights=[100, 10, 10]))  # 随机选择一个元素,可以指定权重

string

import  string
print(string.digits)  # 获取所有的数字
print(string.ascii_letters)
print(string.ascii_lowercase)
print(string.ascii_uppercase)

颜色模块

from colorama import Fore
print(Fore.RED + 'Error: 主机不存在')
print(Fore.GREEN + 'Success: 主机创建成功')

生成测试信息的模块

from faker import  Faker
fake = Faker('zh-cn')
print(fake.name())
print(fake.address())
print(fake.email())

2.5.模块的安装

pip install ** 但在安装的时候较慢,尽量选择合适的源安装
pip install colorama -i https://pypi.douban.com/simple

以上就是python异常处理、模块与包的详细内容,更多关于python异常处理、模块与包的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
python练习程序批量修改文件名
Jan 16 Python
Python实现检测服务器是否可以ping通的2种方法
Jan 01 Python
Python实现单词拼写检查
Apr 25 Python
python用reduce和map把字符串转为数字的方法
Dec 19 Python
python数据类型判断type与isinstance的区别实例解析
Oct 31 Python
python编写Logistic逻辑回归
Dec 30 Python
python中ImageTk.PhotoImage()不显示图片却不报错问题解决
Dec 06 Python
Python TestCase中的断言方法介绍
May 02 Python
python3的url编码和解码,自定义gbk、utf-8的例子
Aug 22 Python
python找出列表中大于某个阈值的数据段示例
Nov 24 Python
python实现批量转换图片为黑白
Jun 16 Python
5道关于python基础 while循环练习题
Nov 27 Python
Python实战之OpenCV实现猫脸检测
Python爬虫基础之简单说一下scrapy的框架结构
Python爬虫基础之初次使用scrapy爬虫实例
Python上下文管理器Content Manager
Jun 26 #Python
仅用几行Python代码就能复制她的U盘文件?
总结几个非常实用的Python库
Jun 26 #Python
手残删除python之后的补救方法
You might like
js为鼠标添加右击事件防止默认的右击菜单弹出
2013/07/29 Javascript
js中运算符&amp;&amp; 和 || 的使用记录
2014/08/21 Javascript
JavaScript变量声明详解
2014/11/27 Javascript
javascript实现简单的二级联动
2015/03/19 Javascript
Jquery使用小技巧汇总
2015/12/29 Javascript
js实现文字垂直滚动和鼠标悬停效果
2015/12/31 Javascript
Adapter适配器模式在JavaScript设计模式编程中的运用分析
2016/05/18 Javascript
JS使用cookie设置样式的方法
2016/06/30 Javascript
javascript和jQuery实现网页实时聊天的ajax长轮询
2016/07/20 Javascript
原生js实现网易轮播图效果
2020/04/10 Javascript
详解Angular.js数据绑定时自动转义html标签及内容
2017/03/30 Javascript
Angular学习笔记之集成三方UI框架、控件的示例
2018/03/23 Javascript
js中的this的指向问题详解
2019/08/29 Javascript
通过实例了解JS 连续赋值
2019/09/24 Javascript
React+EggJs实现断点续传的示例代码
2020/07/07 Javascript
如何在 ant 的table中实现图片的渲染操作
2020/10/28 Javascript
Python3写入文件常用方法实例分析
2015/05/22 Python
python与C互相调用的方法详解
2017/07/14 Python
python 批量修改/替换数据的实例
2018/07/25 Python
python爬虫超时的处理的实例
2018/12/19 Python
python实现静态web服务器
2019/09/03 Python
用python3读取python2的pickle数据方式
2019/12/25 Python
python matplotlib中的subplot函数使用详解
2020/01/19 Python
Python日志:自定义输出字段 json格式输出方式
2020/04/27 Python
django form和field具体方法和属性说明
2020/07/09 Python
python 怎样进行内存管理
2020/11/10 Python
详解Html5 Canvas画线有毛边解决方法
2018/03/01 HTML / CSS
华为俄罗斯官方网上商城:购买Huawei手机和平板
2017/04/21 全球购物
巴西化妆品商店:Lojas Rede
2019/07/26 全球购物
澳大利亚有机化妆品网上商店:The Well Store
2020/02/20 全球购物
深入开展党的群众路线教育实践活动方案
2014/02/04 职场文书
2014年寒假社会实践活动心得体会
2014/04/07 职场文书
夫妻婚内购房协议书
2014/10/05 职场文书
交警作风整顿剖析材料
2014/10/11 职场文书
质监局领导班子践行群众路线整改方案
2014/10/26 职场文书
2015高考寄语集锦
2015/02/27 职场文书