目前,我有一个json文件:
{"root":[
{
"companyname":"Zcompany",
"style":"Dstyle",
"price":"$ 99.99"
},
{
"companyname":"Scompany",
"style":"Gstyle",
"price":"$ 129.99"
},
{
"companyname":"Fcompany",
"style":"Estyle",
"price":"$ 19.99"
}
]
}
我使用php创建了一个表,但我希望能够按照公司名称按字母顺序排列json文件。
我就是不能让usort
工作。我很确定这是因为我对json类型使用了错误的usort。
但是,我似乎不明白我做错了什么。
<?php
//read json file
$file = 'root.json';
$filedata = file_get_contents($file);
$root = json_decode($filedata,true);
function build_sorter($key) {
return function ($a, $b) use ($key) {
return strnatcmp($a[$key], $b[$key]);
};
}
usort($root, build_sorter('root'));
foreach($root['root'] as $p) {
//prints table from the json file
echo '<tr><br>
<td>'.$p['companyname'].'</td>'.
'<td>'.$p['style'].'</td>'.
'<td>'.$p['price'].'</td>'.
'</tr>';
;
}
?>
当我运行上面的代码时,我得到错误
警告:在开始foreach的第14行//中为foreach()提供的参数无效。
未定义的索引:根在第14行//启动foreach 的同一行
尝试通过root
密钥(其父密钥)进行排序是没有意义的,使用内部级别中的密钥(price, style, etc..
):
usort($root['root'], build_sorter('price'));