您好我刚刚开始使用python编程,我正在尝试使用subprocess.Popen来运行我使用“make”编译的程序的多个实例。但在我做“制作”之前,我必须做一些文本处理并生成一组“make”将使用的文件。现在我想同时使用不同的生成文件运行相同的程序,并将程序输出的所有实例的输出写入同一文件。根据实例的数量,我还必须生成那么多文本文件。从本质上讲,我想在第一个for循环下执行所有操作,同时,让我们说'n'次。任何提供的帮助将不胜感激:)。
for mC in range(monteCarlo):
print "Simulation Number",str(mC+1),"of",str(monteCarlo)
L = numpy.zeros((1,4),float)
W = numpy.zeros((1,4),float)
i = 0
j = 0
with open("1t.sp", "r") as inFile:
with open("2t.sp","w") as outFile:
line = inFile.readline()
while (line != ""):
newLine = []
for words in line.split():
if words.startswith("W="):
W[0,i] = float(words[2:].replace('n',''))*random.normalvariate(1,widthDeviation)
#print i,words,str('W='+str(W[i]).strip('[]')+'n').replace(" ","")
words = str('W='+str(W[0,i]).strip('[]')+'n').replace(" ","")
i = i+1
elif words.startswith("L="):
L[0,j] = float(words[2:].replace('n',''))*random.normalvariate(1,lengthDeviation)
#print j,words,str('L='+str(L[j]).strip('[]')+'n').replace(" ","")
words = str('L='+str(L[0,j]).strip('[]')+'n').replace(" ","")
j = j+1
newLine.append(words)
#print newLine
outFile.write(" ".join(newLine))
outFile.write("\n")
line = inFile.readline()
outFile.close()
inFile.close()
openWrite.write(str(W).strip('[]'))
openWrite.write(str(L).strip('[]'))
call(["make"])
fRate = (open("tf.log","r").readlines()[34]).split()[-2]
cSect = (open("tf.log","r").readlines()[35]).split()[-2]
openWrite.write("\t")
openWrite.write(fRate)
openWrite.write(" ")
openWrite.write(cSect)
openWrite.write("\n")
openWrite.close()
答案 0 :(得分:1)
如果您的系统有多个处理器或内核,您可以通过使用multiprocessing module同时运行Python函数来利用它:
import multiprocessing as mp
def run_mc(mC):
print "Simulation Number", str(mC+1), "of", str(monteCarlo)
...
call(["make"])
fRate = (open("tf.log", "r").readlines()[34]).split()[-2]
cSect = (open("tf.log", "r").readlines()[35]).split()[-2]
return fRate, cSect
def log_result(result):
# This is called whenever run_mc returns a result.
# result is modified only by the main process, not the pool workers.
fRate, cSect = result
with open(..., 'a') as openWrite:
openWrite.write('\t{f} {c}\n'.format(f = fRate, c = cSect))
def main():
# mp.Pool creates a pool of worker processes. By default it creates as many
# workers as the system has processors. When the problem is CPU-bound, there
# is no point in making more.
pool = mp.Pool()
for mC in range(monteCarlo):
# This will call run_mc(mC) in a worker process.
pool.apply_async(run_mc, args = (mC), callback = log_result)
if __name__ == '__main__':
main()