python中用try来处理程序异常的集中常用方法

 

 
 
  1. 如果你在写python程序时遇到异常后想进行如下处理的话,一般用try来处理异常,假设有下面的一段程序: 
  2. try
  3.     语句1 
  4.     语句2 
  5.     . 
  6.     语句N 
  7. except .........: 
  8.     print ....... 
  9.  
  10. 但是你并不知道"语句1至语句N"在执行会出什么样的异常,但你还要做异常处理,且想把出现的异常打印出来,并不停止程序的运行,所以在"except ......"这句应怎样来写呢? 
  11.  
  12. 总结了一下至少3个方法: 
  13.  
  14. 方法一:捕获所有异常 
  15.  
  16. try
  17.     a=b 
  18.     b=c 
  19. except Exception,e: 
  20.     print Exception,":",e 
  21.  
  22. 方法二:采用traceback模块查看异常 
  23.  
  24.  
  25. import traceback 
  26. try
  27.     a=b 
  28.     b=c 
  29. except
  30.     traceback.print_exc() 
  31.  
  32. 方法三:采用sys模块回溯最后的异常 
  33.  
  34. import sys 
  35. try
  36.     a=b 
  37.     b=c 
  38. except
  39.     info=sys.exc_info() 
  40.     print info[0],":",info[1
  41.  
  42. 但是,如果你还想把这些异常保存到一个日志文件中,来分析这些异常,那么请看下面的方法: 
  43. 把 traceback.print_exc() 打印在屏幕上的信息保存到一个文本文件中 
  44.  
  45. try:   
  46.     a=b   
  47.     b=c   
  48. except:   
  49.     f=open("c:log.txt",'a')   
  50.     traceback.print_exc(file=f)   
  51.     f.flush()   
  52.     f.close()   
    原文作者:AIOPS_DBA
    原文地址: https://blog.51cto.com/wangwei007/1113007
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞