douhuang1973 2014-01-09 12:25
浏览 72
已采纳

json_encode数组的特定部分

$array = array("Real" => array("Alonso","Zidan"),"Inter" => "Zanetti", "Roma" => "Toti");
$json=json_encode($array);
echo $json

By this way I am reading all the data, but how can I read the data of only Real or Inter?

For example, if it is json_decoded I can do so:

  1. For Inter:

    echo $array['Inter'];
    
  2. For Real:

    foreach($array["Real"] as $real){ 
        echo $real."<br>";
    }
    

How can I do the same with json_encode()?

  • 写回答

2条回答 默认 最新

  • douyouqian8550 2014-01-09 12:34
    关注

    As I understand your question you need to output the json`d object.

    Input

    $input = '{"Real":["Alonso","Zidan"],"Inter":"Zanetti","Roma":"Toti"}';
    

    In php:

    // Second true is for array return, not object)
    $string = json_decode($input, true) 
    echo $string['Inter'];
    

    In Javascript (jQuery):

    var obj = jQuery.parseJSON(input);
    if (obj != undefined) {
        echo obj['Inter'];
    }
    

    UPD:

    If you need to get an json in all arrays you need to make follow:

    $array = array("Real" => array("Alonso","Zidan"),"Inter" => "Zanetti", "Roma" => "Toti");
    foreach($array as $key => $value) {
        $array[$key] = json_encode($value);
    }
    

    After this code all variables in array will be json`ed and you can echo them in any time

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 wifi 图标不见了 不知道怎么办 上不了网 变成小地球了
  • ¥50 STM32单片机传感器读取错误
  • ¥50 power BI 从Mysql服务器导入数据,但连接进去后显示表无数据
  • ¥15 (关键词-阻抗匹配,HFSS,RFID标签)
  • ¥50 sft下载大文阻塞卡死
  • ¥15 机器人轨迹规划相关问题
  • ¥15 word样式右侧翻页键消失
  • ¥15 springboot+vue 集成keycloak sso到阿里云
  • ¥15 win7系统进入桌面过一秒后突然黑屏
  • ¥30 backtrader对于期货交易的现金和资产计算的问题