python 系列(8) 异常与os模块

Posted on Posted in python

## 异常

### python标准异常

- BaseException 所有异常的基类
- SystemExit 解释器请求退出
- KeyboardInterrupt 用户中断执行(通常是输入^C)
- Exception 常规错误的基类
- StopIteration 迭代器没有更多的值
- GeneratorExit 生成器(generator)发生异常来通知退出
- StandardError 所有的内建标准异常的基类
- ArithmeticError 所有数值计算错误的基类
- FloatingPointError 浮点计算错误
- OverflowError 数值运算超出最大限制
- ZeroDivisionError 除(或取模)零 (所有数据类型)
- AssertionError 断言语句失败
- AttributeError 对象没有这个属性
- EOFError 没有内建输入,到达EOF 标记
- EnvironmentError 操作系统错误的基类
- IOError 输入/输出操作失败
- OSError 操作系统错误
- WindowsError 系统调用失败
- ImportError 导入模块/对象失败
- LookupError 无效数据查询的基类
- IndexError 序列中没有此索引(index)
- KeyError 映射中没有这个键
- MemoryError 内存溢出错误(对于Python 解释器不是致命的)
- NameError 未声明/初始化对象 (没有属性)
- UnboundLocalError 访问未初始化的本地变量
- ReferenceError 弱引用(Weak reference)试图访问已经垃圾回收了的对象
- RuntimeError 一般的运行时错误
- NotImplementedError 尚未实现的方法
- SyntaxError Python 语法错误
- IndentationError 缩进错误
- TabError Tab 和空格混用
- SystemError 一般的解释器系统错误
- TypeError 对类型无效的操作
- ValueError 传入无效的参数
- UnicodeError Unicode 相关的错误
- UnicodeDecodeError Unicode 解码时的错误
- UnicodeEncodeError Unicode 编码时错误
- UnicodeTranslateError Unicode 转换时错误
- Warning 警告的基类
- DeprecationWarning 关于被弃用的特征的警告
- FutureWarning 关于构造将来语义会有改变的警告
- OverflowWarning 旧的关于自动提升为长整型(long)的警告
- PendingDeprecationWarning 关于特性将会被废弃的警告
- RuntimeWarning 可疑的运行时行为(runtime behavior)的警告
- SyntaxWarning 可疑的语法的警告
- UserWarning 用户代码生成的警告

### 异常处理

> 语法

  1. try:  
  2. <语句>        #运行别的代码  
  3. except <名字>:  
  4. <语句>        #如果在try部份引发了'name'异常  
  5. except <名字>,<数据>:  
  6. <语句>        #如果引发了'name'异常,获得附加的数据  
  7. else:  
  8. <语句>        #如果没有异常发生  

> try的工作原理是,当开始一个try语句后,python就在当前程序的上下文中作标记,这样当异常出现时就可以回到这里,try子句先执行,接下来会发生什么依赖于执行时是否出现异常。
- 如果当try后的语句执行时发生异常,python就跳回到try并执行第一个匹配该异常的except子句,异常处理完毕,控制流就通过整个try语句(除非在处理异常时又引发新的异常)。
- 如果在try后的语句里发生了异常,却没有匹配的except子句,异常将被递交到上层的try,或者到程序的最上层(这样将结束程序,并打印缺省的出错信息)。
- 如果在try子句执行时没有发生异常,python将执行else语句后的语句(如果有else的话),然后控制流通过整个try语句。

> eg

  1. #!/usr/bin/python  
  2. # -*- coding: UTF-8 -*-  
  3.   
  4. try:  
  5.     fh = open("testfile", "w")  
  6.     fh.write("这是一个测试文件,用于测试异常!!")  
  7. except IOError:  
  8.     print "Error: 没有找到文件或读取文件失败"  
  9. else:  
  10.     print "内容写入文件成功"  
  11.     fh.close()  

### 使用except而不带任何异常类型

> 捕获所有的异常,不推荐,语法

  1. try:  
  2.     正常的操作  
  3.    ......................  
  4. except:  
  5.     发生异常,执行这块代码  
  6.    ......................  
  7. else:  
  8.     如果没有异常执行这块代码  

### 使用except而带多种异常类型

  1. try:  
  2.     正常的操作  
  3.    ......................  
  4. except(Exception1[, Exception2[,...ExceptionN]]]):  
  5.    发生以上多个异常中的一个,执行这块代码  
  6.    ......................  
  7. else:  
  8.     如果没有异常执行这块代码  

### try-finally 语句

> 语句无论是否发生异常都将执行最后的代码,语法

> eg1

  1. try:  
  2. <语句>  
  3. finally:  
  4. <语句>    #退出try时总会执行  
  5. raise  

> eg2

  1. try:  
  2.     fh = open("testfile", "w")  
  3.     try:  
  4.         fh.write("这是一个测试文件,用于测试异常!!")  
  5.     finally:  
  6.         print "关闭文件"  
  7.         fh.close()  
  8. except IOError:  
  9.     print "Error: 没有找到文件或读取文件失败"  

### 异常的参数

> 语法

  1. try:  
  2.     正常的操作  
  3.    ......................  
  4. except ExceptionType, Argument:  
  5.     你可以在这输出 Argument 的值...  

> eg

  1. # 定义函数  
  2. def temp_convert(var):  
  3.     try:  
  4.         return int(var)  
  5.     except ValueError, Argument:  
  6.         print "参数没有包含数字\n", Argument  
  7.   
  8. # 调用函数  
  9. temp_convert("xyz");  

### 触发异常

> 使用raise语句自己触发异常,语法

  1. raise [Exception [, args [, traceback]]]  

语句中Exception是异常的类型(例如,NameError)参数是一个异常参数值。该参数是可选的,如果不提供,异常的参数是"None"。
最后一个参数是可选的(在实践中很少使用),如果存在,是跟踪异常对象。

> eg

  1. # 定义函数  
  2. def mye( level ):  
  3.     if level < 1:  
  4.         raise Exception("Invalid level!", level)  
  5.         # 触发异常后,后面的代码就不会再执行  
  6.   
  7. try:  
  8.     mye(0)                // 触发异常  
  9. except "Invalid level!": # 为了能够捕获异常,"except"语句必须有用相同的异常来抛出类对象或者字符串。  
  10.     print 1  
  11. else:  
  12.     print 2  

### 用户自定义异常

通过创建一个新的异常类,程序可以命名它们自己的异常。异常应该是典型的继承自Exception类,通过直接或间接的方式。
以下为与RuntimeError相关的实例,实例中创建了一个类,基类为RuntimeError,用于在异常触发时输出更多的信息。
在try语句块中,用户自定义的异常后执行except块语句,变量 e 是用于创建Networkerror类的实例。

  1. class Networkerror(RuntimeError):  
  2.     def __init__(self, arg):  
  3.         self.args = arg  

在你定义以上类后,你可以触发该异常,如下所示:

  1. try:  
  2.     raise Networkerror("Bad hostname")  
  3. except Networkerror,e:  
  4.     print e.args  

## os 模块

  1. #!/usr/bin/env python  
  2. import os  
  3. print os.sep # 输出"/",可以取代操作系统特定的路径分隔符  
  4. print os.name # 输出"posix",操作系统平台,windows输出"nt"  
  5. print os.getenv('PATH') # 输出现在系统的环境变量  
  6. os.putenv('PATH',"/usr") # 设置环境变量 ??????????  
  7.   
  8. print os.listdir("/") # 返回指定目录下的所有名字  
  9.   
  10. os.remove("./1.file") # 删除文件  
  11. os.rmdir("./1") # 删除目录  
  12. os.mkdir("./2") # 创建目录  
  13. os.makedirs("./1/2/3") # 创建多层目录  
  14.   
  15. print os.getcwd() # 输出当前的路径,不是脚本所在路径,是工作路径  
  16. os.chdir("/usr/local") # 更改当前工作路径  
  17. os.walk("/home")  
  18. for i in os.walk("/home"): # 遍历目录  
  19.     print i  
  20.   
  21. print os.path.splitext("./2.file") # 分离文件的名字,扩展名,('./2', '.file')  
  22. print os.path.split("./2.file") # ('.', '2.file')  
  23. print os.path.isfile("./2.file") # 判断是否为文件  
  24. print os.path.lexists("/home") # 检测路径是否存在  
  25.   
  26. print os.path.getsize("./2.file") # 返回文件大小   
  27. print os.path.abspath('./2.file') # 获取文件的绝对路径  
  28. print os.path.join('/home','2.file') # 连接目录名与文件名  
» 转载请注明来源:呢喃 » python 系列(8) 异常与os模块

Leave a Reply

Your email address will not be published. Required fields are marked *

7 + one =