python14异常处理

1.错误
有的错误是程序编写有问题造成的,比如本来应该输出整数结果输出了字符
,这种错误我们通常称之为 bug,bug 是必须修复的。
有的错误是用户输入造成的,比如让用户输入 email 地址,结果得到一个空字
符串,这种错误可以通过检查用户输入来做相应的处理。
还有一类错误是完全无法在程序运行过程中预测的,比如写入文件的时候,磁盘
满了,写不进去了,这类错误也称为异常,在程序中通常是必须处理的,否则,程序会因为各种问题终止并退出。
2.
错误处理
在程序运行的过程中,如果发生了错误,可以事先约定返回一个错误代码;
• Python
语言通常都内置了一套 try...except...finally...的错误处理机制错误处理
try:           #
把可能出现异常的代码放在该语句块中
   print 'starting ......'
   li = [1,2,3]
   dic ={"name":'fentiao'}
   print dic
   print dic['age']
   print dic
   print a   #NameError
   print li[3]
except
 BaseException,e:
   print '%s is error' %e
# except
 IndexError,e:          #
捕获指定的异常,如果异常IndexError,则执行下面语句
#    print e
# except NameError as e:
#
    print e
else:
                      #
如果没有任何异常被捕获,则执行该代码块
   print 'no error'

finally:
                   #
不管是否有异常,一定会执行的代码块
   print 'end.........'

-
try来运行可能会出错的代码;
-
如果执行正确,except语句块不会执行;
-
如果执行错误,直接跳转至错误处理代码,except语句块;
-
如果有 finally语句块,不管try语句块内容是否正确,都会执行finally
语句块
错误有很多种类,如果发生了不同类型的错误,应该由不同的 except语句
块处理。因此可以有多个 except来捕获不同类型的错误。
eroDivisionError:', e
print 'ValueError:', e
except ZeroDivisionError, e:
print 'ZeroDivisionError:', e

• Python
的错误其实也是 class,所有的错误类型都继承自BaseException;
在使用except捕获该类型的错误,还把其子类也一网打尽”;
常见的错误类型和继承关系看这里:
https://docs.python.org/2/library/exceptions.html#exception­hierarchy3.
读懂复杂的错误
解读错误信息是定位错误的关键。我们从上往下可以看到整个错误的调用函数
链。
def foo(s):
   return 10 / int(s)
def bar(s):
   return foo(s) * 2
def main():
   bar('0')
main()
4.
记录错误
不捕获错误,Python解释器会打印出错误信息,但程序也被结束;
捕获错误,就可以把错误信息打印出来,然后分析错误原因,同时,让程
序继续执行下去。
• Python
内置的 logging 模块可以记录错误信息。
logging.exception(e)

import logging
logging.basicConfig(filename='err.log')
def func1(s):
   return func2(s)*2

def func2(s):

   return 10/int(s)
def main():
   try:
       print func1('0')
   except ZeroDivisionError as e:
       raise MyError
       # ZeroDivisionError
转换为 MyError
       # logging.exception(e)
main()
5.
抛出错误
错误是 class,捕获一个错误就是捕获到该 class 的一个实例;
• Python
的内置函数会抛出很多类型的错误,我们自己编写的函数也可以抛出错误。
可以定义一个错误的 class,选择好继承关系,然后,raise语句抛出一个错误的实例;
尽量使用 Python内置的错误类型
class FooError(StandardError):
     pass
def foo(s):
     n = int(s)
     if n==0:
        raise FooError('invalid value:%s' % s)
     return 10 / n
6.
调试- print
第一种方法简单直接粗暴有效,就是用 print 把可能有问题的变量打印出来看
看。用 print最大的坏处是将来还得删掉它,运行结果也会包含很多垃圾信息。调试-断言
凡是用 print来辅助查看的地方,都可以用断言(assert)来替代:;
如果断言失败, assert语句本身就会抛出AssertionError
assert n!=0
assert hello() = "hello"
print
打印你认为可能出错的变量
- assert
断言, 格式
       assert
变量名==[不符合预设条件时,输出的内容”]
       assert func(x)==
[,'不符合预设条件时,输出的内容']
• Python
解释器执行时可以用 -O参数来关闭assert,把所有的 assert 语句
当成 pass
调试- logging
• logging
不会抛出错误,而且可以输出到文件;
• logging.info()
就可以输出一段文本到日志文件中。
• logging.basicConfig(level=logging.INFO)
指定记录信息的级别,debug , info , warning , error等几个级别。
import logging
s = '0'
n = int(s)
logging.basicConfig(filename="/home/kiosk/hello.log
",level=logging.INFO)
logging.info('n=%d' %n)
print 10/n
调试- pdb
•pdb
pdb
让程序以单步方式运行,随时查看运行状态。n可以单步执行代码,p变量名 来查看变量,q结束调试,退出程序。
•pdb.set_trace
在可能出错的地方放一个 pdb.set_trace() ,就可以设置一个断点。程序会自动在 pdb.set_trace() 暂停并进入 pdb调试环境, p查看变量, c继续运行。
import pdb

n1 = 1
n = int(n1)
print n
pdb.set_trace()
print 'world'
pdb.set_trace()
print 'hello'
s = 2
print s
 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值