PaddlePaddle学习课程——课节4:AI Studio基本操作(二)

主要参考:https://howchoo.com/g/zgi2y2iwyze/debugging-your-python-code

1. 一个混乱的程序

为了本教程的目的,让我们考虑下面的简单程序。

该程序采用两个命令行参数并执行加法和减法操作。

(让我们假设用户输入有效值,因此我们不是错误处理)

import sys

def add(num1=0, num2=0):
    return int(num1) + int(num2)

def sub(num1=0, num2=0):
    return int(num1) - int(num2)

def main():
    #Assuming our inputs are valid numbers
    num1 = 0
    num2 = 2
    
    addition = add(num1, num2)
    print addition
    
    subtraction = sub(num1, num2)
    print subtraction

if __name__ == '__main__':
    main()

2
-2

2. pdb来了

Python附带了一个名为pdb的有用模块,它基本上是一个交互式源代码调试器。

您需要以下几行来实际使用此模块

import pdb
pdb.set_trace()
import pdb
import sys

def add(num1=0, num2=0):
    return int(num1) + int(num2)
    
def sub(num1=0, num2=0):
    return int(num1) - int(num2)
    
def main():
    #Assuming our inputs are valid numbers
    num1 = 33
    num2 = 44
    pdb.set_trace() # <-- 这个表示添加断点
    addition = add(num1, num2)
    print addition
    subtraction = sub(num1, num2)
    print subtraction
    
if __name__ == '__main__':
    main()

paddlespeech 的java实现 paddle教程_Baidu Ai Studio

3. 下一行 - > n

在输入框里, 输入n, 可转到下一行

paddlespeech 的java实现 paddle教程_函数体_02


这将执行当前代码行,现在可以执行下一行。

paddlespeech 的java实现 paddle教程_子程序_03


我们可以使用n逐行遍历整个程序,但这不会非常有用。

另外你可能已经注意到pdb实际上没有进入我们的add函数。让我们看看更多选项,使调试更有趣。

注意: 另一个很酷的功能是点击’返回键’执行你以前的命令(在这种情况下只是n)。

4. 打印 - > p

让我们再次开始调试我们的程序。(你可以点击c使pdb跳到最后或直到下一个断点。由于我们没有任何程序将完成执行)。

现在,如果我们想知道num1或num2包含什么,我们可以在输入框里输入

p num1

paddlespeech 的java实现 paddle教程_函数体_04


回车

paddlespeech 的java实现 paddle教程_输入框_05


这非常方便查看我们的变量实际存储的值。

现在让我们进入添加功能。

5. 动态添加断点 - > b

我们在运行程序之前使用了pdb.set_trace()来设置断点。

我们通常希望在调试会话开始后在程序的特定位置添加断点。

这个时候可以考虑输入b. 可以亲自试一下.

6. 动态分配变量

知道在调试会话期间可以分配变量以帮助调试也很有用。考虑:

paddlespeech 的java实现 paddle教程_输入框_06


输入后运行

paddlespeech 的java实现 paddle教程_Baidu Ai Studio_07

7. 退出 - > q

最后,如果你想在任何时候退出,你可以使用q。正在执行的程序被中止。

8. 其他

还有一种更好的方式, 叫ipdb. 用法和PDB很相似. 不过返回的输出是彩色的.

ENTER (重复上次命令)
c (继续)
l (查找当前位于哪里)
s (进入子程序,如果当前有一个函数调用,那么 s 会进入被调用的函数体)
n(ext) 让程序运行下一行,如果当前语句有一个函数调用,用 n 是不会进入被调用的函数体中的
r (运行直到子程序结束)
!<python 命令>
h (帮助)
a(rgs) 打印当前函数的参数
j(ump) 让程序跳转到指定的行数
l(ist) 可以列出当前将要运行的代码块
p(rint) 最有用的命令之一,打印某个变量
q(uit) 退出调试
r(eturn) 继续执行,直到函数体返回

#如发现环境中未安装, 可以运行下方代码来安装ipdb

!pip install ipdb -i https://pypi.tuna.tsinghua.edu.cn/simple