在PHP中的随机索引处将数组合并到已建立的数组中


Merge array into established array at random indexes in PHP

我正在建立一个图片库,并想在随机点投放一些促销横幅,向用户推广某些优惠。给定以下两个数组已从数据库查询中筛选出来:

媒体图像阵列:

 Array
 (
      [0] => Array
         (
             [insertDate] => 2014-11-10 11:22:58
             [keyword] => standard
             [mediaClass] => image
             [mediaURL] => http://image1.jpg
             [promoURL] => 
         )
      [2] => Array
         (
             [insertDate] => 2014-11-10 11:23:18
             [keyword] => standard
             [mediaClass] => image
             [mediaURL] => http://image3.jpg
             [promoURL] => 
         )
      [3] => Array
         (
             [insertDate] => 2014-11-10 11:23:28
             [keyword] => standard
             [mediaClass] => image
             [mediaURL] => http://image4.jpg
             [promoURL] => 
         )
      [5] => Array
         (
            [insertDate] => 2014-11-10 11:23:48
            [keyword] => standard
            [mediaClass] => image
            [mediaURL] => http://image6.jpg
            [promoURL] => 
         )
    )

促销图像阵列:

    Array
    (
       [1] => Array
          (
            [insertDate] => 2014-11-10 11:23:08
            [keyword] => promo
            [mediaClass] => image
            [mediaURL] => http://image2.jpg
            [promoURL] => http://www.google.com
          )
       [4] => Array
          (
            [insertDate] => 2014-11-10 11:23:38
            [keyword] => promo
            [mediaClass] => image
            [mediaURL] => http://image5.jpg
            [promoURL] => http://www.google.com
          )
     )

如何在保持insertDate媒体图像的排序顺序的同时,将promo图像以随机索引插入媒体映像阵列?

即,将促销横幅添加到图像的时间线中。

这就是我要做的:

<?php
$promo = Array (
   Array ('insertDate' => '2014-11-10 11:23:08', 'keyword' => 'promo', 'mediaClass' => 'image', 'mediaURL' => 'http://image2.jpg', 'promoURL' => 'http://www.google.com'),
   Array ('insertDate' => '2014-11-10 11:23:38', 'keyword' => 'promo', 'mediaClass' => 'image', 'mediaURL' => 'http://image5.jpg', 'promoURL' => 'http://www.google.com')
 );
$media = Array (
  Array ('insertDate' => '2014-11-10 11:22:58', 'keyword' => 'standard', 'mediaClass' => 'image', 'mediaURL' => 'http://image1.jpg', 'promoURL' => '', ),
  Array ('insertDate' => '2014-11-10 11:23:18', 'keyword' => 'standard', 'mediaClass' => 'image', 'mediaURL' => 'http://image3.jpg', 'promoURL' => '', ),
  Array ('insertDate' => '2014-11-10 11:23:28', 'keyword' => 'standard', 'mediaClass' => 'image', 'mediaURL' => 'http://image4.jpg', 'promoURL' => '', ),
  Array ('insertDate' => '2014-11-10 11:23:48', 'keyword' => 'standard', 'mediaClass' => 'image', 'mediaURL' => 'http://image6.jpg', 'promoURL' => '', )
);
//sort the promo in random order. This ensures they go into media in random order
shuffle($promo);
//get random keys to insert the promo image before
$randKeys = array_rand($media, count($promo));
//sort by the random key value in reverse. By inserting in reverse order,
//we won't have an issue with needing to increment keys to prevent two promo
//images ending up next to each other. Also, this is why we shuffle the promo
//array above, so the promo images go in random order because this is no longer random.
rsort($randKeys);
//loop over the random keys and insert the next promo image before each key
foreach($randKeys as $key){
    //get the first promo image and remove it
    $promoImage = array_shift($promo);
    //splice the promo image into the media array
    array_splice($media, $key, 0, array($promoImage));
}
//display
print_r($media);

唯一需要注意的是,我的媒体和promo阵列都是基于数字索引的,从零开始,并且是连续的,这是阵列的默认值,而不像您发布的从媒体阵列中删除14键的阵列。

如果没有大量的图像(比如说,最多100个),可以"手动"创建数组。首先,您应该创建一个数组,其中包含促销项目的位置。你知道内容数组中的项目数,促销数组中的项数;它们的总和将是最终数组的大小。想出一些聪明的数学方法,计算促销项目的位置(例如,不要把促销放在第一和最后一位,不要把两个促销项目放在相邻的位置,如果促销项目比内容项目多,也许你必须unset()一些促销项目)。

如果你有促销职位,你可以在内容项目上仔细搜索,将它们复制到最终数组中。在内容复制之前,您应该检查当前位置是否为促销项目保留,如果是,则应首先复制促销项目。沃伊拉,你有一个最终的项目列表,促销项目交错排列。

PHP对于这类任务是一个很好的选择,这要归功于自动生动化(您不必为深层元素创建父节点)。编程,尤其是网页是:

  1. 将一些数据项挖掘到数组中(来自SQL、JSON、API调用)
  2. 创建具有不同索引的最终数组(可能发生合并/求和项)
  3. 排序、筛选、查找其他字段的其他数组
  4. 显示最终阵列

类似的任务出现在求职面试问题中(扫描一个数组,然后计数/求和/合并一些东西)。