繁体   English   中英

迭代json数据php

[英]Iterate json data php

首先,对不起我的英语。 现在,我从.json解析数据,但遇到一个问题,通过使用foreach,我只能解析一次1个属性数据。 我需要检索src_big超过1次

"src_big":"http:\/\/cs7004.vk.me\/v7004692\/1af45\/QRt-0dPZ8qg.jpg"

"src_big":"http:\/\/cs7004.vk.me\/v7004767\/1ab37\/3M52LmF_dY8.jpg"

例如:

{  
   "response":[  
      {  
         "id":14867,
         "from_id":-65923388,
         "to_id":-65923388,
         "date":1456947602,
         "post_type":"post",
         "text":"Горячие клавиши Windows 10",
         "attachment":{  
            "type":"photo",
            "photo":{  
               "pid":404384423,
               "aid":223686536,
               "owner_id":-65923388,
               "user_id":100,
               "src":"http:\/\/cs7004.vk.me\/v7004692\/1af44\/5zhYes1I7xg.jpg",
               "src_big":"http:\/\/cs7004.vk.me\/v7004692\/1af45\/QRt-0dPZ8qg.jpg",
               "src_small":"http:\/\/cs7004.vk.me\/v7004692\/1af43\/msvfzwgm5tc.jpg",
               "width":604,
               "height":302,
               "text":"Наука<br>http:\/\/vk.com\/public65923388",
               "created":1456235510,
               "access_key":"d1cff88abc28e29b28"
            }
         },
         "attachments":[  
            {  
               "type":"photo",
               "photo":{  
                  "pid":404384423,
                  "aid":223686536,
                  "owner_id":-65923388,
                  "user_id":100,
                  "src":"http:\/\/cs7004.vk.me\/v7004692\/1af44\/5zhYes1I7xg.jpg",
                  "src_big":"http:\/\/cs7004.vk.me\/v7004692\/1af45\/QRt-0dPZ8qg.jpg",
                  "src_small":"http:\/\/cs7004.vk.me\/v7004692\/1af43\/msvfzwgm5tc.jpg",
                  "width":604,
                  "height":302,
                  "text":"Наука<br>http:\/\/vk.com\/public65923388",
                  "created":1456235510,
                  "access_key":"d1cff88abc28e29b28"
               }
            },
            {  
               "type":"photo",
               "photo":{  
                  "pid":404384428,
                  "aid":223686536,
                  "owner_id":-65923388,
                  "user_id":100,
                  "src":"http:\/\/cs7004.vk.me\/v7004365\/1a9ff\/3tEb3pm-bBA.jpg",
                  "src_big":"http:\/\/cs7004.vk.me\/v7004365\/1aa00\/LIQOncL-su8.jpg",
                  "src_small":"http:\/\/cs7004.vk.me\/v7004365\/1a9fe\/TKchasZfhNo.jpg",
                  "width":604,
                  "height":585,
                  "text":"Наука<br>http:\/\/vk.com\/public65923388",
                  "created":1456235512,
                  "access_key":"e9370296ef33bebb7a"
               }
            },
            {  
               "type":"photo",
               "photo":{  
                  "pid":404384439,
                  "aid":223686536,
                  "owner_id":-65923388,
                  "user_id":100,
                  "src":"http:\/\/cs7004.vk.me\/v7004767\/1ab36\/1IqODh-OmS0.jpg",
                  "src_big":"http:\/\/cs7004.vk.me\/v7004767\/1ab37\/3M52LmF_dY8.jpg",
                  "src_small":"http:\/\/cs7004.vk.me\/v7004767\/1ab35\/lOR1yvNeE8Y.jpg",
                  "width":478,
                  "height":604,
                  "text":"Наука<br>http:\/\/vk.com\/public65923388",
                  "created":1456235514,
                  "access_key":"8cc1048e72e29b8ced"
               }
            },
            {  
               "type":"photo",
               "photo":{  
                  "pid":404384504,
                  "aid":223686536,
                  "owner_id":-65923388,
                  "user_id":100,
                  "src":"http:\/\/cs7004.vk.me\/v7004474\/1b385\/wdi9GlRth20.jpg",
                  "src_big":"http:\/\/cs7004.vk.me\/v7004474\/1b386\/I5PY-gN_xa4.jpg",
                  "src_small":"http:\/\/cs7004.vk.me\/v7004474\/1b384\/HkzVl-hsZUo.jpg",
                  "width":604,
                  "height":419,
                  "text":"Наука<br>http:\/\/vk.com\/public65923388",
                  "created":1456235537,
                  "access_key":"5d5ca96b04e91e2744"
               }
            },
            {  
               "type":"photo",
               "photo":{  
                  "pid":404384509,
                  "aid":223686536,
                  "owner_id":-65923388,
                  "user_id":100,
                  "src":"http:\/\/cs7004.vk.me\/v7004452\/1a619\/nDL7Q9dJhxs.jpg",
                  "src_big":"http:\/\/cs7004.vk.me\/v7004452\/1a61a\/PaJXcLeD5Aw.jpg",
                  "src_small":"http:\/\/cs7004.vk.me\/v7004452\/1a618\/-h36pYEcpPY.jpg",
                  "width":604,
                  "height":292,
                  "text":"Наука<br>http:\/\/vk.com\/public65923388",
                  "created":1456235540,
                  "access_key":"ae318183e5303414e9"
               }
            }
         ],
         "comments":{  
            "count":0
         },
         "likes":{  
            "count":127
         },
         "reposts":{  
            "count":45
         }
      }
   ]
}

您可以尝试json_decode,如注释中提到的“尝试”是这里的示例。

<?PHP


$myJson = <<<JSON
{"response":[{"id":14867,"from_id":-65923388,"to_id":-65923388,"date":1456947602,"post_type":"post","text":"Горячие клавиши Windows 10","attachment":{"type":"photo","photo":{"pid":404384423,"aid":223686536,"owner_id":-65923388,"user_id":100,"src":"http:\/\/cs7004.vk.me\/v7004692\/1af44\/5zhYes1I7xg.jpg","src_big":"http:\/\/cs7004.vk.me\/v7004692\/1af45\/QRt-0dPZ8qg.jpg","src_small":"http:\/\/cs7004.vk.me\/v7004692\/1af43\/msvfzwgm5tc.jpg","width":604,"height":302,"text":"Наука<br>http:\/\/vk.com\/public65923388","created":1456235510,"access_key":"d1cff88abc28e29b28"}},"attachments":[{"type":"photo","photo":{"pid":404384423,"aid":223686536,"owner_id":-65923388,"user_id":100,"src":"http:\/\/cs7004.vk.me\/v7004692\/1af44\/5zhYes1I7xg.jpg","src_big":"http:\/\/cs7004.vk.me\/v7004692\/1af45\/QRt-0dPZ8qg.jpg","src_small":"http:\/\/cs7004.vk.me\/v7004692\/1af43\/msvfzwgm5tc.jpg","width":604,"height":302,"text":"Наука<br>http:\/\/vk.com\/public65923388","created":1456235510,"access_key":"d1cff88abc28e29b28"}},{"type":"photo","photo":{"pid":404384428,"aid":223686536,"owner_id":-65923388,"user_id":100,"src":"http:\/\/cs7004.vk.me\/v7004365\/1a9ff\/3tEb3pm-bBA.jpg","src_big":"http:\/\/cs7004.vk.me\/v7004365\/1aa00\/LIQOncL-su8.jpg","src_small":"http:\/\/cs7004.vk.me\/v7004365\/1a9fe\/TKchasZfhNo.jpg","width":604,"height":585,"text":"Наука<br>http:\/\/vk.com\/public65923388","created":1456235512,"access_key":"e9370296ef33bebb7a"}},{"type":"photo","photo":{"pid":404384439,"aid":223686536,"owner_id":-65923388,"user_id":100,"src":"http:\/\/cs7004.vk.me\/v7004767\/1ab36\/1IqODh-OmS0.jpg","src_big":"http:\/\/cs7004.vk.me\/v7004767\/1ab37\/3M52LmF_dY8.jpg","src_small":"http:\/\/cs7004.vk.me\/v7004767\/1ab35\/lOR1yvNeE8Y.jpg","width":478,"height":604,"text":"Наука<br>http:\/\/vk.com\/public65923388","created":1456235514,"access_key":"8cc1048e72e29b8ced"}},{"type":"photo","photo":{"pid":404384504,"aid":223686536,"owner_id":-65923388,"user_id":100,"src":"http:\/\/cs7004.vk.me\/v7004474\/1b385\/wdi9GlRth20.jpg","src_big":"http:\/\/cs7004.vk.me\/v7004474\/1b386\/I5PY-gN_xa4.jpg","src_small":"http:\/\/cs7004.vk.me\/v7004474\/1b384\/HkzVl-hsZUo.jpg","width":604,"height":419,"text":"Наука<br>http:\/\/vk.com\/public65923388","created":1456235537,"access_key":"5d5ca96b04e91e2744"}},{"type":"photo","photo":{"pid":404384509,"aid":223686536,"owner_id":-65923388,"user_id":100,"src":"http:\/\/cs7004.vk.me\/v7004452\/1a619\/nDL7Q9dJhxs.jpg","src_big":"http:\/\/cs7004.vk.me\/v7004452\/1a61a\/PaJXcLeD5Aw.jpg","src_small":"http:\/\/cs7004.vk.me\/v7004452\/1a618\/-h36pYEcpPY.jpg","width":604,"height":292,"text":"Наука<br>http:\/\/vk.com\/public65923388","created":1456235540,"access_key":"ae318183e5303414e9"}}],"comments":{"count":0},"likes":{"count":127},"reposts":{"count":45}}]}
JSON;

$myObject = json_decode($myJson);
foreach($myObject->response AS $index=>$item)
{
    //print_r($item); //Remove comment to see your item
    foreach($item->attachments AS $attachment)
    {
        echo "attachment:";
        print_r($attachment);
    }
}

工作示例在这里http://ideone.com/8WRxcB

希望这可以帮助

无论如何,您正在使用它来探究源JSON时,问题都来自其结构:

  • 第一个现有的src_bigattachment对象的成员
  • 其他所有对象都是attachments数组对象的成员

因此,您必须:

  • 更改JSON结构(如果已使用),使其保持一致,即将第一个attachment对象更改为对象的attachments数组
  • 或明确地迭代以查找上述每个结构

如果您使用的是PHP > 5.1.3则可以使用迭代器。 看看下面的解决方案:

$json = '{
   "response":[
      {
         "id":14867,
         "from_id":-65923388,
         "to_id":-65923388,
         "date":1456947602,
         "post_type":"post",
         "text":"Горячие клавиши Windows 10",
         "attachment":{
            "type":"photo",
            "photo":{
               "pid":404384423,
               "aid":223686536,
               "owner_id":-65923388,
               "user_id":100,
               "src":"http:\/\/cs7004.vk.me\/v7004692\/1af44\/5zhYes1I7xg.jpg",
               "src_big":"http:\/\/cs7004.vk.me\/v7004692\/1af45\/QRt-0dPZ8qg.jpg",
               "src_small":"http:\/\/cs7004.vk.me\/v7004692\/1af43\/msvfzwgm5tc.jpg",
               "width":604,
               "height":302,
               "text":"Наука<br>http:\/\/vk.com\/public65923388",
               "created":1456235510,
               "access_key":"d1cff88abc28e29b28"
            }
         },
         "attachments":[
            {
               "type":"photo",
               "photo":{
                  "pid":404384423,
                  "aid":223686536,
                  "owner_id":-65923388,
                  "user_id":100,
                  "src":"http:\/\/cs7004.vk.me\/v7004692\/1af44\/5zhYes1I7xg.jpg",
                  "src_big":"http:\/\/cs7004.vk.me\/v7004692\/1af45\/QRt-0dPZ8qg.jpg",
                  "src_small":"http:\/\/cs7004.vk.me\/v7004692\/1af43\/msvfzwgm5tc.jpg",
                  "width":604,
                  "height":302,
                  "text":"Наука<br>http:\/\/vk.com\/public65923388",
                  "created":1456235510,
                  "access_key":"d1cff88abc28e29b28"
               }
            },
            {
               "type":"photo",
               "photo":{
                  "pid":404384428,
                  "aid":223686536,
                  "owner_id":-65923388,
                  "user_id":100,
                  "src":"http:\/\/cs7004.vk.me\/v7004365\/1a9ff\/3tEb3pm-bBA.jpg",
                  "src_big":"http:\/\/cs7004.vk.me\/v7004365\/1aa00\/LIQOncL-su8.jpg",
                  "src_small":"http:\/\/cs7004.vk.me\/v7004365\/1a9fe\/TKchasZfhNo.jpg",
                  "width":604,
                  "height":585,
                  "text":"Наука<br>http:\/\/vk.com\/public65923388",
                  "created":1456235512,
                  "access_key":"e9370296ef33bebb7a"
               }
            },
            {
               "type":"photo",
               "photo":{
                  "pid":404384439,
                  "aid":223686536,
                  "owner_id":-65923388,
                  "user_id":100,
                  "src":"http:\/\/cs7004.vk.me\/v7004767\/1ab36\/1IqODh-OmS0.jpg",
                  "src_big":"http:\/\/cs7004.vk.me\/v7004767\/1ab37\/3M52LmF_dY8.jpg",
                  "src_small":"http:\/\/cs7004.vk.me\/v7004767\/1ab35\/lOR1yvNeE8Y.jpg",
                  "width":478,
                  "height":604,
                  "text":"Наука<br>http:\/\/vk.com\/public65923388",
                  "created":1456235514,
                  "access_key":"8cc1048e72e29b8ced"
               }
            },
            {
               "type":"photo",
               "photo":{
                  "pid":404384504,
                  "aid":223686536,
                  "owner_id":-65923388,
                  "user_id":100,
                  "src":"http:\/\/cs7004.vk.me\/v7004474\/1b385\/wdi9GlRth20.jpg",
                  "src_big":"http:\/\/cs7004.vk.me\/v7004474\/1b386\/I5PY-gN_xa4.jpg",
                  "src_small":"http:\/\/cs7004.vk.me\/v7004474\/1b384\/HkzVl-hsZUo.jpg",
                  "width":604,
                  "height":419,
                  "text":"Наука<br>http:\/\/vk.com\/public65923388",
                  "created":1456235537,
                  "access_key":"5d5ca96b04e91e2744"
               }
            },
            {
               "type":"photo",
               "photo":{
                  "pid":404384509,
                  "aid":223686536,
                  "owner_id":-65923388,
                  "user_id":100,
                  "src":"http:\/\/cs7004.vk.me\/v7004452\/1a619\/nDL7Q9dJhxs.jpg",
                  "src_big":"http:\/\/cs7004.vk.me\/v7004452\/1a61a\/PaJXcLeD5Aw.jpg",
                  "src_small":"http:\/\/cs7004.vk.me\/v7004452\/1a618\/-h36pYEcpPY.jpg",
                  "width":604,
                  "height":292,
                  "text":"Наука<br>http:\/\/vk.com\/public65923388",
                  "created":1456235540,
                  "access_key":"ae318183e5303414e9"
               }
            }
         ],
         "comments":{
            "count":0
         },
         "likes":{
            "count":127
         },
         "reposts":{
            "count":45
         }
      }
   ]
}';
$json_array = json_decode($json, true);
$iterator = new RecursiveIteratorIterator(new RecursiveArrayIterator($json_array));
$src_big = array();
foreach ($iterator as $key => $value) {
        //check key and dulicate entry
        if($key =='src_big' && in_array($value, $src_big) === false){
            $src_big[] = $value;
        }
}

print_r($src_big);

产量

Array
(
    [0] => http://cs7004.vk.me/v7004692/1af45/QRt-0dPZ8qg.jpg
    [1] => http://cs7004.vk.me/v7004365/1aa00/LIQOncL-su8.jpg
    [2] => http://cs7004.vk.me/v7004767/1ab37/3M52LmF_dY8.jpg
    [3] => http://cs7004.vk.me/v7004474/1b386/I5PY-gN_xa4.jpg
    [4] => http://cs7004.vk.me/v7004452/1a61a/PaJXcLeD5Aw.jpg
)

暂无
暂无

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

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