如何解决IPython - 引发 SystemExit 时隐藏回溯
我很惊讶之前没有人问过这个问题,但不知何故我找不到答案。
在简单的 SystemExit
中引发 my_script.py
时。
import sys
sys.exit(2)
运行 python my_script.py
时不显示回溯,如 python doc 中所述:
SystemExit:不处理时,Python解释器退出;没有打印堆栈回溯。
但是,当使用 ipython
运行时,会打印回溯:
$ ipython my_script.py
---------------------------------------------------------------------------
SystemExit Traceback (most recent call last)
my_script.py in <module>
2 import sys
3
----> 4 sys.exit(2)
SystemExit: 2
如果解析失败,将 argparse
用作 parser.parse_args()
call sys.exit()
时会出现此问题。因此,用户看到的是无用的 SystemExit: 2
,而不是回溯上方打印的错误消息。
一种解决方法是使用 os._exit
,但这感觉很麻烦,可能无法正确清理。
是否有一个 ipython
标志可以在引发 SystemExit
时静音/隐藏回溯,就像标准的 python
解释器一样?
解决方法
以下是使用 xmode
'plain' 的示例会话:
In [1]: import argparse
In [2]: parser=argparse.ArgumentParser()
In [3]: parser.add_argument('foo')
Out[3]: _StoreAction(option_strings=[],dest='foo',nargs=None,const=None,default=None,type=None,choices=None,help=None,metavar=None)
In [4]: import sys; sys.argv
Out[4]:
['/usr/local/bin/ipython3','--pylab','qt','--nosep','--term-title','--InteractiveShellApp.pylab_import_all=False','--TerminalInteractiveShell.xmode=Plain']
In [5]: parser.parse_args()
usage: ipython3 [-h] foo
ipython3: error: unrecognized arguments: --pylab --nosep --term-title --InteractiveShellApp.pylab_import_all=False --TerminalInteractiveShell.xmode=Plain
An exception has occurred,use %tb to see the full traceback.
SystemExit: 2
/usr/local/lib/python3.8/dist-packages/IPython/core/interactiveshell.py:3426: UserWarning: To exit: use 'exit','quit',or Ctrl-D.
warn("To exit: use 'exit',or Ctrl-D.",stacklevel=1)
In [6]: parser.parse_args([])
usage: ipython3 [-h] foo
ipython3: error: the following arguments are required: foo
An exception has occurred,stacklevel=1)
这显示了解析器产生的错误消息,然后是捕获和回溯。这让我能够以交互方式继续。
使用简单的解释器,我收到消息,然后退出。
2310:~/mypy$ python3
Python 3.8.5 (default,Jan 27 2021,15:41:15)
[GCC 9.3.0] on linux
Type "help","copyright","credits" or "license" for more information.
>>> import argparse
>>> parser=argparse.ArgumentParser()
>>> parser.add_argument('foo');
_StoreAction(option_strings=[],metavar=None)
>>> parser.parse_args()
usage: [-h] foo
: error: the following arguments are required: foo
2311:~/mypy$
对我来说,使用 ipython
的全部目的是尝试多种方法,而不会让我放弃。否则我会在没有交互层的情况下运行脚本。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。