Python案例分析|使用调试器调试Python程序

举报
TiAmoZhang 发表于 2023/07/07 09:36:00 2023/07/07
【摘要】 本案例通过一个示例程序的调试,帮助大家了解使用Python调试器调试程序的方法 分析定位程序错误是程序设计最基本的功能。Python标准库的调试器pdb提供了基本的调试功能:设置断点、查看变量等。 集成开发环境(IDE,例如IDLE、Spyder、PyCharm)则提供了更直接方便的调试器。 本案例研究通过实例,阐述使用IDLE调试器跟踪调试Python程序的基本方法

01、示例程序

本节采用的示例程序为一个简单的递归函数小程序。程序模拟倒计时,实现代码如下。
【例1】倒计时小程序countdown.py。

import time
def countdown(n):
    """从n倒计数到0"""
    if n <= 0: #基本情况
        print("时间到!!!")
    else: #递归步骤
        time.sleep(1) #睡眠1秒钟
        print(n) #输出倒数的数字
        countdown(n-1) #递归调用
if __name__ == "__main__":
    countdown(3)

程序正常运行结果如下所示。

3

2

1

时间到!!!

02、使用IDLE调试器调试运行程序

【例CS7.2】使用IDLE调试器调试运行程序示例程序countdown.py。

(1)运行IDLE并打开程序源代码countdown.py。

(2)设置断点。在想要调试的语句上,通过鼠标右键快捷菜单【Set Breakpoint】设置断点,设置了断点的代码行底色为黄色,如图CS7-1所示。也可以通过【Clear Breakpoint】清除已经设置的断点。

image.png

■ 图1 设置断点

(3)打开调试器。在IDLE窗口,按快捷键【F5】,程序开始运行。在弹出的Python解释器命令行窗口,通过执行菜单命令【Debug】|【Debugger】,打开调试器窗口,如图2所示。

image.png


■ 图2 打开调试器窗口

请确保【Debugger】菜单处于选中状态,此时Python解释器命令行窗口显示[DEBUG ON]。在调试器【Debug Control】窗口,选中Source和Globals复选框。如图3所示。

image.png


■ 图3 选中Source和Globals复选框

(4)调试运行程序。在IDLE窗口,按快捷键【F5】,程序开始运行。程序在代码的第一行中断暂停。如图4所示,底色为灰色的代码为当前执行代码行。

image.png


■ 图4 底色为灰色的代码为当前执行代码行

用户可以通过【Debug Control】窗口查看程序运行状态(调用堆栈Stack、局部变量Locals、全局变量Globals),执行下一步调试命令。如图5所示。

image.png


■ 图5 通过【Debug Control】窗口查看程序运行状态

(5)在【Debug Control】窗口中单击运行调试命令【Go】,使程序运行到下一个断点处中断暂停。如图6所示。


image.png


■ 图6 在【Debug Control】窗口中使程序运行到下一个断点处中断暂停


(6)查看程序运行状态。查看局部变量Locals和全局变量Globals。此时n为3。

(7)在【Debug Control】窗口中单击运行调试命令【Over】,单步执行命令。由于n为3,故程序跳转到else后的第一条语句。

(8)继续执行其它调试命令。(注:运行调试命令【Go】执行到下一个断点;【Step】进入函数;【Over】单步执行;【Out】跳出函数;【Quit】退出结束调试)。

【版权声明】本文为华为云社区用户原创内容,未经允许不得转载,如需转载请自行联系原作者进行授权。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。