Code笔记 之 : PHP多维数组排序及分页

实例代码: 
$li= array(
  [0] => array(
  ["id"] => "10689" ,
  ["uid"] =>  "98" ,
  ["add_time"] =>  "1461203204",
  ["user_name"] =>  "wdxwdx" ,
  ["affect_integral"] => "900" ,
  ["active_integral"] =>  "34722" ,
  ["account_integral"] => "39422",
  ["type"] => "2"
  )
  [1] => array(
  ["id"] =>  "10716" ,
  ["uid"] =>  "11" ,
  ["add_time"] => "1461308471" ,
  ["user_name"] =>"尔东" ,
  ["affect_integral"] =>  "1842" ,
  ["active_integral"] =>  "81638" ,
  ["account_integral"] =>  "82138" ,
  ["type"] =>  "2"
  )
  [2] => array(
  ["id"] => "10728" ,
  ["uid"] =>  "213" ,
  ["add_time"] =>  "1461312705" ,
  ["user_name"] => "Hello" ,
  ["affect_integral"] =>  "3" ,
  ["active_integral"] =>  "76253" ,
  ["account_integral"] => "88953" ,
  ["type"] =>"2"
  }
  [3] => array(
  ["id"] => "10724" ,
  ["uid"] =>  "53" ,
  ["add_time"] => "1461312705" ,
  ["user_name"] =>  "奥迪FAS" ,
  ["affect_integral"] => "21" ,
  ["active_integral"] =>  "51748" ,
  ["account_integral"] =>  "85448" ,
  ["type"] =>  "2"
  )
  [4] => array(
  ["id"] => "10707" ,
  ["uid"] =>  "157" ,
  ["add_time"] => "1461221218" ,
  ["user_name"] =>  "阿发梳" ,
  ["affect_integral"] =>  "603" ,
  ["active_integral"] =>  "59542" ,
  ["account_integral"] =>  "67342" ,
  ["type"] =>  "2"
  )
  [5] => array(
  ["id"] => "10243" ,
  ["uid"] =>  "156" ,
  ["add_time"] =>  "1455334647" ,
  ["user_name"] =>  "liqian" ,
  ["affect_integral"] => "-50" ,
  ["active_integral"] =>  "39357" ,
  ["account_integral"] => "47157" ,
  ["type"] => "4"
  )
);
 
//降序排列处理数组
array_multisort($li,SORT_DESC);
$p_firstRow=0;
$p_listRows=10;
//…………
//分页显示处理
$list = array_slice($li,$p_firstRow,$p_listRows);
 
print_r($list);
 
//*****************************//
 
方法解释:
 
array_multisort()函数
 

array_multisort() 函数返回排序数组。您可以输入一个或多个数组。函数先对第一个数组进行排序,接着是其他数组,如果两个或多个值相同,它将对下一个数组进行排序。

注释:字符串键名将被保留,但是数字键名将被重新索引,从 0 开始,并以 1 递增。

注释:您可以在每个数组后设置排序顺序和排序类型参数。如果没有设置,每个数组参数会使用默认值。
 
有时候我们需要对二维数组的某个键的值进行排序,这里就是讨论这个问题。我们可以使用array_multisort()这个函数。array_multisort() 函数对多个数组或多维数组进行排序。

参数中的数组被当成一个表的列并以行来进行排序 - 这类似 SQL 的 ORDER BY 子句的功能。第一个数组是要排序的主要数组。数组中的行(值)比较为相同的话,就会按照下一个输入数组中相应值的大小进行排序,依此类推。

第一个参数是数组,随后的每一个参数可能是数组,也可能是下面的排序顺序标志(排序标志用于更改默认的排列顺序)之一:

  • SORT_ASC - 默认,按升序排列。(A-Z)
  • SORT_DESC - 按降序排列。(Z-A)

随后可以指定排序的类型:

  • SORT_REGULAR - 默认。将每一项按常规顺序排列。
  • SORT_NUMERIC - 将每一项按数字顺序排列。
  • SORT_STRING - 将每一项按字母顺序排列。

语法:array_multisort(array1,sorting order,sorting type,array2,array3...)

  • array1:必需。规定输入的数组。
  • sorting order:可选。规定排列顺序。可能的值是 SORT_ASC 和 SORT_DESC。
  • sorting type:可选。规定排序类型。可能的值是SORT_REGULAR、SORT_NUMERIC和SORT_STRING。
  • array2:可选。规定输入的数组。
  • array3:可选。规定输入的数组。
字符串键名将被保留,但是数字键将被重新索引,从 0 开始,并以 1 递增。可以在每个数组后设置排序顺序和排序类型。如果没有设置,每个数组参数会使用默认值。
 
 
array_slice ()函数
array_slice(array,start,length,preserve)

array_slice() 函数在数组中根据条件取出一段值,并返回。

注释:如果数组有字符串键,所返回的数组将保留键名。
参数描述
array 必需。规定数组。
start

必需。数值。规定取出元素的开始位置。 0 = 第一个元素。

如果该值设置为正数,则从前往后开始取。

如果该值设置为负数,则从后向前取 start 绝对值。 -2 意味着从数组的倒数第二个元素开始。

length

可选。数值。规定被返回数组的长度。

如果该值设置为整数,则返回该数量的元素。

如果该值设置为负数,则函数将在举例数组末端这么远的地方终止取出。

如果该值未设置,则返回从 start 参数设置的位置开始直到数组末端的所有元素。

preserve

可选。规定函数是保留键名还是重置键名。可能的值:

  • true - 保留键名
  • false - 默认。重置键名
 
 
posted @ 2016-06-03 17:29  Anthonylight  阅读(482)  评论(0编辑  收藏  举报