首页 > 语言 > PHP > 正文

php中数据排序与遍历函数总结

2024-09-04 11:46:19
字体:
来源:转载
供稿:网友

在php中,排序方式有三种,通过索引排序、通过值排序(不保留原索引)、通过值排序(保留原索引),每种又分为升序、降序以及用户定义顺序三个函数,它们分别如下:

通过索引排序:①升序 ksort() ②降序 krsort() ③用户定义顺序 uksort()

不保留原索引值排序:①升序 sort() ②降序 rsort() ③用户定义顺序 usort()

保留原索引值排序:①升序 asort() ②降序 arsort() ③用户定义顺序 uasort()

在php中,也可以用array_multisort来一次排序多个数组,不过项目中可能用得比较少,翻转数组,把数字索引翻转,索引重新从0开始:array_reverse()

把索引和值调换:array_flip()

随机顺序:shuffle()

迭代器遍历,代码如下:

  1. $test01 = array('a''b''c'); 
  2. // for 
  3. for ($i = 0; $i < count($test01); $i++) { 
  4.     echo $test01[$i]; 
  5. // foreach value only 
  6. foreach ($test01 as $value) { 
  7.     echo $value
  8. // foreach key and value 
  9. $test01 = array('a' => 'aaaa''b' => 'bbbb''c' => 'cccc'); 
  10. foreach ($test01 as $key => $value) { 
  11.     echo "$key => $value"
  12. $test01 = array('a' => 'aaaa''b' => 'bbbb''c' => 'cccc'); 
  13. while (list($key$value) = each($test01)) { 
  14.     echo "$key => $value" . "<br/>"

php中,迭代遍历主要要用到以下函数。

current() 迭代的当前元素。

reset() 重新移动到第一个元素并返回它。

next() 移动到下一个元素并返回它。

prev() 移动到上一个元素并返回它。

end() 移动到最后一个元素并返回它。

each() 以数组的形式返回当前元素的索引和值,并移动到下一个迭代。

key() 返回当前的索引。

array_ walk() 为每一个元素调用函数。

array_ reduce() 为每一个元素依次计算。

变通遍历,代码如下:

  1. array_walk($test01, walk_test); 
  2. function walk_test($key$value) { 
  3.     echo "walk: $key => $value" . "<br/>"
  4.  
  5. $test02 = array(1, 2, 3, 4, 5); 
  6. echo array_reduce($test02, reduce_test); 
  7. function reduce_test($run_result$current_value) { 
  8.     return $run_result + $current_value * $current_value

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表