在php中,排序方式有三種,通過索引排序、通過值排序(不保留原索引)、通過值排序(保留原索引),每種又分為升序、降序以及用戶定義順序三個函數,它們分別如下:
通過索引排序:①升序 ksort()?、诮敌?krsort() ③用戶定義順序 uksort()
不保留原索引值排序:①升序 sort()?、诮敌?rsort()?、塾脩舳x順序 usort()
保留原索引值排序:①升序 asort()?、诮敌?arsort()?、塾脩舳x順序 uasort()
在php中,也可以用array_multisort來一次排序多個數組,不過項目中可能用得比較少,翻轉數組,把數字索引翻轉,索引重新從0開始:array_reverse()
把索引和值調換:array_flip()
隨機順序:shuffle()
迭代器遍歷,代碼如下:
- $test01 = array('a', 'b', 'c');
- // for
- for ($i = 0; $i < count($test01); $i++) {
- echo $test01[$i];
- }
- // foreach value only
- foreach ($test01 as $value) {
- echo $value;
- }
- // foreach key and value
- $test01 = array('a' => 'aaaa', 'b' => 'bbbb', 'c' => 'cccc');
- foreach ($test01 as $key => $value) {
- echo "$key => $value";
- }
- $test01 = array('a' => 'aaaa', 'b' => 'bbbb', 'c' => 'cccc');
- while (list($key, $value) = each($test01)) {
- echo "$key => $value" . "<br/>";
- }
php中,迭代遍歷主要要用到以下函數。
current() 迭代的當前元素。
reset() 重新移動到第一個元素并返回它。
next() 移動到下一個元素并返回它。
prev() 移動到上一個元素并返回它。
end() 移動到最后一個元素并返回它。
each() 以數組的形式返回當前元素的索引和值,并移動到下一個迭代。
key() 返回當前的索引。
array_ walk() 為每一個元素調用函數。
array_ reduce() 為每一個元素依次計算。
變通遍歷,代碼如下:
- array_walk($test01, walk_test);
- function walk_test($key, $value) {
- echo "walk: $key => $value" . "<br/>";
- }
- $test02 = array(1, 2, 3, 4, 5);
- echo array_reduce($test02, reduce_test);
- function reduce_test($run_result, $current_value) {
- return $run_result + $current_value * $current_value;
- }
新聞熱點
疑難解答