简体   繁体   English

使用 php 或 javascript 列出 JSON 文件中的部分数据

[英]List part of data in JSON file using php or javascript

anyone know how to list some/part of data from json file using php or javascript?有人知道如何使用 php 或 javascript 从 json 文件中列出部分/部分数据吗?

example if i using sql i must do code例如如果我使用 sql 我必须做代码

select email from employees where name='Shyam'

but for json i don't have any clue how to do it.但是对于 json 我不知道该怎么做。

{"employees":[  
    {"name":"Shyam", "email":"shyamjaiswal@gmail.com", "job":"police"},  
    {"name":"Bob", "email":"bob32@gmail.com", "job":"athelic"},  
    {"name":"Jai", "email":"jai87@gmail.com", "job":"king"}  
]}  

by referring data above, i only want to select email where name=shyam by using php/javascript from json file.通过参考上面的数据,我只想使用 json 文件中的 php/javascript 来 select email where name=shyam。

With Javascript you could do something like that:使用 Javascript 您可以执行以下操作:

 const data = {"employees": [ {"name":"Shyam", "email":"shyamjaiswal@gmail.com", "job":"police"}, {"name":"Bob", "email":"bob32@gmail.com", "job":"athelic"}, {"name":"Jai", "email":"jai87@gmail.com", "job":"king"} ]}; const result = data.employees.filter(employe => employe.name === "Shyam"); console.log(result);

And with PHP you can do that:使用 PHP 您可以做到这一点:

$data = json_decode('{"employees": [  
  {"name":"Shyam", "email":"shyamjaiswal@gmail.com", "job":"police"},  
  {"name":"Bob", "email":"bob32@gmail.com", "job":"athelic"},  
  {"name":"Jai", "email":"jai87@gmail.com", "job":"king"}  
]}', true);

$result = array_filter($data['employees'], function ($employee) {
    return $employee['name'] === 'Shyam';
});
var_dump($result);

In PHP you can do something like this.在 PHP 你可以做这样的事情。

$json = '{"employees":[  
    {"name":"Shyam", "email":"shyamjaiswal@gmail.com", "job":"police"},  
    {"name":"Bob", "email":"bob32@gmail.com", "job":"athelic"},  
    {"name":"Jai", "email":"jai87@gmail.com", "job":"king"}  
]} ';

$jsonArray = json_decode($json, true);
$emails = [];

foreach ($jsonArray['employees'] as $item){
    if ($item['name'] == "Shyam") {
        $emails[] = $item['email'];
    }
}

Somethink like this (JS)?像这样(JS)?

      const getEmail = (json, name) => {
        const row = json.employees.find(e => e.name === name);
        return row ? row.email : null;
      }

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM