zoukankan      html  css  js  c++  java
  • Python学习 Day 12 调试 断言 logging pdb pdb.set_trace

    调试

    第一种方法简单直接粗暴有效,就是用print把可能有问题的变量打印出来看看:

    >>> def foo(s):
    
    n= int(s)
    
    print '>>> n = %d' % n
    
    return 10 / n
    
    >>> def main():
    
    foo('0')
    
    >>> main()
    
    >>> n = 0
    
    Traceback (most recent call last):
    
    File "<pyshell#25>", line 1, in <module>
    
    main()
    
    File "<pyshell#24>", line 2, in main
    
    foo('0')
    
    File "<pyshell#22>", line 4, in foo
    
    return 10 / n
    
    ZeroDivisionError: integer division ormodulo by zero
    

      

    断言

    凡是用print来辅助查看的地方,都可以用断言(assert)来替代:

    >>> def foo(s):
    
    n=int(s)
    
    assertn!=0,'n is zero'
    
    return10/n
    
    >>> def main():
    
    foo('0')
    
    >>> main()
    
    Traceback (most recent call last):
    
    File "<pyshell#37>", line 1, in <module>
    
    main()
    
    File "<pyshell#36>", line 2, in main
    
    foo('0')
    
    File "<pyshell#32>", line 3, in foo
    
    assert n!=0,'n is zero'
    
    AssertionError: n is zero
    

      

    logging

    把print替换为logging是第3种方式,和assert比,logging不会抛出错误,而且可以输出到文件:

    >>> import logging
    
    >>>logging.basicConfig(level=logging.INFO)
    
    >>> s='0'
    
    >>> n=int(s)
    
    >>> logging.info('n=%d' % n)
    
    >>> print 10/n
    
     
    
    Traceback (most recent call last):
    
    File "<pyshell#48>", line 1, in <module>
    
    print 10/n
    
    ZeroDivisionError: integer division ormodulo by zero
    

      

    pdb

    第4种方式是启动Python的调试器pdb,让程序以单步方式运行,可以随时查看运行状态。

    # err.py
    
    s = '0'
    
    n = int(s)
    
    print 10 / n
    
    $ python -m pdb err.py
    
    > /Users/michael/Github/sicp/err.py(2)<module>()
    
    -> s = '0'
    

      

    以参数-m pdb启动后,pdb定位到下一步要执行的代码-> s = '0'。输入命令l来查看代码:

    (Pdb) l

    1 # err.py

    2 -> s = '0'

    3 n = int(s)

    4 print 10 / n

    [EOF]

    输入命令n可以单步执行代码:

    (Pdb) n

    >/Users/michael/Github/sicp/err.py(3)<module>()

    -> n = int(s)

    (Pdb) n

    >/Users/michael/Github/sicp/err.py(4)<module>()

    -> print 10 / n

    任何时候都可以输入命令p 变量名来查看变量:

    (Pdb) p s

    '0'

    (Pdb) p n

    0

    输入命令q结束调试,退出程序:

    (Pdb) n

    ZeroDivisionError: 'integer division ormodulo by zero'

    >/Users/michael/Github/sicp/err.py(4)<module>()

    -> print 10 / n

    (Pdb) q

    Try

    这种通过pdb在命令行调试的方法理论上是万能的,但实在是太麻烦

    pdb.set_trace()

    这个方法也是用pdb,但是不需要单步执行,我们只需要import pdb,然后,在可能出错的地方放一个pdb.set_trace(),就可以设置一个断点:

    # err.py
    import pdb
    
    
    s = '0'
    n = int(s)
    pdb.set_trace() # 运行到这里会自动暂停
    print10 / n

    运行代码,程序会自动在pdb.set_trace()暂停并进入pdb调试环境,可以用命令p查看变量,或者用命令c继续运行:

    $ python err.py

    >/Users/michael/Github/sicp/err.py(7)<module>()

    -> print 10 / n

    (Pdb) p n

    0

    (Pdb) c

    Traceback (most recent call last):

    File "err.py", line 7, in <module>

    print 10 / n

    ZeroDivisionError: integer division ormodulo by zero

    这个方式比直接启动pdb单步调试效率要高很多,但也高不到哪去。

  • 相关阅读:
    离开学校一年多
    ZOJ Problem Set–1337 Pi
    Old Bill
    ZOJ Problem Set–1382 A Simple Task
    ZOJ Problem Set 2975 Kinds of Fuwas
    ZOJ Problem Set 2952 Find All M^N Please
    Generate Passwords
    Java 数据类型转换之字符串
    ZOJ Problem Set 2987 Misspelling
    Digital Roots
  • 原文地址:https://www.cnblogs.com/jpld/p/4481394.html
Copyright © 2011-2022 走看看