【问题标题】:Get values from JSON array in PHP with the following format?使用以下格式从 PHP 中的 JSON 数组获取值?
【发布时间】:2020-01-25 19:56:51
【问题描述】:

我从与之合作的 Android 开发人员那里得到了这个数组,我必须从以下数组中获取键 name 的值:

[ 
   { 
      "data":"[{\"name\":\"step 1 kdfhghdkgjdf\\nkjdhfgkjhdkjghd\\nkdfjhgkjdhfg\\n\\n\\ndfjhgkjdfjhgdfgd\\n\"},{\"name\":\"step 2 dhfgkjdfhkhkjchjkfd\\ndkjhjdf\\njhkdfhkghdkfhgkdhg\\n\\n\\ndfjhgkjdfhgdfhgkjdhfgkjhdf\"},{\"name\":\"step 3 kkkkkkkkkk\"},{\"name\":\"step 4 ljlejrhlflhgf\\n\\n\\ndfhjk\"}]",
      "status":1
   }
]

我已尝试执行以下操作:

 <?php
    $s = '[
  {
    "data": "[{\"name\":\"step 1 kdfhghdkgjdf\\nkjdhfgkjhdkjghd\\nkdfjhgkjdhfg\\n\\n\\ndfjhgkjdfjhgdfgd\\n\"},{\"name\":\"step 2 dhfgkjdfhkhkjchjkfd\\ndkjhjdf\\njhkdfhkghdkfhgkdhg\\n\\n\\ndfjhgkjdfhgdfhgkjdhfgkjhdf\"},{\"name\":\"step 3 kkkkkkkkkk\"},{\"name\":\"step 4 ljlejrhlflhgf\\n\\n\\ndfhjk\"}]",
    "status": 1
  }
]';
    $obj = json_decode($s,true);
    echo $obj[0]['data']
    ?> 

这给了我以下输出:

[
  {
    "name": "step 1 kdfhghdkgjdf kjdhfgkjhdkjghd kdfjhgkjdhfg dfjhgkjdfjhgdfgd "
  },
  {
    "name": "step 2 dhfgkjdfhkhkjchjkfd dkjhjdf jhkdfhkghdkfhgkdhg dfjhgkjdfhgdfhgkjdhfgkjhdf"
  },
  {
    "name": "step 3 kkkkkkkkkk"
  },
  {
    "name": "step 4 ljlejrhlflhgf dfhjk"
  }
]

但我只想要键 name 的值,例如:

step 1 kdfhghdkgjdf kjdhfgkjhdkjghd kdfjhgkjdhfg dfjhgkjdfjhgdfgd
step 2 dhfgkjdfhkhkjchjkfd dkjhjdf jhkdfhkghdkfhgkdhg dfjhgkjdfhgdfhgkjdhfgkjhdf
step 3 kkkkkkkkkk
.
.
.

我的问题与此类似: Get value from JSON array in PHP 除了格式不同。

我可以获取这种格式的值吗?如果是这样,怎么做?如果不是,是格式不正确吗?

【问题讨论】:

  • 告诉 Android 开发者再次正确地提供 json 数据。这当然是有效的 JSON,但它看起来像 JSON 中的 JSON。我这么说是因为他/她在服务器端让事情变得不必要地复杂。
  • 你是什么意思“你想要键 name 的值”?每个索引都是这些字符串之一的数组就足够了吗?
  • 这里问题的很大一部分是(部分)数据是双重编码的。这需要通过发送数据的应用程序来解决。处理这类问题不是服务器的工作。让他们发送一个连贯的 JSON 对象,而不是这种愚蠢的 JSON-within-JSON 格式
  • @Shubham 更新部分中的数据与顶部完全相同。有什么区别?
  • 即使在编辑之后,基本点仍然存在。数据仍然是 JSON-within-JSON 并且仍然需要从源头进行更正以使其全部成为一个对象,因此处理起来简单且可预测。与您的 Android 开发人员交谈并说明情况。

标签: php arrays json multidimensional-array arrayobject


【解决方案1】:

假设 $obj[0]['data'] 实际上有您发布的 JSON,只需解码并提取 name 列:

foreach(array_column(json_decode($obj[0]['data'], true), 'name') as $name) {
    echo $name;
}

【讨论】:

  • 是的......虽然恕我直言,最好将数据作为单个对象发送开始
【解决方案2】:

首先,"data" 字段中没有 json 结构,而只是一个包含 json 数据的字符串。

因此,当您将数据转换为常量值时,您做错了。您必须先将所有反斜杠加倍。

然后你可以得到"data"元素并再次执行json_decode

<?php
    $s = '[
  {
    "data": "[{\\"name\\":\\"step 1 kdfhghdkgjdf\\\\nkjdhfgkjhdkjghd\\\\nkdfjhgkjdhfg\\\\n\\\\n\\\\ndfjhgkjdfjhgdfgd\\\\n\\"},{\\"name\\":\\"step 2 dhfgkjdfhkhkjchjkfd\\\\ndkjhjdf\\\\njhkdfhkghdkfhgkdhg\\\\n\\\\n\\\\ndfjhgkjdfhgdfhgkjdhfgkjhdf\\"},{\\"name\\":\\"step 3 kkkkkkkkkk\\"},{\\"name\\":\\"step 4 ljlejrhlflhgf\\\\n\\\\n\\\\ndfhjk\\"}]",
    "status": 1
  }
]';
    $obj = json_decode($s,true);
    $data = json_decode($obj[0]['data'], true);

    foreach($data as $item) {
      print($item['name'] . "\r\n");
    }

【讨论】:

  • 我发布了格式化的 JSON,请再次检查问题。我已经编辑了问题。
  • @Shubham,这不会改变我的答案。当你在 php 中将斜杠放入字符串常量时,你必须通过添加斜杠来转义它们。
  • 答案中的代码没有给出任何输出!
  • 它确实输出每个“名称”项。刚刚又检查了一遍。不要忘记&lt;?php 前缀
  • @MaroofMandal 是的,确实如此。演示:sandbox.onlinephpfunctions.com/code/…。但是,如果数据在发送时采用合理的格式,那就更好了
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2013-08-02
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2020-04-16
  • 1970-01-01
  • 2014-10-15
相关资源
最近更新 更多