Python Day7(相关补充)

一、其他相关

1.isinstance(obj, cls)

检查是否obj是否是类 cls 的对象

1 class Foo(object):
2     pass
3
4 obj = Foo()
5
6 print(isinstance(obj, Foo))
7 # True

2.issubclass(sub, super)

检查sub类是否是super类的子类

1 class Foo(object):
2     pass
3
4 class Bar(Foo):
5     pass
6
7 print(issubclass(Bar, Foo))
8 # True

二、异常处理

1.异常基础

在程序运行过程中,如果不想因为某个异常造成程序退出,则可以使用异常处理来抓取某类异常,从而让程序不会中断。

 1 while True:
 2     num1 = input(‘num1:‘)
 3     num2 = input(‘num2:‘)
 4     try:
 5         num1 = int(num1)
 6         num2 = int(num2)
 7         result = num1 + num2
 8     except ValueError as e:
 9         print(‘出现异常,信息如下:‘)
10         print(e)

上述代码即抓住了一个ValueError的异常。

2.抓取多个异常

怎么抓取多个异常呢?如果一个代码块可能会有多种异常情况出现,则可以这样写:

 1 l = []
 2 while True:
 3     num1 = input(‘num1:‘)
 4     num2 = input(‘num2:‘)
 5     print(l[2])
 6     try:
 7         num1 = int(num1)
 8         num2 = int(num2)
 9         result = num1 + num2
10     except ValueError as e:
11         print(e)
12     except IndexError as e:
13         print(e)

还可以这样写:

 1 l = []
 2 while True:
 3     num1 = input(‘num1:‘)
 4     num2 = input(‘num2:‘)
 5     print(l[2])
 6     try:
 7         num1 = int(num1)
 8         num2 = int(num2)
 9         result = num1 + num2
10     except (ValueError, IndexError) as e:
11         print(e)

注:这样写的问题是,不知道哪句代码出错,它的用处是当这两种错误都出现时,统一采用一种处理办法时使用

3.万能异常

在python的异常中,有一个万能异常:Exception,他可以捕获任意异常,即:

1 l = []
2 while True:
3     try:
4         l[2]
5     except Exception as e:
6         print(e)

注:抓住所有的错误,一般不建议在开头就使用,因为不好调试

 1 l = []
 2 while True:
 3     try:
 4         l[2]
 5     except ValueError as e:
 6         print(e)
 7     except IndexError as e:
 8         print(e)
 9     except Exception as e:
10         print(e)

注:一般万能异常放在最后抓取未知错误

TIP:万能异常并不是一定万能的,比如缩进错误及一些语法异常或者其他某些异常是抓取不到的

4.异常结构

如下所示:

 1 l = []
 2 try:
 3     l[2]
 4 except ValueError as e:
 5     print(e)
 6 except IndexError as e:
 7     print(e)
 8 except Exception as e:
 9     print(e)
10 else:
11     print("balalala")  # 程序一切正常,才会执行此段代码
12 finally:
13     print("balalalallala")  # 不管程序有没有出错,此段代码总会执行

5.自定义异常&主动触发异常

如下所示:

 1 class MyException(Exception):  # 自定义异常,继承异常类Exception
 2     def __init__(self, msg):
 3         self.message = msg
 4
 5     def __str__(self):
 6         return self.message
 7
 8 try:
 9     raise MyException(‘我的异常‘)  # 主动触发异常,关键字raise
10 except MyException as e:
11     print(e)

6.异常种类

python中的异常种类非常多,每个异常专门用于处理某一项异常!!!

常用异常:

 1 AttributeError 试图访问一个对象没有的树形,比如foo.x,但是foo没有属性x
 2 IOError 输入/输出异常;基本上是无法打开文件
 3 ImportError 无法引入模块或包;基本上是路径问题或名称错误
 4 IndentationError 语法错误(的子类) ;代码没有正确对齐
 5 IndexError 下标索引超出序列边界,比如当x只有三个元素,却试图访问x[5]
 6 KeyError 试图访问字典里不存在的键
 7 KeyboardInterrupt Ctrl+C被按下
 8 NameError 使用一个还未被赋予对象的变量
 9 SyntaxError Python代码非法,代码不能编译(个人认为这是语法错误,写错了)
10 TypeError 传入对象类型与要求的不符合
11 UnboundLocalError 试图访问一个还未被设置的局部变量,基本上是由于另有一个同名的全局变量,
12 导致你以为正在访问它
13 ValueError 传入一个调用者不期望的值,即使值的类型是正确的

更多异常:

 1 ArithmeticError
 2 AssertionError
 3 AttributeError
 4 BaseException
 5 BufferError
 6 BytesWarning
 7 DeprecationWarning
 8 EnvironmentError
 9 EOFError
10 Exception
11 FloatingPointError
12 FutureWarning
13 GeneratorExit
14 ImportError
15 ImportWarning
16 IndentationError
17 IndexError
18 IOError
19 KeyboardInterrupt
20 KeyError
21 LookupError
22 MemoryError
23 NameError
24 NotImplementedError
25 OSError
26 OverflowError
27 PendingDeprecationWarning
28 ReferenceError
29 RuntimeError
30 RuntimeWarning
31 StandardError
32 StopIteration
33 SyntaxError
34 SyntaxWarning
35 SystemError
36 SystemExit
37 TabError
38 TypeError
39 UnboundLocalError
40 UnicodeDecodeError
41 UnicodeEncodeError
42 UnicodeError
43 UnicodeTranslateError
44 UnicodeWarning
45 UserWarning
46 ValueError
47 Warning
48 ZeroDivisionError

7.断言

 1 class A(object):
 2
 3   def __init__(self):
 4   self.name = "Breakering"
 5
 6 obj = A()
 7
 8 assert type(obj.name) is str # 断言,只有满足条件程序才会继续往下走
 9
10 print("pass")

用处:如果后面的代码比较重要,且依赖一些条件,断言此时就可以去筛选这些条件看看满不满足,如果满足条件,后面的代码才可继续执行,相当于过安检

三、反射

python中的反射功能是由以下四个内置函数提供:hasattr、getattr、setattr、delattr,改四个函数分别用于对对象内部执行:检查是否含有某成员、获取成员、设置成员、删除成员。

1 hasattr(obj, name_str) 判断一个对象obj里是否有对应字符串name_str 的方法
2 getattr(obj, name_str ) 根据字符串name_str去获取obj对象里的对应的方法的内存地址
3 setattr(x, y, z) is equivalent to "x.y = z"
4 delattr(obj, name_str) 根据字符串name_str去删除obj对象里对应的方法

结论:反射是通过字符串的形式操作对象相关的成员。一切事物都是对象!!!

四、动态导入模块

模块结构:

动态导入模块如下所示:

 1 # python解释器自用
 2 lib = __import__("lib.aa")
 3
 4 print(lib.aa)
 5 # <module ‘lib.aa‘ from ‘D:\\PythonStudy\\day07\\lib\\aa.py‘>
 6
 7 obj = lib.aa.C()
 8 print(obj.name)
 9 # Breakering
10
11 # 官方建议
12 import importlib
13
14 aa = importlib.import_module("lib.aa")
15
16 print(aa.C().name)
17 # Breakering
时间: 2024-08-09 10:39:24

Python Day7(相关补充)的相关文章

python文件相关操作

Python文件相关操作 打开文件 打开文件,采用open方法,会将文件的句柄返回,如下: f = open('test_file.txt','r',encoding='utf-8') 在上面的代码中,open()方法进行打开文件等相关操作,open()方法其中第一个参数是要打开的文件的文件路径,第二个参数是对要打开文件要执行的权限,第三个参数是文件采用字符编码. 而open()方法返回的内容叫做文件句柄.我们可以打印返回的文件句柄来看下: f = open('test_file.txt','r

Linux环境下非root用户安装Python及相关库

以前在使用python的时候,都是使用root用户安装好的全局python,现在,因为root用户安装的Python版本太低,同时自己没有root权限去对全局Python升级,所以要在非root用户下安装自己指定的Python.因此,就重新整理了一份如何在Linux环境下使用非root用户安装python及其相关的库,以备不时之需. 安装python python版本库https://www.python.org/ftp/python/,此处我选择2.7.5版本的,在安装python的时候,使用

python 列表相关内容

python 列表相关内容 1.增加2.修改3.切片4.清空5.删除6.杂项 #定义两个列表name2 = [1,2,3,4]name_list = ['zhang','wang','li','liu','yang' ,['ding','guo'],'zhao'] 1.列表的追加操作:name_list.append(name2)print(name_list)输出结果:['zhang', 'wang', 'li', 'liu', 'yang', ['ding', 'guo'], 'zhao',

Python安装相关

Python安装相关 第一步:下载Python安装包 在Python的官网 www.python.org 中找到最新版本的Python安装包,点击进行下载,请注意,当你的电脑是32位的机器,请选择32位的安装包,如果是64位的,请选择64位的安装包: 第二步:安装 A.双击下载好的安装包,弹出如下界面: 这里要注意的是,将python加入到windows的环境变量中,如果忘记打勾,则需要手工加到环境变量中:在这里我选择的是自定义安装,点击"自定义安装"进行下一步操作: B.进入到下一步

Python - celery 相关报错 - AttributeError: type object &#39;_multiprocessing.win32&#39; has no attribute &#39;WAIT_OBJECT_0&#39;

报错场景 执行   celery worker -A tasks -l INFO  打开 worker 的时候报错无法进行 报错解决 Celery 的版本过高, 进行降级处理即可 pip install celery==3.1.25 降级后再次执行会触发 另一报错 此报错原因是 redis 的版本过高导致 对 redis 进行降级即可  pip install redis==2.10.6 Python - celery 相关报错 - AttributeError: type object '_m

python之路_django ORM相关补充

一.非django项目文件执行ORM 在不启动django项目的情况下,我们是否可以进行ORM操作呢?当然不行.因为所有的ORM操作都必须是要连接数据库的.但是我们有这样的一个需求:想在一个文件中执行ORM.该如何实现呢?参考如下实例: import os import sys import django sys.path.append(r'C:\Users\Administrator\PycharmProjects\s6day109') #将当前djang项目路径添加到环境 os.chdir(

python基础数据类型补充以及编码的进阶

一. 基础数据类型补充内容 1.1 字符串 字符串咱们之前已经讲了一些非常重要的方法,剩下还有一些方法虽然不是那么重要,但是也算是比较常用,在此给大家在补充一些,需要大家尽量记住. #captalize :首字母大写 #swapcase :大小写翻转 #title :每个单词的首字母大写 #center :内同居中,总长度,空白处填充 #寻找字符串中的元素是否存在 #find :返回的找到的元素的索引,如果找不到返回-1 #index :返回的找到的元素的索引,找不到报错. #captalize

Python 正则表达式相关问题

这几天学习python,写正则表达式相关代码如下: import re print(re.search(r'(?<=<(\w+)>).*(?=<\/\1>)',"<b>ewuiiriur</b>sdksfkj").span()) 报错如下: raise error("look-behind requires fixed-width pattern")sre_constants.error: look-behind

python day7

面向对象初级篇面向对象进阶篇一.isinstance(obj, cls) 检查是否obj是否是类 cls 的对象 1 2 3 4 5 6 class Foo(object): pass obj = Foo() isinstance(obj, Foo) 二.issubclass(sub, super) 检查sub类是否是 super 类的派生类 1 2 3 4 5 6 7 class Foo(object): pass class Bar(Foo): pass issubclass(Bar, Fo