0

我正在调试一个 python 模块,它另外导入模块。

[主.py]

import module1

def main():
    param = 'A'

    module1.func1(param)

if __name__ == '__main__':
    main()

[模块1.py]

def func1(arg1):
    print(arg1)

所以我希望得到的是

PROMPT> python -m pdb main.py
(pdb) <theCommand>
calling main()
(pdb) <theCommand>
calling module1.func1(param = 'A')
(pdb) <theCommand>
calling print(firstArg = 'A')
A

我记得这可以在 gdb 中为 debuggin c 源代码完成。可以这样做 pdb 吗?

EDIT1:步骤不起作用

-> import module1
(Pdb) s
--Call--
> <frozen importlib._bootstrap>(1559)_find_and_load()
(Pdb) 
> <frozen importlib._bootstrap>(1561)_find_and_load()
(Pdb) 
> <frozen importlib._bootstrap>(1562)_find_and_load()
(Pdb) 
--Call--
> <frozen importlib._bootstrap>(266)_get_module_lock()
(Pdb) 
> <frozen importlib._bootstrap>(270)_get_module_lock()
(Pdb) 
> <frozen importlib._bootstrap>(271)_get_module_lock()
(Pdb) 
> <frozen importlib._bootstrap>(272)_get_module_lock()
(Pdb) 
KeyError: 'module1'
> <frozen importlib._bootstrap>(272)_get_module_lock()
(Pdb) 
> <frozen importlib._bootstrap>(273)_get_module_lock()
(Pdb) 
> <frozen importlib._bootstrap>(274)_get_module_lock()
(Pdb) 
> <frozen importlib._bootstrap>(275)_get_module_lock()
(Pdb) 
> <frozen importlib._bootstrap>(276)_get_module_lock()
(Pdb) 
> <frozen importlib._bootstrap>(279)_get_module_lock()
(Pdb) 
--Call--
> <frozen importlib._bootstrap>(181)__init__()
(Pdb) 
> <frozen importlib._bootstrap>(182)__init__()
(Pdb) 
> <frozen importlib._bootstrap>(183)__init__()
(Pdb) 
> <frozen importlib._bootstrap>(184)__init__()
(Pdb) 
> <frozen importlib._bootstrap>(185)__init__()
(Pdb) 
> <frozen importlib._bootstrap>(186)__init__()
(Pdb) 
> <frozen importlib._bootstrap>(187)__init__()
(Pdb) 
--Return--
> <frozen importlib._bootstrap>(187)__init__()->None
(Pdb) 
> <frozen importlib._bootstrap>(280)_get_module_lock()
(Pdb) 
> <frozen importlib._bootstrap>(282)_get_module_lock()
(Pdb) 
> <frozen importlib._bootstrap>(283)_get_module_lock()
(Pdb) 
--Return--
> <frozen importlib._bootstrap>(283)_get_module_lock()->_ModuleLock('...39858433548816
(Pdb) 
> <frozen importlib._bootstrap>(1564)_find_and_load()
(Pdb) 
> <frozen importlib._bootstrap>(1565)_find_and_load()
(Pdb) 
--Call--
> <frozen importlib._bootstrap>(201)acquire()
(Pdb) 
> <frozen importlib._bootstrap>(207)acquire()
(Pdb) 
> <frozen importlib._bootstrap>(208)acquire()
(Pdb) 
> <frozen importlib._bootstrap>(209)acquire()
(Pdb) 
> <frozen importlib._bootstrap>(210)acquire()
(Pdb) 
> <frozen importlib._bootstrap>(211)acquire()

我不知道该怎么办。

编辑2:这就是我使用gdb在c中调试的方式。[main.c]

#include <stdlib.h>

void func2(char * str)
{
    NULL;
}

int func1(int a)
{
    int b = 0;
    b = b + 1;  // useless statement

    func2("this is a string");
    return a;
}

int main()
{
    int a = 0 ;
    return func1(a);
}

现在 gdb a.out

(gdb) break func1
Breakpoint 1 at 0x4004c5: file main.c, line 10.
(gdb) break func2 
Breakpoint 2 at 0x4004b8: file main.c, line 6.
(gdb) break main
Breakpoint 3 at 0x4004e7: file main.c, line 19.
(gdb) run
Starting program: ./a.out 
warning: no loadable sections found in added symbol-file system-supplied DSO at 0x7ffff7ffa000
warning: Could not load shared library symbols for linux-vdso.so.1.
Do you need "set solib-search-path" or "set sysroot"?

Breakpoint 3, main () at main.c:19
19      int a = 0 ;
(gdb) c
Continuing.

Breakpoint 1, func1 (a=0) at main.c:10
10      int b = 0;
(gdb) 
Continuing.

Breakpoint 2, func2 (str=0x400584 "this is a string") at main.c:6
6   }
(gdb) 
Continuing.
[Inferior 1 (process 29249) exited normally]
(gdb)

(ps。我有一段时间没有使用 gdb,所以我之前可能听起来很困惑。现在一切都好。)

现在我尝试对 pdb 做同样的事情。

> ./main.py(3)<module>()
-> import module1
(Pdb) n
> ./main.py(5)<module>()
-> def main():
(Pdb) break module1.  
module1.__builtins__      module1.__doc__           module1.__initializing__  module1.__name__          module1.func1             
module1.__cached__        module1.__file__          module1.__loader__        module1.__package__       module1.py:               
(Pdb) break module1.func1
Breakpoint 1 at ./module1.py:3
(Pdb) c
> ./module1.py(4)func1()
-> print(arg1)
(Pdb) c
A
The program finished and will be restarted
> ./main.py(3)<module>()
-> import module1
(Pdb) 

所以而不是

> ./module1.py(4)func1()

我希望看到这样的东西

> ./module1.py(4)func1(arg1 = 'A')

谢谢。

4

1 回答 1

1

使用s(tep)命令。它将进入函数(与 不同next,如果可能,它会严格前进到下一行)。

于 2013-09-24T05:02:56.030 回答