该进程无法访问该文件,因为它正被python中的另一个进程使用

时间:2017-05-15 10:15:10

标签: python python-2.7 subprocess multiprocessing export-to-text

 def worker(ip, started_date, full_path):


    planner_file = full_path+"\\"+"export_"+str(ip)+".txt"

    print "planner file", planner_file

    arg_list = []
    action ="MakeExport"
    arg_list.append(upnp_path)
    arg_lista.append(action)
    arg_list.append(' ip=')
    arg_list.append(ip)
    arg_list.append(" 2>NULL")


    command = ['python', arg_list]

    p = Popen(command, shell=True, stdin=PIPE, stdout=PIPE, stderr=STDOUT)

    output = p.stdout.read()

   with open(planner_file, "a") as pf:
       pf.write(output)




if __name__=='__main__':

    rack_number, started_date, full_path, ips = main()

    pid = os.getpid()

   print('Main Process is started and PID is: ' + str(pid))

   process_list = []

   for ip in ips:
        p = Process(target=worker, args=(ip, started_date, full_path))
        p.start()
        child_pid = str(p.pid)
        print('PID is:' + child_pid)
        process_list.append(child_pid)

   children = multiprocessing.active_children()

   # print process_list

  while children != []:
     time.sleep(1)
     children = multiprocessing.active_children()

我正在尝试将一些ip地址数据导出到txt文件。虽然它可以正常使用单个IP地址,但如果我尝试使用多个ip地址的脚本,我会在所有其他ip txt文件中收到以下错误。

对于第一个ip地址,脚本正确导出数据。对于所有其他剩余的ips,它说;

'该进程无法访问该文件,因为该文件正由另一个进程使用。'

例如: export_1.8.5.20.txt(正确导出第一个ip数据) export_1.8.5.21.txt(表示进程无法访问该文件)

我的脚本没有任何错误。只需在txt文件中获取上述详细信息。

任何帮助将不胜感激。感谢

1 个答案:

答案 0 :(得分:-1)

这似乎是已知的错误:https://bugs.python.org/issue33369https://bugs.python.org/issue19575

尝试在Popen()调用周围加锁。