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

标签 python

我有一个 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/

相关文章:

用于正则表达式的 Python 和 Unicode block

python - keras和scipy的2D卷积结果不同

python - 嵌套列表的字典理解语法?

python - 使用scrapy时在AWS上获取TCP连接超时: 110: Connection timed out.?

python - 如何去除图像的白色背景并使其透明?

python - 在python中使用函数之前应该定义函数吗?

python - 无法使用 DataFrame.eval() 减去 datetime64

python - 按总值(value)对堆积柱形图进行排序 - Python

python - 如何使用 boost_python 将 C++ 序列化数据暴露给 python

python - tensorflow 逻辑回归的准确性非常差