[英]fetch values from array within an array
我有一个多维数组,我希望从此数组中提取每个值。 数组存储在$ data中。
{"success":true,"categories":
[
{"
category_id":"C1",
"parent_id":"P1",
"name":"N1",
"categories":
[
{
"category_id":"C11",
"parent_id":"P11",
"name":"N11",
},
{
"category_id":"C12",
"parent_id":"P12",
"name":"N12",
},
],
"status":"1"
},
{
category_id":"C2",
"parent_id":"P2",
"name":"N2",
"categories":
[
{
"category_id":"C21",
"parent_id":"P21",
"name":"N21",
[
{
"category_id":"C22",
"parent_id":"P23",
"name":"N24",
}
],
"status":"2"
}
],
"status":"3"
},
]
}
我尝试使用
$total = $data['categories']['category_id'];
取值C11
但无法做到。
谁能告诉我如何获取所有数据,尤其是C22
您必须首先使用json_decode 。
$array = json_decode($data, true);
然后,您可以按照说明访问阵列。 或循环浏览以下类别:
if (!empty($array)) {
foreach ($array['categories'] as $category) {
echo $category['id'];
}
}
您可能必须递归执行此操作,才能在类别中遍历类别。 但这完全取决于您要实现的目标。 如果嵌套循环始终只有一个深度,则可以完成此工作。
编辑
您提供的JSON不太正确,我在下面提供了一个更正的JSON:
{
"success": true,
"categories": [
{
"category_id": "C1",
"parent_id": "P1",
"name": "N1",
"categories": [
{
"category_id": "C11",
"parent_id": "P11",
"name": "N11"
},
{
"category_id": "C12",
"parent_id": "P12",
"name": "N12"
}
],
"status": "1"
},
{
"category_id": "C2",
"parent_id": "P2",
"name": "N2",
"categories": [
{
"category_id": "C21",
"parent_id": "P21",
"name": "N21",
"categories": [
{
"category_id": "C22",
"parent_id": "P23",
"name": "N24"
}
],
"status": "2"
}
],
"status": "3"
}
]
}
有一些结尾的逗号和引号丢失。
数据不在PHP数组中,而是JSON数组。 您必须使用json_decode()函数对其进行解码。
那是JSON,而不是php多维数组。 您可以使用json_decode函数来读取它。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.