【问题标题】:Parse JSON file using PHP/Laravel [duplicate]使用 PHP/Laravel 解析 JSON 文件 [重复]
【发布时间】:2017-07-31 21:35:48
【问题描述】:

我有一个需要解析的 JSON。

{
    "Room 251": {
        "calID": "igm4pfi6cc78ncvm5i3gv521snp0si82@import.calendar.google.com",
        "availMsg": "Open Computer Lab"
        },

    "Room 318": {
        "calID": "9duielvutvv2b8d52ikgf8793pbn43sk@import.calendar.google.com",
        "availMsg": "Open Computer Lab"
        },

    "Room 319 (Friends Room)": {
        "calID": "q5tj99a61g71eqcaboae6md0qahle2hv@import.calendar.google.com",
        "availMsg": "Available For Study"
        },

    "Room 323": {
        "calID": "josiglibstb75c88o4s4f2r3h4i3lagc@import.calendar.google.com",
        "availMsg": "Open Computer Lab"
        },

    "Room 513 (Voinovich Room)": {
        "calID": "anjv4nfcr0b00sttbjp6cse5l7j0mvbe@import.calendar.google.com",
        "availMsg": "Available For Study"
        }
}

我需要获取房间名称、calID 和可用消息。在 PHP/Laravel 中执行此操作的最佳方法是什么?

【问题讨论】:

  • 你有没有尝试过这样做?
  • 究竟是什么意思?
  • 你试过用 laravel 或 php 解析 json 吗?
  • json_decode() 在 PHP 但我不知道是否有 Laravel 特定的方式来做这件事。
  • $data = json_decode($data, TRUE); 返回一个多维数组。任何特定于 laravel 的方式都是毫无意义的,因为它是对这一行的抽象

标签: php json laravel file parsing


【解决方案1】:

你可以使用json_decode来解析一个json数据。

混合 json_decode (字符串 $json [, bool $assoc ] )

例如:

$rooms = json_decode($yourJsonHere, true);

var_dump($rooms);

foreach($rooms as $name => $data) {
    var_dump($name, $data['calID'], $data['availMsg']); // $name is the Name of Room
}

【讨论】:

  • 这将所有房间作为一个多维数组,我已经拥有了。我需要从房间中获取值并将它们设置为变量
  • 为什么要将它们设置为变量?为什么不能使用数组?
  • 因为我需要它们成为以后传递的变量。
  • 好吧,随你所愿。
  • 将您的标记为正确,因为它对我的需要有正确的解决方案,即使我不需要将数据集放入数组中。谢谢
【解决方案2】:

你可以这样做:

<?php
$json = '
{
    "Room 251": {
        "calID": "igm4pfi6cc78ncvm5i3gv521snp0si82@import.calendar.google.com",
        "availMsg": "Open Computer Lab"
        },

    "Room 318": {
        "calID": "9duielvutvv2b8d52ikgf8793pbn43sk@import.calendar.google.com",
        "availMsg": "Open Computer Lab"
        },

    "Room 319 (Friends Room)": {
        "calID": "q5tj99a61g71eqcaboae6md0qahle2hv@import.calendar.google.com",
        "availMsg": "Available For Study"
        },

    "Room 323": {
        "calID": "josiglibstb75c88o4s4f2r3h4i3lagc@import.calendar.google.com",
        "availMsg": "Open Computer Lab"
        },

    "Room 513 (Voinovich Room)": {
        "calID": "anjv4nfcr0b00sttbjp6cse5l7j0mvbe@import.calendar.google.com",
        "availMsg": "Available For Study"
        }
}';
foreach(json_decode($json) as $room_name => $room){
  echo $room_name.'<br/>'; // output the room name, for instead "Room 251"
  echo $room->calID.'<br/>'; // output the room calID
  echo $room->availMsg.'<br/>'; // output the room availMsg
}

 ?>

【讨论】:

  • Trying to get property of non-object
  • 我已经测试过了,它可以工作,你确定你在复制/粘贴时不会遗漏一些东西吗?
  • $cal_ID = $keys['calID']; $availMsg = $keys['availMsg']; echo $cal_ID; echo "&lt;br&gt;"; echo $availMsg; echo "&lt;br&gt;";
  • 你不觉得$data = json_decode($json); foreach ($data ..... 会更好吗? @VincentG
  • 也许在性能方面可能会更好,但我不确定。但它提供了相同的输出结果。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2014-03-08
  • 1970-01-01
  • 2017-09-01
  • 2019-10-02
相关资源
最近更新 更多