gpt4 book ai didi

python - 如何在命令提示符下将 python 变量传递给进程

转载 作者:行者123 更新时间:2023-12-01 07:39:13 24 4
gpt4 key购买 nike

我有一个 python 循环,每次迭代都会在新路径中创建一个新图像。我想将该路径发送到先前执行的进程中,该进程正在命令提示符处等待路径。

更详细:

我正在 python 中运行一个自动驾驶模拟器,每 5 帧我想将当前帧(保存在 RAM 磁盘中)测试到我训练过的对象检测器算法(花费大约 9 毫秒来检测我的对象)但打开进程需要 2 秒)。实际上,我使用子进程模块执行训练后的算法,但我遇到的问题是,当打开该进程时(当我运行主脚本时,我只打开该进程一次),它正在等待路径图像。我相信,根据您的提示,我已经接近答案,但我不知道如何将该路径图像传递给在每 5 帧迭代中等待它的子进程。

PD:我使用的是 Windows,Python 3.5.4

你知道我能做什么吗?

最佳答案

如果你在 *nix 环境中,并且我理解你想要什么,管道可以非常优雅地提供你想要做的事情。我不了解 Windows,但也许可以在那里使用相同的概念。

这是一个简单的例子来说明这一点:

管道1a.py:

#!/usr/bin/env python

import time
import sys

for i in range(10):
time.sleep(1) # represent some processing delay
print("filename{}.jpg".format(i))
sys.stdout.flush()

Pipe1b.py:

#!/usr/bin/env python

import sys

while True:
line = sys.stdin.readline()
if len(line) == 0:
break
print "Processing image '{}'".format(line.strip())

如果您使这两个脚本都可执行,那么您可以在命令提示符下通过管道将它们链接在一起:

> Pipe1a.py | Pipe1b.py

结果输出:

Processing image 'filename0.jpg'
Processing image 'filename1.jpg'
Processing image 'filename2.jpg'
Processing image 'filename3.jpg'
Processing image 'filename4.jpg'
Processing image 'filename5.jpg'
Processing image 'filename6.jpg'
Processing image 'filename7.jpg'
Processing image 'filename8.jpg'
Processing image 'filename9.jpg'

这里的概念是,一个进程将数据写入其 stdout,第二个进程从其 stdin 读取该数据。

如果您不想使用命令提示符将它们串在一起,而是想运行单个脚本,则可以使用 Python subprocess1< 执行相同的操作,使用几乎相同的代码 模块。对于此示例,您可以让 Pipe1b.py 程序通过 subprocess.Popen 运行 Pipe1a.py 程序,然后在此处理其输出同样的方式。

关于python - 如何在命令提示符下将 python 变量传递给进程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56810924/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com