2

我有一个有效 Json 格式的字符串,它看起来像这样:

{
    "message": "success",
    "result": {
        "46620": {
            "course_id": "29",
            "en_title": "Google Analytics (Basic)",
            "fa_title": "مبانی گوگل آنالیتیکز",
            "badge_link": "http://www.darsnameh.com/badge/index.php?user=46620&badge="
        },
        "49449": {
            "course_id": "16",
            "en_title": "Multimedia Reporting 1- Reporting in the Internet Age",
            "fa_title": "گزارش‌گری چندرسانه‌ای ۱- گزارشگری در زمانه‌ی اينترنت",
            "badge_link": "http://www.darsnameh.com/badge/index.php?user=49449&badge="
        },
        "55480": {
            "course_id": "33",
            "en_title": "HTML for Journalists and Bloggers",
            "fa_title": "آشنایی با اچ‌تی‌ام‌ال Ùˆ Ùناوری‌های اینترنت برای روزنامه‌نگاران Ùˆ وبلاگ‌نویس‌ها",
            "badge_link": "http://www.darsnameh.com/badge/index.php?user=55480&badge="
        },
        "59250": {
            "course_id": "31",
            "en_title": "Twitter",
            "fa_title": "توییتر",
            "badge_link": "http://www.darsnameh.com/badge/index.php?user=59250&badge="
        },
        "103716": {
            "course_id": "42",
            "en_title": "How to write a CV?",
            "fa_title": "چگونه رزومه بنویسیم؟",
            "badge_link": "http://www.darsnameh.com/badge/index.php?user=103716&badge="
        }
    }
}

我想读取不同的字段,例如所有 fa_titles,我使用 $obj = json_decode($str, true); 将其转换为 Json,然后 echo sizeof($obj['result']); 显示它有 5 个结果对象,但我现在如何访问 fa_title 或 en_title 字段?

4

2 回答 2

3

要遍历所有结果,应该这样做:

$obj = json_decode($str);
foreach ($obj->result as $result)
{
    $fa_title = $result->fa_title;
    $en_title = $result->en_title;
}
于 2012-07-31T16:05:05.040 回答
2

在 JSON 中,数组由方括号 ( [and ]) 指定,而字典只有大括号 ( {and })。

您可以通过执行单独访问每个结果对象$obj['result']['46620']['en_title']。结果对象是关联数组的关联数组(也称为字典)。

您还可以使用循环遍历每个对象foreach,如this question所示

于 2012-07-31T16:05:30.957 回答