返回顶部
首页 > 资讯 > 后端开发 > Python >Python 中的 pdb 模块
  • 343
分享到

Python 中的 pdb 模块

模块Pythonpdb 2023-01-31 05:01:06 343人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

python 代码,尤其是别人写的代码看不懂。怎么办? 其实Python中也提供了类似于C语言中用于debug 的 gdb。它叫做pdb。结合本人自己的学习,进行简单的举例,以做备忘和补偿学习。首先参考资料:1、Http://WEB.sta

python 代码,尤其是别人写的代码看不懂。怎么办? 其实Python中也提供了类似于C语言中用于debug 的 gdb。它叫做pdb。结合本人自己的学习,进行简单的举例,以做备忘和补偿学习。


首先参考资料:

1、Http://WEB.stanford.edu/class/physics91si/2013/handouts/Pdb_Commands.pdf

2、https://docs.python.org/2/library/pdb.html


以 shadowsocks 的 local.py 代码为例子,演示相应的基本命令使用。


local.py 代码:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
#
# Copyright 2012-2015 clowwindy
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language Governing permissions and limitations
# under the License.

from __future__ import absolute_import, division, print_function, \
    with_statement

import sys
import os
import logging
import signal

sys.path.insert(0, os.path.join(os.path.dirname(__file__), '../'))
from shadowsocks import shell, daemon, eventloop, tcprelay, udprelay, asyncdns


def main():
    shell.check_python()

    # fix py2exe
    if hasattr(sys, "frozen") and sys.frozen in \
            ("windows_exe", "console_exe"):
        p = os.path.dirname(os.path.abspath(sys.executable))
        os.chdir(p)

    config = shell.get_config(True)

    daemon.daemon_exec(config)

    try:
        logging.info("starting local at %s:%d" %
                     (config['local_address'], config['local_port']))

        dns_resolver = asyncdns.DNSResolver()
        tcp_server = tcprelay.TCPRelay(config, dns_resolver, True)
        udp_server = udprelay.UDPRelay(config, dns_resolver, True)
        loop = eventloop.EventLoop()
        dns_resolver.add_to_loop(loop)
        tcp_server.add_to_loop(loop)
        udp_server.add_to_loop(loop)

        def handler(signum, _):
            logging.warn('received SIGQUIT, doing graceful shutting down..')
            tcp_server.close(next_tick=True)
            udp_server.close(next_tick=True)
        signal.signal(getattr(signal, 'SIGQUIT', signal.SIGTERM), handler)

        def int_handler(signum, _):
            sys.exit(1)
        signal.signal(signal.SIGINT, int_handler)

        daemon.set_user(config.get('user', None))
        loop.run()
    except Exception as e:
        shell.print_exception(e)
        sys.exit(1)

if __name__ == '__main__':
    main()


为了配合测试,写了一个假的配置文件config.JSON:

{
    "server":"127.0j.0.1",
    "server_port":8388,
    "local_port":10808,
    "passWord":"bgt56yhn",
    "timeout":600,
    "method":null
}


一、如何使用pdb 进行调试和获取帮助

1、脚本启动时,即载入pdb 调试信息

python -m pdb scriptfile [arg] #此中情况,程序在代码的第一行设置了一个断点


2、更改脚本加入pdb 调试信息

import pdb
pdb.set_trace()   # 在程序某处设置断点


OK ,我们这里为了图简单,就不去更改local.py 源代码了,直接使用第一种方法去调试

 $ python -m pdb local.py  -c config.json
> /home/test/python/shadowsocks/shadowsocks/local.py(18)<module>()
-> from __future__ import absolute_import, division, print_function, \
(Pdb) help

Documented commands (type help <topic>):
========================================
EOF    bt         cont      enable  jump  pp       run      unt   
a      c          continue  exit    l     q        s        until 
alias  cl         d         h       list  quit     step     up    
args   clear      debug     help    n     r        tbreak   w     
b      commands   disable   ignore  next  restart  u        whatis
break  condition  down      j       p     return   unalias  where 

Miscellaneous help topics:
==========================
exec  pdb

Undocumented commands:
======================
retval  rv

从以上结果也可以看出,默认代码的第一行为断点(只是一个假象的断点,显示断点指令是看不到的),程序停留在此处。

在pdb 状态下,使用help 指令可以获取pdb的帮助信息。


二、n(next)

n(next) 输入的时候,可以执行代码的下一行。

(Pdb) n
> /home/test/python/shadowsocks/shadowsocks/local.py(21)<module>()
-> import sys
(Pdb) n
> /home/test/python/shadowsocks/shadowsocks/local.py(22)<module>()
-> import os
(Pdb) n
> /home/test/python/shadowsocks/shadowsocks/local.py(23)<module>()
-> import logging
(Pdb)           # 此处为空白,按了一个回车键
> /home/test/python/shadowsocks/shadowsocks/local.py(24)<module>()
-> import signal
(Pdb)          # 此处为空白,按了一个回车键
> /home/test/python/shadowsocks/shadowsocks/local.py(26)<module>()
-> sys.path.insert(0, os.path.join(os.path.dirname(__file__), '../'))
(Pdb)

注意:
一个很牛的特性是你可以单击回车键来执行以前的命令(在上面的例子中执行的指令为n)。


三、s(step) 、  b(break) 和 c(continue) 指令

s(step) 输入的时候,可以进入这行代码中的相关函数去执行

b num 输入的时候,是在某行(num)上设置一个断点。若直接输入b ,则显示所有的断点

本来,打算讲s(step)指令和 n(next)指令放到一起,做个比较。不过我更感觉s(step) 指令应该和b(break) 及 c(continue)结合起来一起用,这样感觉效率上更高。

以实际操作去说话,我想在main()函数上打一个断点,然后直接走到这个断点,最后进入main函数。

前提,我知道了 main() 函数位于 72行(函数位于文件中的哪一行,这个靠自己了)

> /home/test/python/shadowsocks/shadowsocks/local.py(18)<module>()
-> from __future__ import absolute_import, division, print_function, \
(Pdb) b 72     # 在72 行设置一个断点
Breakpoint 1 at /home/test/python/shadowsocks/shadowsocks/local.py:72
(Pdb) b        # 显示所有的断点
Num Type         Disp Enb   Where
1   breakpoint   keep yes   at /home/test/python/shadowsocks/shadowsocks/local.py:72
(Pdb) c        # 直接走到这个断点处
> /home/test/python/shadowsocks/shadowsocks/local.py(72)<module>()
-> main()
(Pdb) s        # s ,进入main 函数
--Call--
> /home/dexin/python/shadowsocks/shadowsocks/local.py(30)main()
-> def main():
(Pdb) l
 25      
 26      sys.path.insert(0, os.path.join(os.path.dirname(__file__), '../'))
 27      from shadowsocks import shell, daemon, eventloop, tcprelay, udprelay, asyncdns
 28      
 29      
 30  ->    def main():
 31          shell.check_python()
 32      
 33          # fix py2exe
 34          if hasattr(sys, "frozen") and sys.frozen in \
 35                  ("windows_exe", "console_exe"):

(Pdb) n         # n 移动到下一行
> /home/dexin/python/shadowsocks/shadowsocks/local.py(31)main()
-> shell.check_python()
(Pdb) s         # s 进入到 check_python 函数
--Call--
> /home/dexin/python/shadowsocks/shadowsocks/shell.py(35)check_python()
-> def check_python():
(Pdb)

以上调试中,用的了 l(list) 指令,这个指令的意思为显示代码。默认什么参数也没有的情况下。

显示当前行上下共11行代码。


四、clear num 清除先前设置的断点 ,这里的num 为第几个断点的意思

(Pdb) b 34
Breakpoint 1 at /home/test/python/shadowsocks/shadowsocks/local.py:34
(Pdb) b
Num Type         Disp Enb   Where
1   breakpoint   keep yes   at /home/test/python/shadowsocks/shadowsocks/local.py:34
(Pdb) l
 36              p = os.path.dirname(os.path.abspath(sys.executable))
 37              os.chdir(p)
 38      
 39          config = shell.get_config(True)
 40      
 41          daemon.daemon_exec(config)
 42      
 43          try:
 44              logging.info("starting local at %s:%d" %
 45                           (config['local_address'], config['local_port']))
 46      
(Pdb) b 41
Breakpoint 2 at /home/dexin/python/shadowsocks/shadowsocks/local.py:41
(Pdb) b         # 显示所有的断点
Num Type         Disp Enb   Where
1   breakpoint   keep yes   at /home/dexin/python/shadowsocks/shadowsocks/local.py:34
2   breakpoint   keep yes   at /home/dexin/python/shadowsocks/shadowsocks/local.py:41
(Pdb) clear 1    # 清除第一个断点
Deleted breakpoint 1
(Pdb) b
Num Type         Disp Enb   Where
2   breakpoint   keep yes   at /home/dexin/python/shadowsocks/shadowsocks/local.py:41
(Pdb)


五、p(print) 打印

这个指令的功能主要用于打印程序中的变量值

(Pdb) n
> /home/test/python/shadowsocks/shadowsocks/shell.py(37)check_python()
-> if info[0] == 2 and not info[1] >= 6:
(Pdb) l
 32      verbose = 0
 33      
 34      
 35      def check_python():
 36          info = sys.version_info
 37  ->        if info[0] == 2 and not info[1] >= 6:
 38              print('Python 2.6+ required')
 39              sys.exit(1)
 40          elif info[0] == 3 and not info[1] >= 3:
 41              print('Python 3.3+ required')
 42              sys.exit(1)
(Pdb) p info  # 打印变量值
sys.version_info(major=2, minor=7, micro=6, releaselevel='final', serial=0)


六、动态调整变量的值

(Pdb) n
> /home/test/python/shadowsocks/shadowsocks/shell.py(37)check_python()
-> if info[0] == 2 and not info[1] >= 6:
(Pdb) l
 32      verbose = 0
 33      
 34      
 35      def check_python():
 36          info = sys.version_info
 37  ->        if info[0] == 2 and not info[1] >= 6:
 38              print('Python 2.6+ required')
 39              sys.exit(1)
 40          elif info[0] == 3 and not info[1] >= 3:
 41              print('Python 3.3+ required')
 42              sys.exit(1)
(Pdb) p info
sys.version_info(major=2, minor=7, micro=6, releaselevel='final', serial=0)
(Pdb) info = (11,22,33)
(Pdb) p info
(11, 22, 33)


七、q(quit)退出

(Pdb) quit

--结束END--

本文标题: Python 中的 pdb 模块

本文链接: https://lsjlt.com/news/188771.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Python 中的 pdb 模块
    PYTHON 代码,尤其是别人写的代码看不懂。怎么办? 其实PYTHON中也提供了类似于C语言中用于debug 的 gdb。它叫做pdb。结合本人自己的学习,进行简单的举例,以做备忘和补偿学习。首先参考资料:1、http://web.sta...
    99+
    2023-01-31
    模块 Python pdb
  • Python中的sys模块、random模块和math模块
    一、sys运行时环境模块 sys模块负责程序与python解释器的交互,提供了一系列的函数和变量,用于操控python的运行时环境。 用法: sys.argv:命令行参数List,第...
    99+
    2024-04-02
  • python中的模块
    模块:随着程序变的越来越大  为了便于维护 需要把它分为多个文件 为此python允许把定义放入一个文件 然后在其他脚本中将其作为模块导入 创建模块: 将相关的语句和定义放入与模块同名的文件中 #file:module.py def num...
    99+
    2023-01-31
    模块 python
  • python中的sys模块和os模块
    目录1.sys模块2.os模块(和操作系统相关数据)1.sys模块 sys模块的常见函数列表: sys.argv: 实现从程序外部向程序传递参数。sys.exit([arg]): 程...
    99+
    2024-04-02
  • Python中的time模块和calendar模块
    目录1、时间戳2、时间元组3、获取当前时间4、格式化时间5、格式化日期6、获取CPU时间7、日历模块在Python中对时间和日期的处理方式有很多,其中转换日期是最常见的一个功能。Py...
    99+
    2024-04-02
  • python中的deque模块(collections的deque模块)
    目录 1. deque是python的collections中的一个类 2.deque的简单使用以及它的方法 2.1 创建deque的方法  2.2 创建deque时,并指定大小maxlen,即能装几个元素, 以及d...
    99+
    2023-09-25
    python 开发语言 collections deque 队列
  • Python中模块
    模块对我来说是什么        模块对我来说,感觉就像亲属或者朋友已经走过的路,他们已经趟过的浑水、掉过的坑、践行过的路线,全部提供给你,在你需要的时候请求帮助,借鉴他们的解决方法一样。都是为了方便走好人生路,用最短的路程走到成功的终...
    99+
    2023-01-31
    模块 Python
  • python中的zip模块
    目录1、引入模块2、ZipFile提供如下常用的方法和属性1、引入模块 import zipfile zip文件格式是通用的文档压缩标准,在ziplib模块中,使用ZipFile类来操作zip文件,下面具体介绍...
    99+
    2022-06-10
    python zip模块
  • Python 中的 docx 模块
    Python 中的 docx 模块 本文介绍了 Python 中的 docx 模块,该模块可以用来创建、修改和读取 Microsoft Word 文档(.docx 文件)。本文包括以下内容: 什么是 ...
    99+
    2023-09-13
    python word
  • Python 中 os.path 模块的
    官网文档链接:   https://docs.python.org/3/library/os.path.html 概念:   该模块在路径名上实现了一些有用的功能,主要用于文件的属性获取 代码实现: os.path.abspath(pat...
    99+
    2023-01-30
    模块 Python os
  • python中的json模块
    json模块JSON就是JavaScript Object Notation,这个模块完成了python对象和JSON字符串的互相转换! json是一种很多语言支持的通用语言作用:如下,作为一个桥梁 在api接口中数据调用传输中常用php数...
    99+
    2023-01-31
    模块 python json
  • Python中的Subprocess模块
    原文出处:https://segmentfault.com/a/1190000009176351以前我一直用os.system()处理一些系统管理任务,因为我认为那是运行linux命令最简单的方式.我们能从Python官方文档里读到应该用s...
    99+
    2023-01-31
    模块 Python Subprocess
  • Python中的 getopt模块
    python 的 getopt 模块是一个简单实用的命令行参数解析模块。实现命令解析功能的为模块中的getopt 方法。下面主要介绍一下这个getopt方法的使用。查看getopt 模块的帮助可以得到 getopt方法的所有解释。    g...
    99+
    2023-01-31
    模块 Python getopt
  • Python中的 optparse模块
    python的内置模块中对于命令行的解析模块共两个getopt 和 optparse 。不过getopt过于简单,往往不能满足需求。此时可以使用optparse模块。这个模块相对于getopt更新,功能更强大。那么如何使用optparse模...
    99+
    2023-01-31
    模块 Python optparse
  • Python 中 的 json 模块
    python 中的json 模板主要的两个功能:序列化和反序列化序列化: encoding   将python 数据 编码成json 字符串对应的函数有 dump 和 dumps反序列化: decoding  将json 字符串 解码成 p...
    99+
    2023-01-31
    模块 Python json
  • Python 中的 socket 模块
    本文参考PYTHON 网络编程 第一章import sockethelp(socket)    Functions:    socket() -- create a new socket object    socketpair() -- ...
    99+
    2023-01-31
    模块 Python socket
  • python中的wx模块
    wx包中的方法都是以大写字母开头的,而这和Python的习惯是相反的。原文位置:http://www.cnblogs.com/fnng/archive/2013/05/23/3094033.html---------------------...
    99+
    2023-01-31
    模块 python wx
  • Python中的mmap模块
    mmap是一种虚拟内存映射文件的方法,即可以将一个文件或者其它对象映射到进程的地址空间,实现文件磁盘地址和进程虚拟地址空间中一段虚拟地址的一一对映关系。 普通文件被映射到虚拟地址空间后,程序可以像操作内存一样操作文件,可以提高访问效率,...
    99+
    2023-01-31
    模块 Python mmap
  • Python 中的 urllib2 模块
    通过python 的 urllib2 模块,可以轻易的去模拟用户访问网页的行为。这里将自己的学习过程简单的记录下来。一、urlopen函数    urlopen(url, data=None) -- Basic usage is the s...
    99+
    2023-01-31
    模块 Python
  • Python中的pprint模块
    目录一. pprint美观打印数据结构1.打印2 .格式化3. 任意类4. 递归5. 限制嵌套输出6.控制输出宽度一. pprint美观打印数据结构 pprint模块包含一个“美观打...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作