我正在尝试在python中编写一些简短的脚本,它会在子进程中启动另一个python代码,如果还没有启动,则终止终端& app(Linux)。
所以看起来像:
#!/usr/bin/python
from subprocess import Popen
text_file = open(".proc", "rb")
dat = text_file.read()
text_file.close()
def do(dat):
text_file = open(".proc", "w")
p = None
if dat == "x" :
p = Popen('python StripCore.py', shell=True)
text_file.write( str( p.pid ) )
else :
text_file.write( "x" )
p = # Assign process by pid / pid from int( dat )
p.terminate()
text_file.close()
do( dat )
通过pid从文件“。proc”读取的pid命名过程缺乏知识的问题。 另一个问题是解释器说名为 dat 的字符串不等于“x” ???我错过了什么?
答案 0 :(得分:82)
使用真棒psutil
库非常简单:
p = psutil.Process(pid)
p.terminate() #or p.kill()
如果您不想安装新库,可以使用os
模块:
import os
import signal
os.kill(pid, signal.SIGTERM) #or signal.SIGKILL
如果您有兴趣启动命令python StripCore.py
,如果它没有运行,否则就可以杀死它,您可以使用psutil
来可靠地执行此操作。
类似的东西:
import psutil
from subprocess import Popen
for process in psutil.process_iter():
if process.cmdline() == ['python', 'StripCore.py']:
print('Process found. Terminating it.')
process.terminate()
break
else:
print('Process not found: starting it.')
Popen(['python', 'StripCore.py'])
示例运行:
$python test_strip.py #test_strip.py contains the code above
Process not found: starting it.
$python test_strip.py
Process found. Terminating it.
$python test_strip.py
Process not found: starting it.
$killall python
$python test_strip.py
Process not found: starting it.
$python test_strip.py
Process found. Terminating it.
$python test_strip.py
Process not found: starting it.
注意:在之前的psutil
个版本中cmdline
是属性而不是方法。
答案 1 :(得分:3)
我想做同样的事情,但我想在一个文件中做到这一点。
所以逻辑是:
我修改了Bakuriu的答案并提出了这个问题:
from os import getpid
from sys import argv, exit
import psutil ## pip install psutil
myname = argv[0]
mypid = getpid()
for process in psutil.process_iter():
if process.pid != mypid:
for path in process.cmdline():
if myname in path:
print "process found"
process.terminate()
exit()
## your program starts here...
运行脚本将执行脚本执行的任何操作。运行该脚本的另一个实例将终止该脚本的任何现有实例。
我用它来显示一个PyGTK日历小部件,当我点击时钟时它会运行。如果我单击并且日历未启动,则会显示日历。如果日历正在运行,我单击时钟,日历将消失。
答案 2 :(得分:0)
所以,没有直接关系,但这是当您尝试查找如何使用 Python 终止从特定文件夹运行的进程时出现的第一个问题。
它还以某种方式回答了这个问题(即使它是一个有很多答案的旧问题)。
在创建一种更快的方法来抓取一些政府网站的数据时,我遇到了一个问题,如果池中的任何进程卡住了,它们将被跳过,但仍会占用我计算机的内存。这是我杀死他们的解决方案,如果有人知道更好的方法,请告诉我!
import pandas as pd
import wmi
from re import escape
import os
def kill_process(kill_path, execs):
f = wmi.WMI()
esc = escape(kill_path)
temp = {'id':[], 'path':[], 'name':[]}
for process in f.Win32_Process():
temp['id'].append(process.ProcessId)
temp['path'].append(process.ExecutablePath)
temp['name'].append(process.Name)
temp = pd.DataFrame(temp)
temp = temp.dropna(subset=['path']).reset_index().drop(columns=['index'])
temp = temp.loc[temp['path'].str.contains(esc)].loc[temp.name.isin(execs)].reset_index().drop(columns=['index'])
[os.system('taskkill /PID {} /f'.format(t)) for t in temp['id']]