что является функцией php для случайного распределения ассоциативного массива при сохранении пар ключ / значения. Я не хочу просто случайным образом выбирать пару ключевых значений, но фактически изменять массив (аналогично функции uasort, но не в порядке).
ТИА
пример:
original array ( [a] => 4 [b] => 8 [c] => -1 [d] => -9 [e] => 2 [f] => 5 [g] => 3 [h] => -4 ) random ordered array ( [d] => -9 [a] => 4 [b] => 8 [c] => -1 [h] => -4 [e] => 2 [g] => 3 [h] => -4 [f] => 5 )
Изменить Сравнение между двумя решениями.
$start = microtime(true); $array = array('a' => 4, 'b' => 8, 'c' => -1, 'd' => -9, 'e' => 2, 'f' => 5, 'g' => 3, 'h' => -4); $shuffleKeys = array_keys($array); shuffle($shuffleKeys); $newArray = array(); foreach($shuffleKeys as $key) { $newArray[$key] = $array[$key]; } print_r ($newArray); $elapsed = microtime(true) - $start; echo "<br>array values took $elapsed seconds.<br>"; $start = microtime(true); $array = array('a' => 4, 'b' => 8, 'c' => -1, 'd' => -9, 'e' => 2, 'f' => 5, 'g' => 3, 'h' => -4); $keys = array_keys( $array ); shuffle( $keys ); print_r(array_merge( array_flip( $keys ) , $array )); $elapsed = microtime(true) - $start; echo "<br>array values took $elapsed seconds.<br>";
Массив ([h] => -4 [e] => 2 [b] => 8 [d] => -9 [a] => 4 [c] => -1 [f] => 5 [g] => 3) значения массива взяли 3.0994415283203E-5 секунд.
Массив ([e] => 2 [a] => 4 [d] => -9 [c] => -1 [g] => 3 [f] => 5 [b] => 8 [h] = > -4) принимали значения 4.2915344238281E-5 секунд.
Вы можете использовать shuffle () для array_keys, а затем объедините свой массив, добавив их в список в новом порядке.
Например
$shuffleKeys = array_keys($array); shuffle($shuffleKeys); $newArray = array(); foreach($shuffleKeys as $key) { $newArray[$key] = $array[$key]; }
Комментарий к shuffle () может сделать трюк: http://ch2.php.net/manual/en/function.shuffle.php#104430
<?php function shuffle_assoc( $array ) { $keys = array_keys( $array ); shuffle( $keys ); return array_merge( array_flip( $keys ) , $array ); } ?>