使用php将foreach循环的结果写入json


write the results of foreach loop to json with php

我是PHP和JSON的新手,正在尝试将一些数据(我从Instagram API获取的)写入JSON文件。我知道我已经成功地在foreach()循环中从Instagram上解码并获取了数组,因为我可以将它们回声出来,但我似乎无法正确地将它们写入json。当我这样做的时候,我只得到一个数组,而不是它们的集合。。。这是我的代码:

foreach($instagram_array['data'] as $key => $image){
    $id = $image['id'];
    $url    = $image['images']['standard_resolution']['url'];
    $date_shot = date('M d, Y', $image['created_time']);
    $likes = $image['likes']['count'];
    };
//I've tried wrapping this below in a foreach loop as well, but without success
$values = array(
    'id' => $id,
    'url' => $url,
    'likes' => $likes,
    'date_shot' => $date_shot,
);
    file_put_contents('mydata.json', json_encode($values, JSON_FORCE_OBJECT)); // I wondered if force_object was the problem, but same result without it...

我得到的是,只有一次(循环中的最后一次):

{
id: "123_456",
url: "http://whatever.jpg",
likes: 5,
date_shot: "Jan 19, 2015"
}

当我希望得到(我认为)是更像这样的东西(整个循环):

{
0: {
  id: "123_456",
  url: "http://whatever.jpg",
  likes: 5,
  date_shot: "Jan 19, 2015"
  }
1: {
  id: "123_457",
  url: "http://whatever2.jpg",
  likes: 10,
  date_shot: "Jan 21, 2015"
  }
2: {...}
}...

最终的目标是将这个json文件与更新版本的json文件合并为一个不断增长的文件,以防这与如何最好地写入json产生差异。。。

您的问题似乎是创建单独的数组并将它们写入文件,而不是创建一个大的"数组数组"然后将其写入文件。

试试这行:

$values[] = ...

$values后面的方括号表示$values将成为一个多维数组。

它应该在foreach循环中移动,所以完整的代码现在看起来是这样的:

foreach($instagram_array['data'] as $key => $image){
    $id = $image['id'];
    $url    = $image['images']['standard_resolution']['url'];
    $date_shot = date('M d, Y', $image['created_time']);
    $likes = $image['likes']['count'];
    $values[] = array(
        'id' => $id,
        'url' => $url,
        'likes' => $likes,
        'date_shot' => $date_shot,
    );
);
file_put_contents('mydata.json', json_encode($values, JSON_FORCE_OBJECT));

在每次迭代时,您需要在$arr中的$values中推送它

$arr = array();
foreach($instagram_array['data'] as $key => $image){
    $id = $image['id'];
    $url    = $image['images']['standard_resolution']['url'];
    $date_shot = date('M d, Y', $image['created_time']);
    $likes = $image['likes']['count'];
    $values = array(
    'id' => $id,
    'url' => $url,
    'likes' => $likes,
    'date_shot' => $date_shot,
    );
    array_push($arr, $values); 
    };
    file_put_contents('mydata.json', json_encode($arr, JSON_FORCE_OBJECT));