process = subprocess.Popen(["python", "restruct.py", dch, photos_folder, project_folder, kmls_folder], stdout=subprocess.PIPE) for line in iter(process.stdout.readline, b''): yield line + b' -------- ' 这段代码中,判断yield输出的信息,如果是“结束”,则输出“end
时间: 2023-07-15 15:13:45 浏览: 62
可以在代码中添加一个判断语句,判断当前 yield 的字符串是否包含“结束”,如果包含则在输出前添加一个“end”字符串,可以像下面这样修改代码:
```
process = subprocess.Popen(["python", "restruct.py", dch, photos_folder, project_folder, kmls_folder], stdout=subprocess.PIPE)
for line in iter(process.stdout.readline, b''):
if "结束" in line.decode():
yield b"end " + line
else:
yield line + b' -------- '
```
这样就可以在输出的字符串前添加一个“end”字符串了。注意要使用`decode()`将`bytes`类型的字符串转换为`str`类型的字符串进行判断。
相关问题
subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
`subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE)`是Python中用于执行外部命令的函数。其中,`cmd`是要执行的命令,`stdout=subprocess.PIPE`表示将命令的标准输出重定向到一个管道中,`stderr=subprocess.PIPE`表示将命令的标准错误输出重定向到一个管道中。这样做的好处是可以在Python中获取命令的输出结果,而不是将结果输出到终端。
下面是一个使用`subprocess.Popen`执行外部命令并获取输出结果的例子:
```python
import subprocess
# 执行命令
cmd = 'ls -l'
p = subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE, shell=True)
# 获取标准输出和标准错误输出
out, err = p.communicate()
# 输出结果
print(out.decode('utf-8'))
print(err.decode('utf-8'))
```
该例子中,我们执行了一个`ls -l`命令,并将其标准输出和标准错误输出保存到了`out`和`err`变量中。最后,我们将输出结果打印到了终端上。
process = subprocess.Popen(['python', '-u', 'E:\20呼气\树莓派上源程序resp2i.py'], stdout=subprocess.PIPE, stderr=subprocess.PIPE)这样写有问题吗
根据您提供的代码,您正在尝试使用`subprocess.Popen()`函数运行一个名为`resp2i.py`的Python脚本。根据您提供的路径,该脚本似乎是位于`E:\20呼气\树莓派上源程序`目录下。
从代码本身来看,看起来没有什么问题。但是,如果您在Windows操作系统上运行该代码,则需要注意路径分隔符的问题。在Windows上,路径分隔符应该是反斜杠`\`,而不是正斜杠`/`。因此,您应该在路径中使用反斜杠,像这样:
```python
process = subprocess.Popen(['python', '-u', 'E:\\20呼气\\树莓派上源程序\\resp2i.py'], stdout=subprocess.PIPE, stderr=subprocess.PIPE)
```
此外,如果您的Python脚本需要使用依赖于其他库或模块,您需要确保这些库和模块已经正确安装,并且可以在运行脚本的Python环境中被导入。否则,您可能会遇到导入错误或其他运行时错误。