magento array_merge

时间:2012-02-01 18:22:01

标签: php array-merge

这个array_merge似乎对我不起作用。我正在尝试将所有数组合并到一个数组中,如下所示:

foreach ($collection as $result) {
          $i++;
          if(empty($json)){
            $json = $result->getData();                                
          }else{
            $json = array_merge($json, $result->getData());                
          }
      }
      print_r($json);

我在集合中有3个数组。但是当我做print_r($ json);它只显示了我这样的最后一个数组。

Array ( 
    [po_id]           => 3 
    [title]           => Test3 
    [geo_address]     => M1 2FF 
    [latitude]        => 53.449137 
    [longitude]       => -2.364551 
    [display_address] => testing 
    [url]             => http://testing.com 
    [phone]           => 0321654987 
    [status]          => 1 
    [type]            => 1 
    [created_time]    => 2012-01-26 11:07:05 
    [update_time]     => 2012-01-26 11:10:13 
    [distance]        => 3708.40724665926 
)

我希望这可以合并所有三个数组并打印出来。

我有点期待它:

Array ( 
[po_id]           => 1 
[title]           => Test1 
[geo_address]     => M1 2FF
[po_id]           => 2 
[title]           => Test2 
[geo_address]     => M2 2FF  
[po_id]           => 3 
[title]           => Test3 
[geo_address]     => M3 2FF 

表示所有数组都应合并到数组中。

EDITTED

我有它的工作。事实上这正是我所寻找的:

$json = array();

    foreach ($collection as $key=>$result) {

         $data = $result->getData();

         $json[$key]['postorefinder_id'] = $data['postorefinder_id'];
         $json[$key]['title'] = $data['title'];
         $json[$key]['geo_address'] = $data['geo_address'];
         $json[$key]['latitude'] = $data['latitude'];
         $json[$key]['latitude'] = $data['latitude'];
         $json[$key]['longitude'] = $data['longitude'];
         $json[$key]['display_address'] = $data['display_address'];
         $json[$key]['url'] = $data['url'];
         $json[$key]['phone'] = $data['phone'];
         $json[$key]['status'] = $data['status'];
         $json[$key]['type'] = $data['type'];
         $json[$key]['created_time'] = $data['created_time'];
         $json[$key]['update_time'] = $data['update_time'];
         $json[$key]['distance'] = $data['distance'];
    }
    return json_encode($json);

谢谢@cillosis,你的例子确实有帮助。

2 个答案:

答案 0 :(得分:4)

根据php.net上的array_merge()函数:

  

如果输入数组具有相同的字符串键,则该键的后一个值将覆盖前一个键。但是,如果数组包含数字键,则后面的值不会覆盖原始值,但会附加。

这意味着,每次尝试合并它们时,因为它们使用相同的密钥,它只会被覆盖。这就是你只看到最后一个数组的原因。

[编辑]

  

那么如何在一个数组中使用相同的键连接多个数组呢?

我没有看到两个元素如何共享同一个键,除非该键包含另一个数组:

foreach ($collection as $result) {

   // Get collection of data
   $data = $result->getData();

   // Assign each result to multi-dimensional array
   $json['po_id'][] = $data['po_id'];
   $json['title'][] = $data['title'];
   $json['geo_address'][] = $data['geo_address'];
   $json['latitude'][] = $data['latitude'];
   // ... the rest of them go here ...

}

这是未经测试的,只是快速将它拼凑在一起。它应输出如下内容:

Array(
   "po_id": Array(
      "first_po_id",
      "second_po_id",
      "third_po_id" 
   ),
   "title": Array(
      "first_title",
      "second_title",
      "third_title" 
   )
)

当然有更多的数据。

答案 1 :(得分:1)

不幸的是,您希望的结构在PHP中是不可能的。阅读the array type;如果您尝试将值分配给预先存在的键,它将覆盖任何现有值:

$array = array('foo' => 'bar');
$array = array_merge($array, array('foo' => 'new'));
var_dump($array['foo']); // new

根据您想要操作结果数据的方式,您可以使用array_merge_recursive

$json = array();

foreach ($collection as $result) {
    $json = array_merge_recursive($json, $result->getData());
}

或者您可能希望集合按结果分组:

// make $json a copy of $collection
$json = $collection;

// overwrite $result within $json 
foreach ($json as &$result) {
    $result = $result->getData(); 
}

编辑:请参阅example output for each of these approaches