如何调试需要用-m执行的python模块?

时间:2013-12-23 12:27:48

标签: python debugging command-line relative-import pudb

我尝试过的每个调试器都需要调试源文件。然而,Python并不总是以这种方式工作。

我有一个模块,里面有__init__.py__main__.py个文件夹,我通常会这样执行:

$ cd /parent/folder
$ python3 -m module_folder --help

如果我不使用-m,则相对导入失败。如果我只是将文件夹传递给pudbpdb和其他人,调试器将失败:

$ cd /parent/folder
$ python3 -m pdb module_folder
Traceback (most recent call last):
  File "/usr/lib64/python3.3/pdb.py", line 1658, in main
    pdb._runscript(mainpyfile)
  File "/usr/lib64/python3.3/pdb.py", line 1536, in _runscript
    with open(filename, "rb") as fp:
IsADirectoryError: [Errno 21] Is a directory: 'module_folder'
Uncaught exception. Entering post mortem debugging
Running 'cont' or 'step' will restart the program
> /usr/lib64/python3.3/pdb.py(1536)_runscript()
-> with open(filename, "rb") as fp:
(Pdb)

我该如何调试?最好使用pudb,而不删除相对导入。

2 个答案:

答案 0 :(得分:3)

将它放在__main__.py

的顶部
#!/usr/bin/env python3

# Declare itself as package if needed
if __name__ == '__main__' and __package__ is None:
    import os, sys, importlib
    parent_dir = os.path.abspath(os.path.dirname(__file__))
    sys.path.append(os.path.dirname(parent_dir))
    __package__ = os.path.basename(parent_dir)
    importlib.import_module(__package__)

# Continue with your code
do_things()

这样,这两个命令就变得相同了:

  1. cd /parent/folder; python -m module_folder
  2. python /parent/folder/module_folder/__main__.py
  3. 只需使用第二种语法进行调试:

    pudb /parent/folder/module_folder/__main__.py
    

    python3 -m pdb /parent/folder/module_folder/__main__.py
    

    Python 2也是如此。

    您可以安全地从上面的代码中删除部分__name__ == '__main__' and,因为正如您在__main__.py中所写的那样,它始终是True。但是,这是一种常见的做法。请参阅PEP 366this other answer

答案 1 :(得分:0)

我想你想这样做:

$ cd /parent/folder
$ python3 -m pdb -m module_folder

实际上,你错过了第二个-m,这使得Python认为module_folder是要运行的脚本的名称。