python学习第5天--异常处理、模块与包

异常处理

什么是异常

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

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

异常处理机制

异常处理机制参考文档.

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')

抛出异常

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之间")

自定义异常

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

Python 异常使用规范

  • 不要过度使用异常
  • 不要使用过于庞大的 try 块
  • 不要忽略捕获到的异常
# 自定义的异常
class AgeError(ValueError):
    pass


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

模块与包




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. python模块实质上是一个python文件。
# 2. 注意: 自定义的python文件的文件名一定不要和已有的模块冲突。
# 3. 导入模块实质上是加载并执行模块的内容。
# 4. 导入模块的几种方式:
"""
import  hello
print(hello.digits)
hello.login()

from hello import login
login()

from hello import  login as l
l()
"""

from hello import  *
print(digits)
# 5. 模块的其他信息
import  sys
print(sys.path)  # 模块的查询路径

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

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

import  hello

digits = '0123456789'

def login():
    print('login.......')

print(__name__)  # 当在模块内部执行__name__的值为__main__.

包将有联系的模块组织在一起,有效避免模块名称冲突问题,让应用组织结构更加清晰



init.py

from . import  ali
from . import  huawei

ali.py

def create_ecs():
    print('创建阿里云')

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

huawei.py

def create_ecs():
    print('创建华为云')

def delete_ecs():
    print("删除华为云")
# 1. 包实质上是包含__init__.py文件的目录。
# 2. 导入包实质是在做什么? 执行包里面的__init__.py的内容。
# 3. 导入包的方式:
"""
方法1:
from sdk import  ali
from sdk import  huawei

ali.create_ecs()
huawei.create_ecs()

方法2: 相对麻烦一些, 需要在包的__init__.py添加导入信息。
import  sdk
sdk.ali.create_ecs()
sdk.huawei.create_ecs()
"""

模块的分类

"""
模块的分类:
- 内置模块:time,datetime,random, string
- 第三方模块: requests, pandas, colorama, faker
- 自定义模块: 自己编写的python文件(模块)或者包

Windows配置全局pip镜像源: https://blog.csdn.net/u011627161/article/details/92766340
如何安装模块?>pip install colorama -i https://pypi.douban.com/simple
"""

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

"""
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分钟之前的时间信息
"""


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

"""

"""
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: 主机创建成功')

print('---------------')
# 生成测试信息的模块
from faker import  Faker
fake = Faker('zh-cn')
print(fake.name())
print(fake.address())
print(fake.email())

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值