WireArray::findRandomTimed() method

Find a quantity of random elements from this WireArray based on a timed interval (or user provided seed).

If no $seed is provided, today's date (day) is used to seed the random number generator, so you can use this function to rotate items on a daily basis.

Idea and implementation provided by mindplay.dk

Example

// Get same 3 random items per day
$randomItems = $items->findRandomTimed(3);

// Get same 3 random items per hour
$randomItems = $items->findRandomTimed('YmdH'); 

Usage

// basic usage
$items = $wireArray->findRandomTimed(int $num);

// usage with all arguments
$items = $wireArray->findRandomTimed(int $num, $seed = 'Ymd');

Arguments

NameType(s)Description
numint

The amount of items to extract from the given list

seed (optional)int, string

Optionally provide one of the following:

  • A PHP date() format string.
  • A number used to see the random number generator.
  • The default is the PHP date format "Ymd" which makes it randomize once daily.

Return value

See Also


WireArray methods and properties

API reference based on ProcessWire core version 3.0.248

Latest news

  • ProcessWire Weekly #581
    The 581st issue of ProcessWire Weekly brings in all the latest news from the ProcessWire community. Modules, sites, and more. Read on!
    Weekly.pw / 28 June 2025
  • New ProcessWire admin redesign
    When you upgrade to ProcessWire 3.0.248 or newer (currently the dev branch), you’ll immediately notice something new and beautiful…
    Blog / 9 May 2025
  • Subscribe to weekly ProcessWire news

I just love the easy and intuitive ProcessWire API. ProcessWire rocks!” —Jens Martsch, Web developer