【问题标题】:Python Send SIGINT Signal Subprocess On WindowsPython 在 Windows 上发送 SIGINT 信号子进程
【发布时间】:2018-11-25 10:26:26
【问题描述】:

我已经阅读了很多关于 stackoverflow 的问题,但它们太旧了,对我没有帮助。 我有一个子进程并想发送 CTRL_C_EVENT 信号来停止它。我不想直接杀死它。 这是我的代码:

import subprocess
import os
import signal

CREATE_NO_WINDOW = 0x08000000
'''
I tried these too but i failed.
creationflags=CREATE_NO_WINDOW | CREATE_NEW_PROCESS_GROUP | DETACHED_PROCESS
CREATE_NEW_PROCESS_GROUP = 0x00000200
DETACHED_PROCESS = 0x00000008
'''

cmd = 'my cmd arguments'
process = subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.STDOUT,universal_newlines=True,shell=True,creationflags=CREATE_NO_WINDOW)
test = 0
for line in process.stdout:
    test += 1
    if (test > 60):
        os.kill(process.pid, signal.CTRL_C_EVENT)
        #This fails too
        #process.send_signal(signal.CTRL_C_EVENT)
    else:
        print(line)

这里例外:

OSError: [WinError 6] The handler is invalid

The above exception was the direct cause of the following exception:

Traceback (most recent call last):
  File "C:\Users\xxxxxxx\Desktop\xxxxx\test subprocess.py", line 16, in <module>
    os.kill(process.pid, signal.CTRL_C_EVENT)
SystemError: <built-in function kill> returned a result with an error set

【问题讨论】:

    标签: python python-3.x subprocess sigint


    【解决方案1】:

    我希望这是因为您的进程仍在使用中,因为 for line in process.stdout:

    您可能必须先退出 for 循环然后发送 CTRL_C_EVENT 信号来停止它

    试试这样的:

    import subprocess
    import os
    import signal
    
    CREATE_NO_WINDOW = 0x08000000
    '''
    I tried these too but i failed.
    creationflags=CREATE_NO_WINDOW | CREATE_NEW_PROCESS_GROUP | DETACHED_PROCESS
    CREATE_NEW_PROCESS_GROUP = 0x00000200
    DETACHED_PROCESS = 0x00000008
    '''
    
    cmd = 'my cmd arguments'
    process = subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.STDOUT,universal_newlines=True,shell=True,creationflags=CREATE_NO_WINDOW)
    test = 0
    
    CTRL_C_EVENT_is_required=False
    
    for line in process.stdout:
        test += 1
        if (test > 60):
            CTRL_C_EVENT_is_required=True
            break
        else:
            print(line)
    
    if CTRL_C_EVENT_is_required==True:
        os.kill(process.pid, signal.CTRL_C_EVENT)
    

    【讨论】:

    • 我仍然遇到同样的错误。我也尝试了 time.sleep(20) 并发送 os.kill ctrl_cl_event 信号,但结果相同。
    猜你喜欢
    • 2010-11-08
    • 1970-01-01
    • 1970-01-01
    • 2012-10-08
    • 2011-12-11
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多