python学习笔记012——pdb调试
1 描述
pdb 是 python 自带的一个包,为 python 程序提供了一种交互的源代码调试功能,
主要特性包括设置断点、单步调试、进入函数调试、查看当前代码、查看栈片段、动态改变变量的值等
调试作用 :
可以让程序单步执行,观察中间结果
可以设定指定断点,进行特定位置观察
2 调试命令
| 完整命令 | 简写命令 | 描述 | 
| args | a | 打印当前函数的参数 | 
| break | b | 设置断点 | 
| clear | cl | 清除断点 | 
| condition | 无 | 设置条件断点 | 
| continue | c或者cont | 继续运行,知道遇到断点或者脚本结束 | 
| disable | 无 | 禁用断点 | 
| enable | 无 | 启用断点 | 
| help | h | 查看pdb帮助 | 
| ignore | 无 | 忽略断点 | 
| jump | j | 跳转到指定行数运行 | 
| list | l | 列出脚本清单 | 
| next | n | 执行下条语句,遇到函数不进入其内部 | 
| p | p | 打印变量值,也可以用print | 
| quit | q | 退出 pdb | 
| return | r | 一直运行到函数返回 | 
| tbreak | 无 | 设置临时断点,断点只中断一次 | 
| step | s | 执行下一条语句,遇到函数进入其内部 | 
| where | w | 查看所在的位置 | 
| ! | 无 | 在pdb中执行语句 | 
注意:
1:直接输入Enter,会执行上一条命令;
2:输入PDB不认识的命令,PDB会把他当做Python语句在当前环境下执行;
3 示例
3.1 示例1(测试代码)
import pdb a = "aaa" pdb.set_trace() b = "bbb" c = "ccc" final = a + b + c print(final)
运行
> /home/tarena/桌面/t.py(4)<module>() -> b = "bbb" (Pdb) n > /home/tarena/桌面/t.py(5)<module>() -> c = "ccc" (Pdb) > /home/tarena/桌面/t.py(6)<module>() -> final = a + b + c (Pdb) > /home/tarena/桌面/t.py(7)<module>() -> print(final) (Pdb) aaabbbccc --Return-- > /home/tarena/桌面/t.py(7)<module>()->None -> print(final) (Pdb)
开始调试:
直接运行脚本,会停留在 pdb.set_trace() 处; pdb.set_trace() 的作用:从 pdb.set_trace()位置处进入调试状态,在该语句后面的代码单步执行。
选择 n+enter 可以执行当前的 statement。在第一次按下了 n+enter 之后可以直接按 enter 表示重复执行上一条 debug 命令。
import pdb
pdb.set_trace()
def a(n):
    print(n + 1)
    print(n + 2)
    print(n + 3)
    print(n + 4)
    print(n + 5)
    print(n + 6)
def b(n):
    print('b',n)
    a(n + 1)
    print("b 结束")
def c():
    x = 100
    b(x + 100)
c()
运行
> /home/tarena/桌面/t.py(4)<module>() -> def a(n): (Pdb) n > /home/tarena/桌面/t.py(12)<module>() -> def b(n): (Pdb) > /home/tarena/桌面/t.py(17)<module>() -> def c(): (Pdb) > /home/tarena/桌面/t.py(21)<module>() -> c() (Pdb) b 200 202 203 204 205 206 207 b 结束 --Return-- > /home/tarena/桌面/t.py(21)<module>()->None -> c() (Pdb)
3.2 示例2(代码调试)
详细代码
https://www.ibm.com/developerworks/cn/linux/l-cn-pythondebugger/
https://docs.python.org/3.6/library/pdb.html
python学习笔记012——pdb调试的更多相关文章
- python学习笔记之pdb调试
		
之前一直说要学python可还是一直停留在看的层面,昨天大神手把书教我pdb调试,说要摆脱IDE集成开发环境编程,感激不尽,立一个flag,python一定要入门! 1.进入方式 1)windows ...
 - Python学习笔记012——装饰器
		
1 装饰器 1.1装饰器定义 在代码运行期间动态增加功能的方式,称之为“装饰器”(Decorator). 1.2 装饰器分类 装饰器:函数装饰器,类装饰器,函数的装饰器,类的装饰器 装饰器:函数装饰函 ...
 - python学习笔记012——locals与globals
		
1 定义 globals() 功能:收集全局变量参数:无返回值:得到一个收集全局变量的字典(会包含系统的内置变量) locals() 功能:收集局部变量参数:无返回值:得到一个收集局部变量的字典 a ...
 - [Python学习笔记]调试
		
编码占了编程工作量的90%,调试占了另外90%,这是一个流传着的笑话.调试在编程中占有很大的分量,即使专业的程序员也一直在制造缺陷. 抛出异常 抛出异常相当于是说:"停止运行这个函数中的代码 ...
 - Python学习笔记(十三)
		
Python学习笔记(十三): 模块 包 if name == main 软件目录结构规范 作业-ATM+购物商城程序 1. 模块 1. 模块导入方法 import 语句 import module1 ...
 - Deep learning with Python 学习笔记(4)
		
本节讲卷积神经网络的可视化 三种方法 可视化卷积神经网络的中间输出(中间激活) 有助于理解卷积神经网络连续的层如何对输入进行变换,也有助于初步了解卷积神经网络每个过滤器的含义 可视化卷积神经网络的过滤 ...
 - 雨痕 的《Python学习笔记》--附脑图(转)
		
原文:http://www.pythoner.com/148.html 近日,在某微博上看到有人推荐了 雨痕 的<Python学习笔记>,从github上下载下来看了下,确实很不错. 注意 ...
 - 大学四年的Python学习笔记分享之一,内容整理的比较多与仔细
		
翻到以前在大学坚持记录的Python学习笔记,花了一天的时间整理出来,整理时不经回忆起大学的时光,一眨眼几年就过去了,现在还在上学的你们,一定要珍惜现在,有个充实的校园生活.希望这次的分享对于你们有学 ...
 - python学习笔记整理——字典
		
python学习笔记整理 数据结构--字典 无序的 {键:值} 对集合 用于查询的方法 len(d) Return the number of items in the dictionary d. 返 ...
 
随机推荐
- go语言基础之指针做函数参数用地址传递
			
1.指针做函数参数 示例: package main //必须有个main包 import "fmt" func swap(p1, p2 *int) { *p1, *p2 = *p ...
 - Handler Thread 内部类引起内存泄露分析
			
非静态内部类引起内存泄漏的原因 内部类的实现其实是通过编译器的语法糖(Syntactic sugar)实现的,通过生成相应的子类即以OutClassName$InteriorClassName命名的C ...
 - 本地主机DNS劫持演示及防范
			
劫持演示 如果要进行DNS劫持 ...
 - Java方法重写与方法重载
			
方法重载:发生在同一个类中,方法名相同方法形参列表不同就会重载方法. 方法重写:发生在继承当中,如果子的一个类方法与父类中的那个方法一模一样(方法名和形参列表一样),那么子类就会重写父类的方法. 方法 ...
 - C# ftp ListFilesOnServer
			
public static bool ListFilesOnServer(Uri serverUri) { // The serverUri should start with the ftp:// ...
 - [Javascript Crocks] Make your own functions safer by lifting them into a Maybe context
			
You probably have functions that aren’t equipped to accept a Maybe as an argument. And in most cases ...
 - GG配置ggmgr进程
			
Oracle配置mgr进程 edit params mgr port 7809 syslog none dynamicportlist 7810-7820 自己主动会生成./dirprm/mgr.pr ...
 - Java 程序内存分析
			
转自:http://www.iteye.com/topic/528230 java程序内存主要分为了2个部分,包括stack segment(栈内存区).heap segment(堆内存区). 在分析 ...
 - Passing address of non-local object to __autoreleasing parameter for write-back
			
在希望通过函数的參数返回Objective-C对象的时候.遇到了这个问题 错误代码例如以下: - (void)methodA:(NSString **)string<span style=&qu ...
 - ORACLE关于锁表查询的部分SQL
			
http://www.cnblogs.com/quanweiru/archive/2012/08/28/2660700.html --查询表空间名称和大小 SELECT UPPER (F.TABLES ...