python使用管道获取进程输出(输出是结构体)
时间: 2024-02-28 09:56:01 浏览: 23
如果子进程的输出是一个结构体(比如JSON、XML等格式),可以使用标准库中的 `json` 或 `xml` 模块来解析输出。具体来说,可以使用管道对象的 `read` 方法读取子进程的输出,并将其传递给 `json.loads` 或 `xml.etree.ElementTree.fromstring` 函数进行解析。下面是一个使用 `json` 模块的示例代码:
```python
import subprocess
import json
# 启动子进程,并将标准输出重定向到一个管道中
p = subprocess.Popen(['python', 'script.py'], stdout=subprocess.PIPE)
# 读取子进程的输出,并解析为JSON格式
output = p.stdout.read()
data = json.loads(output)
# 打印输出结果中的某个字段
print(data['field'])
```
在上面的代码中,我们使用 `subprocess.Popen` 函数启动了一个 `script.py` 脚本的子进程,并将其标准输出重定向到一个管道中。然后,我们使用管道对象的 `read` 方法来读取子进程的输出,并使用 `json.loads` 函数将其解析为一个 Python 字典。最后,我们打印输出结果中的某个字段。
如果子进程的输出是 XML 格式,可以使用 `xml.etree.ElementTree.fromstring` 函数来解析。下面是一个示例代码:
```python
import subprocess
import xml.etree.ElementTree as ET
# 启动子进程,并将标准输出重定向到一个管道中
p = subprocess.Popen(['python', 'script.py'], stdout=subprocess.PIPE)
# 读取子进程的输出,并解析为XML格式
output = p.stdout.read()
root = ET.fromstring(output)
# 打印输出结果中的某个元素
print(root.find('tag').text)
```
在上面的代码中,我们使用 `subprocess.Popen` 函数启动了一个 `script.py` 脚本的子进程,并将其标准输出重定向到一个管道中。然后,我们使用管道对象的 `read` 方法来读取子进程的输出,并使用 `xml.etree.ElementTree.fromstring` 函数将其解析为一个 Element 对象。最后,我们使用 `find` 方法找到输出结果中的某个元素,并打印其文本内容。