首页 > 解决方案 > PyCharm 调试子进程/Popen 收到错误消息

问题描述

我使用动态脚本来获取由ansible框架提供的主机信息。

path = '/Volumes/Work@SSD/code/python/icode_devop_be/app/libs/ansible/sources/redis_set_sources.py'
host = 'WIN-2OLQLBCH8FO'
cmd = [path, "--host", host]
try:
    sp = subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
except OSError as e:
    raise AnsibleError("problem running %s (%s)" % (' '.join(cmd), e))
(out, err) = sp.communicate()

当我在Pycharm中调试代码时,我收到了错误消息:

b'usage: redis_set_sources.py [-h] (--list | --host HOST)\nredis_set_sources.py: error: unrecognized arguments: --port 57112 --client 127.0.0.1 --multiproc --file WIN-2OLQLBCH8FO\n'

但是我在终端中运行命令得到了正确的消息:

命令:

app/libs/ansible/sources/redis_set_sources.py --host 'WIN-2OLQLBCH8FO'

正常消息:

{"hostname": "WIN-2OLQLBCH8FO", "port": 5985, "ansible_host": "192.168.0.254", "ansible_user": "administrator", "ansible_ssh_password": "All4Icode", "connection": "winrm", "private_key": null, "transport": "ntlm"}

标签: pythonansiblepycharm

解决方案


绝对您将意外参数传递给您的命令,因为如果您传递它们,错误消息也会在终端中指示:

error: unrecognized arguments: --port 57112 --client 127.0.0.1 --multiproc --file

我认为本文描述了您的问题的解决方案:

https://youtrack.jetbrains.com/issue/PY-7464?_ga=2.7923002.94425001.1581367237-1197479344.1576355856

基本上它建议:

  1. 关闭 PyCharm
  2. 编辑 .idea/workspace.xml 文件并将行从:

< 选项名称="多进程" 值="真" />

<option name="MULTIPROCESS" value="false" />

3.重新启动pycharm 4.在Debug中运行脚本,它再次工作。

我不确定这是否是您的解决方案,但问题模式看起来相同。


推荐阅读