0

我正在建立一个图片库,并想在随机点投放一些促销横幅,以向用户宣传某些优惠。鉴于已从数据库查询中过滤出以下两个数组:

媒体图像数组:

 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排序顺序?

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

4

2 回答 2

0

这就是我要做的:

<?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);

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

于 2014-11-10T23:11:32.940 回答
0

如果您没有大量图像(例如,最多 100 个),请随意“手动”创建数组。首先,您应该创建一个数组,其中包含促销项目的位置。你知道 content 数组中的项目数,promo 数组中的项目数;它们的总和将是最终数组的大小。找出一些聪明的数学,计算促销项目的位置(例如,不要把促销放在第一位和最后一位,不要把两个促销项目放在相邻的位置,unset()如果有的话,你可能需要一些促销项目比内容项目更多的促销项目)。

如果您有促销职位,您可以遍历内容项,将它们复制到最终数组中。在内容复制之前,您应该检查当前位置是否为促销项目保留,如果是,则应先复制促销项目。瞧,你有一个最终的项目列表,促销项目交错。

PHP 是这类任务的不错选择,这要归功于 autovivification(您不必为深层元素创建父节点)。编程,尤其是网页是:

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

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

于 2014-11-10T23:19:46.983 回答