我有一个使用loadRow()从Joomla中的数据库查询返回的JSON数组。
我们将自定义字段用于一些精美的页面内容。
我需要这条记录中的文本/值对,位于不同的可用数组中。
我尝试了爆炸,array_map,许多不同的操作,但是我正在为正确的代码组合而苦苦挣扎。
这就是对象的样子。
Array ( [0] =>
{"options":
{"options0":
{"name":"soph","value":"School of Public Health"},
"options1":
{"name":"son","value":"School of Nursing"},
"options2":
{"name":"sohp","value":"School of Health Professions"}
}
}
)
我需要的是这样的
Array (
[0] => {"name":"soph","value":"School of Public Health"},
[1] => {"name":"son","value":"School of Nursing"},
[2] => {"name":"sohp","value":"School of Health Professions"}
)
答案 0 :(得分:1)
好像您将其作为JSON数据存储在数据库中。这样的事情应该起作用:
$row = json_decode($arr[0], true)['options'];
$optionList = [];
foreach($row as $option => $options)
{
array_push($optionList, [
'name' => $options['name'],
'value' => $options['value']
]);
}
将新数据放入$optionList
。
答案 1 :(得分:0)
您的问题对您的需求有些含糊。
我认为那是因为您不知道要问什么问题。
如果我是你,我相信这就是我想要的。
解码数组,并使用数组列对数组进行展平,并使其具有“名称”,键和“值”值。
这样,您可以将数组用作下面代码中的回显线。
$collegeparams = '{"options":
{"options0":
{"name":"soph","value":"School of Public Health"},
"options1":
{"name":"son","value":"School of Nursing"},
"options2":
{"name":"sohp","value":"School of Health Professions"}
}
}';
$arr = array_column(json_decode($collegeparams[0], true)['options'], "value", "name");
var_dump($arr);
echo $arr['sohp'];
以上输出:
array(3) {
["soph"]=>
string(23) "School of Public Health"
["son"]=>
string(17) "School of Nursing"
["sohp"]=>
string(28) "School of Health Professions"
}
School of Health Professions