本教程详细介绍了如何在python脚本中构建并返回一个标准的json数组,以及php如何通过shell_exec正确接收并解析这种嵌套的json数据结构。通过将python的多个json对象封装成一个列表并统一序列化,以及php分两步解码策略,实现了python与php之间高效、准确地进行复杂数据交互。
在Python与PHP进行数据交互时,一个常见的问题是Python脚本可能以非标准格式输出JSON数据。例如,如果Python循环中每次迭代都打印一个独立的JSON对象,PHP通过shell_exec接收到的将是一个由多个JSON字符串简单拼接而成的长字符串。这种字符串并非一个合法的整体JSON结构(如JSON数组或JSON对象),因此PHP的json_decode()函数将无法直接解析。
原始的Python代码可能如下所示,它在循环内部逐个打印JSON对象:
import json
# 假设 Jira 类和相关方法已定义
if __name__ == "__main__":
jira = Jira() # 示例,实际需要引入Jira类
data = {}
fields = jira.get_fields() # 示例
jql_issues = jira.get_jql_search_issues(jql_search="project = SWAT AND resolution = Unresolved ORDER BY priority DESC, updated DESC") # 示例
for issue in jql_issues:
data['key'] = issue.key
data['assignee'] = issue.fields.assignee.display_name
print(json.dumps(data)) # 问题所在:在循环内逐个打印
# exit # exit在这里会导致只打印第一个这种做法会导致PHP接收到类似 "{"key": "SWAT-107", "assignee
": "Unassigned"} {"key": "SWAT-98", "assignee": "Unassigned"}" 这样的字符串,这并不是一个有效的JSON数组。
为了解决这个问题,Python脚本需要进行优化,确保它输出的是一个标准的JSON数组字符串。这意味着所有的JSON对象都应该被封装在一个Python列表中,然后整个列表作为一个整体被序列化为JSON字符串。
以下是优化后的Python代码示例:
import json
# 假设 Jira 类和相关方法已定义,例如:
# class Jira:
# def get_fields(self):
# return {}
# def get_jql_search_issues(self, jql_search):
# # 模拟返回一些问题对象
# class Issue:
# def __init__(self, key, assignee_name):
# self.key = key
# self.fields = type('obj', (object,), {'assignee': type('obj', (object,), {'display_name': assignee_name})})()
# return [
# Issue("SWAT-107", "Unassigned"),
# Issue("SWAT-98", "Unassigned"),
# Issue("SWAT-100", "Unassigned")
# ]
if __name__ == "__main__":
jira = Jira() # 实例化Jira类
output_list = [] # 创建一个空列表来存储所有数据字典
# 假设以下是获取数据并处理的逻辑
# fields = jira.get_fields()
jql_issues = jira.get_jql_search_issues(jql_search="project = SWAT AND resolution = Unresolved ORDER BY priority DESC, updated DESC")
for issue in jql_issues:
data_item = {} # 为每个issue创建一个新的字典
data_item['key'] = issue.key
data_item['assignee'] = issue.fields.assignee.display_name
output_list.append(data_item) # 将字典添加到列表中
print(json.dumps(output_list)) # 在循环结束后,将整个列表序列化为JSON字符串并打印
# exit() # 通常在脚本末尾不需要显式调用exit()关键点:
当Python脚本按照上述优化方式输出一个标准的JSON数组字符串后,PHP端接收和解析数据就变得相对简单和直观。PHP的shell_exec()函数会捕获Python脚本的所有标准输出,并将其作为单个字符串返回。
PHP接收到的字符串现在是一个有效的JSON数组,但其内部的每个元素仍然是JSON字符串形式。因此,我们需要进行两步解码:
以下是PHP代码示例:
Jira Issues:"; echo "
关键点: