如何在php中按元素按字母顺序排列json文件


How do you alphabetize a json file in php by an element?

目前,我有一个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'));