2013-09-24 3 views
0

모듈을 추가로 가져 오는 파이썬 모듈을 디버깅하고 있습니다.디버깅 - 모든 모듈에서 작동하는 단계별 기능

[main.py]

import module1 

def main(): 
    param = 'A' 

    module1.func1(param) 

if __name__ == '__main__': 
    main() 

는 [module1.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. 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() 

내가 그것으로 무엇을 잘 모릅니다 작동하지 않습니다.

EDIT 2 : 어떻게 내가 c에서 gdb를 사용하여 디버깅합니다. [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를

(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) 

(I 그래서 난 지금. 소리가 이전 혼동 모든 좋은있을 수 있습니다 잠시 동안 GDB를 사용하지 않았습니다. PS.)를

의 a.out

이제 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') 

감사 같은 것을보고 기대했다.

답변

0

s(tep) 명령을 사용하십시오. 가능한 한 다음 줄로 진행하는 next과는 달리 함수로 단계적으로 넘어갑니다.

+0

나는 모든 것을 하나의 기능으로보고 싶지 않습니다. 그냥 기능. 또한 외부 모듈을 통과하지도 않습니다. – AirTycoon

+0

무엇? 당신의 프롬프트는 분명히 당신이 스테핑을하고 싶다는 것을 보여줍니다 ... 당신이 원하는 것을 어떻게하지 않습니까? 너 해봤 어? 그게 뭐가 잘못 됐어? – nneonneo

+0

나는 여전히 debbuging을 처음 사용하지만 pudb에서 s를 누르면 모든 할당이나 conditoin 문을 포함하여 모든 줄에서 중지되었습니다. 그래서 이것은 내가 염두에 두었던 것이 아니며, 단지 함수를 호출 할 때 멈추는 것입니다. – AirTycoon

관련 문제