在将输出写入文件时使用多处理显示子进程的实时输出
Using multiproccessing for displaying realtime output from Subproccess while writing the output to file
我有一个代码获取主机地址,询问文件名(保存在用户的桌面上)并询问用户是否要清除文件或附加到文件。
当它 运行 时,它首先将输出打印到屏幕,然后写入文件。
我怎样才能使用多进程使它们同时工作?
我已经尝试过使用 target=,他们 运行 但仍然一个接一个,而不是在一起。
................................................ ..................................................... .....................................
(不要介意主机、文件名、清除输入验证,它们是用来测试多进程的)
代码:(我用第一个条件来测试多进程)
import multiprocessing as mp
import subprocess as sub
import sys
import os
class pingURL():
def __init__(self):
self.t2d = mp.Queue()
self.tf = mp.Queue()
host = input("Enter Host: ")
filename = input("Enter filename: ")
clear = input("Clear File? [Y/n] ")
print(clear, filename) # For Debugging Input Validation
if clear.lower() == 'y' and filename == '':
self.pHclrFileYesFnNo(host)
# self.clrFileYesFnNoWritefile(host)
# self.clrFileYesFnNoPrintoutput(host)
elif clear.lower() == 'n' and filename == '':
self.clrFileNoFnNoPrintoutput(host)
self.clrFileNoFnNoWritefile(host)
elif clear.lower() == 'y' and filename != '':
self.clrFileYesFnYesPrintoutput(host)
self.clrFileYesFnYesWritefile(host, filename)
elif clear.lower() == 'n' and filename != '':
self.clrFileNoFnYesPrintoutput(host)
self.clrFileNoFnYesWritefile(host, filename)
def pHclrFileYesFnNo(self, host):
procs = []
proc = mp.Process(name="Clear + No Filename + Print Output", target=self.clrFileYesFnNoPrintoutput(host))
proc2 = mp.Process(name="Clear + No Filename + Write to file", target=self.clrFileYesFnNoWritefile(host))
procs.append(proc)
procs.append(proc2)
for proc in procs:
proc.start()
proc.join()
def clrFileYesFnNoPrintoutput(self, host):
print(f'Number of procceccess: {mp.cpu_count()}')
print(f'Current Proccess: {mp.current_process().name} + {mp.current_process().pid}')
with sub.Popen(['ping', f'{host}'], stdout=sub.PIPE,
bufsize=1, universal_newlines=True, stderr=sub.STDOUT) as p:
for line in p.stdout:
print(line, end=' ')
def clrFileYesFnNoWritefile(self, host):
print(f'Number of procceccess: {mp.cpu_count()}')
print(f'Current Proccess: {mp.current_process().name} + {mp.current_process().pid}')
file = fr'c:/users/{os.getlogin()}/Desktop/default.txt'
with open(file, 'a') as output:
output.truncate(0)
sub.call(['ping', f'{host}'], stdout=output)
output.close()
def clrFileNoFnNoPrintoutput(self, host):
with sub.Popen(['ping', f'{host}'], stdout=sub.PIPE,
bufsize=1, universal_newlines=True, stderr=sub.STDOUT) as p:
for line in p.stdout:
print(line, end=' ')
def clrFileNoFnNoWritefile(self, host):
file = fr'c:/users/{os.getlogin()}/Desktop/default.txt'
with open(file, 'a') as output:
sub.call(['ping', f'{host}'], stdout=output)
output.close()
def clrFileYesFnYesPrintoutput(self, host):
with sub.Popen(['ping', f'{host}'], stdout=sub.PIPE,
bufsize=1, universal_newlines=True, stderr=sub.STDOUT) as p:
for line in p.stdout:
print(line, end=' ')
def clrFileYesFnYesWritefile(self, host, filename):
file = fr'c:/users/{os.getlogin()}/Desktop/{filename}.txt'
with open(file, 'a') as output:
output.truncate(0)
sub.call(['ping', f'{host}'], stdout=output)
output.close()
def clrFileNoFnYesPrintoutput(self, host):
with sub.Popen(['ping', f'{host}'], stdout=sub.PIPE,
bufsize=1, universal_newlines=True, stderr=sub.STDOUT) as p:
for line in p.stdout:
print(line, end=' ')
def clrFileNoFnYesWritefile(self, host, filename):
file = fr'c:/users/{os.getlogin()}/Desktop/{filename}.txt'
with open(file, 'a') as output:
sub.call(['ping', f'{host}'], stdout=output)
output.close()
if __name__ == "__main__":
pingURL()
我在 运行 运行脚本时得到相同的进程名称和 ID:
好吧,解决方案是为每个条件定义一个处理程序。
这对我有用。
def pHclrFileNoFnNo(self, host):
procs = []
proc = mp.Process(target=self.clrFileNoFnNoWritefile, args=(host,))
proc.daemon = False
proc2 = mp.Process(target=self.clrFileNoFnNoPrintoutput, args=(host,))
proc2.daemon = True
procs.append(proc)
procs.append(proc2)
for proc in procs:
proc.start()
我有一个代码获取主机地址,询问文件名(保存在用户的桌面上)并询问用户是否要清除文件或附加到文件。
当它 运行 时,它首先将输出打印到屏幕,然后写入文件。 我怎样才能使用多进程使它们同时工作? 我已经尝试过使用 target=,他们 运行 但仍然一个接一个,而不是在一起。
................................................ ..................................................... .....................................
(不要介意主机、文件名、清除输入验证,它们是用来测试多进程的)
代码:(我用第一个条件来测试多进程)
import multiprocessing as mp
import subprocess as sub
import sys
import os
class pingURL():
def __init__(self):
self.t2d = mp.Queue()
self.tf = mp.Queue()
host = input("Enter Host: ")
filename = input("Enter filename: ")
clear = input("Clear File? [Y/n] ")
print(clear, filename) # For Debugging Input Validation
if clear.lower() == 'y' and filename == '':
self.pHclrFileYesFnNo(host)
# self.clrFileYesFnNoWritefile(host)
# self.clrFileYesFnNoPrintoutput(host)
elif clear.lower() == 'n' and filename == '':
self.clrFileNoFnNoPrintoutput(host)
self.clrFileNoFnNoWritefile(host)
elif clear.lower() == 'y' and filename != '':
self.clrFileYesFnYesPrintoutput(host)
self.clrFileYesFnYesWritefile(host, filename)
elif clear.lower() == 'n' and filename != '':
self.clrFileNoFnYesPrintoutput(host)
self.clrFileNoFnYesWritefile(host, filename)
def pHclrFileYesFnNo(self, host):
procs = []
proc = mp.Process(name="Clear + No Filename + Print Output", target=self.clrFileYesFnNoPrintoutput(host))
proc2 = mp.Process(name="Clear + No Filename + Write to file", target=self.clrFileYesFnNoWritefile(host))
procs.append(proc)
procs.append(proc2)
for proc in procs:
proc.start()
proc.join()
def clrFileYesFnNoPrintoutput(self, host):
print(f'Number of procceccess: {mp.cpu_count()}')
print(f'Current Proccess: {mp.current_process().name} + {mp.current_process().pid}')
with sub.Popen(['ping', f'{host}'], stdout=sub.PIPE,
bufsize=1, universal_newlines=True, stderr=sub.STDOUT) as p:
for line in p.stdout:
print(line, end=' ')
def clrFileYesFnNoWritefile(self, host):
print(f'Number of procceccess: {mp.cpu_count()}')
print(f'Current Proccess: {mp.current_process().name} + {mp.current_process().pid}')
file = fr'c:/users/{os.getlogin()}/Desktop/default.txt'
with open(file, 'a') as output:
output.truncate(0)
sub.call(['ping', f'{host}'], stdout=output)
output.close()
def clrFileNoFnNoPrintoutput(self, host):
with sub.Popen(['ping', f'{host}'], stdout=sub.PIPE,
bufsize=1, universal_newlines=True, stderr=sub.STDOUT) as p:
for line in p.stdout:
print(line, end=' ')
def clrFileNoFnNoWritefile(self, host):
file = fr'c:/users/{os.getlogin()}/Desktop/default.txt'
with open(file, 'a') as output:
sub.call(['ping', f'{host}'], stdout=output)
output.close()
def clrFileYesFnYesPrintoutput(self, host):
with sub.Popen(['ping', f'{host}'], stdout=sub.PIPE,
bufsize=1, universal_newlines=True, stderr=sub.STDOUT) as p:
for line in p.stdout:
print(line, end=' ')
def clrFileYesFnYesWritefile(self, host, filename):
file = fr'c:/users/{os.getlogin()}/Desktop/{filename}.txt'
with open(file, 'a') as output:
output.truncate(0)
sub.call(['ping', f'{host}'], stdout=output)
output.close()
def clrFileNoFnYesPrintoutput(self, host):
with sub.Popen(['ping', f'{host}'], stdout=sub.PIPE,
bufsize=1, universal_newlines=True, stderr=sub.STDOUT) as p:
for line in p.stdout:
print(line, end=' ')
def clrFileNoFnYesWritefile(self, host, filename):
file = fr'c:/users/{os.getlogin()}/Desktop/{filename}.txt'
with open(file, 'a') as output:
sub.call(['ping', f'{host}'], stdout=output)
output.close()
if __name__ == "__main__":
pingURL()
我在 运行 运行脚本时得到相同的进程名称和 ID:
好吧,解决方案是为每个条件定义一个处理程序。 这对我有用。
def pHclrFileNoFnNo(self, host):
procs = []
proc = mp.Process(target=self.clrFileNoFnNoWritefile, args=(host,))
proc.daemon = False
proc2 = mp.Process(target=self.clrFileNoFnNoPrintoutput, args=(host,))
proc2.daemon = True
procs.append(proc)
procs.append(proc2)
for proc in procs:
proc.start()