php 根據某個欄位對二維數組這個數組排序

對多個數組或多維數組進行排序可以使用array_multisort()函數
bool array_multisort ( array $ar1 [, mixed $arg [, mixed $... [, array $... ]]] )

成功時返回專 TRUE, 或者在失敗時返回 FALSE.
相關案屬例請參考:https://panxu.net/article/8376.html

Ⅱ thinkPHP二維數組排序

從兩個不同的表中獲取各自的4條數據,然後整合(array_merge)成一個數組,再根據數據的創建時間降序排序取前4條。
遇到這個要求的時候就不是 ORDER BY 能解決的問題了。因此翻看 PHP 手冊查找到了如下方法,做此筆記。
廢話少說,奉上代碼,清單如下:
[php] view plain
<?php
/**
* 二維數組根據某個欄位排序
* 功能:按照用戶的年齡倒序排序
* @author ruxing.li
*/
header('Content-Type:text/html;Charset=utf-8');
$arrUsers = array(
array(
'id' => 1,
'name' => '張三',
'age' => 25,
),
array(
'id' => 2,
'name' => '李四',
'age' => 23,
),
array(
'id' => 3,
'name' => '王五',
'age' => 40,
),
array(
'id' => 4,
'name' => '趙六',
'age' => 31,
),
array(
'id' => 5,
'name' => '黃七',
'age' => 20,
),
);

$sort = array(
'direction' => 'SORT_DESC', //排序順序標志 SORT_DESC 降序;SORT_ASC 升序
'field' => 'age', //排序欄位
);
$arrSort = array();
foreach($arrUsers AS $uniqid => $row){
foreach($row AS $key=>$value){
$arrSort[$key][$uniqid] = $value;
}
}
if($sort['direction']){
array_multisort($arrSort[$sort['field']], constant($sort['direction']), $arrUsers);
}

var_mp($arrUsers);

/*
輸出結果:

array (size=5)
0 =>
array (size=3)
'id' => int 5
'name' => string '黃七' (length=6)
'age' => int 20
1 =>
array (size=3)
'id' => int 2
'name' => string '李四' (length=6)
'age' => int 23
2 =>
array (size=3)
'id' => int 1
'name' => string '張三' (length=6)
'age' => int 25
3 =>
array (size=3)
'id' => int 4
'name' => string '趙六' (length=6)
'age' => int 31
4 =>
array (size=3)
'id' => int 3
'name' => string '王五' (length=6)
'age' => int 40

*/

Ⅲ php循環的二維數組如何排序

$num=$arr[$a]-18按$num排序其實就是按$arr[$a]來排,只需在循環前對$arr排序就行了。出來的結果自然是按 $num排序
<?php
$arr=array(30,15,40,38);

rsort($arr);

for($a=0; $a<4; $a++){
$num=$arr[$a]-18;
if($num>0){
$arr_1=array(array("$arr[$a]","$num"));
$num_1 = array();
foreach ($arr_1 as $arr_2) {
$num_1[] = $arr_2[1];
}
array_multisort( $num_1,SORT_DESC , $arr_1);
print_r($arr_1);
}

}
?>

Ⅳ php二維數組排序

$ary=array(array("ID"=>21,"name"=>"kitty"),array("ID"=>22,"name"=>"sony"),array("ID"=>17,"name"=>"picker"));

for($i=0; $i<count($ary) ;$i++){
for($j=0; $j<$i; $j++){
if($ary[$i]['ID'] > $ary[$j]['ID']){
$temp = $ary[$i]['ID'];
$ary[$i]['ID'] = $ary[$j]['ID'];
$ary[$j]['ID'] = $temp;
}
}
}

Ⅳ php 二維數組的排序問題

對二維數組排序,得用到array_multisort()
下面是從php手冊摘出來的例子.具體請根據你的問題查閱手冊.
=========
數據全都存放在名為 data 的數組中。這通常是通過循環從資料庫取得的結果,例如 mysql_fetch_assoc()。

<?php
$data[] = array('volume' => 67, 'edition' => 2);
$data[] = array('volume' => 86, 'edition' => 1);
$data[] = array('volume' => 85, 'edition' => 6);
$data[] = array('volume' => 98, 'edition' => 2);
$data[] = array('volume' => 86, 'edition' => 6);
$data[] = array('volume' => 67, 'edition' => 7);
?>

本例中將把 volume 降序排列,把 edition 升序排列。

現在有了包含有行的數組,但是 array_multisort() 需要一個包含列的數組,因此用以下代碼來取得列,然後排序。

<?php
// 取得列的列表
foreach ($data as $key => $row) {
$volume[$key] = $row['volume'];
$edition[$key] = $row['edition'];
}

// 將數據根據 volume 降序排列,根據 edition 升序排列
// 把 $data 作為最後一個參數,以通用鍵排序
array_multisort($volume, SORT_DESC, $edition, SORT_ASC, $data);
?>

數據集合現在排好序了,結果如下:

volume | edition
-------+--------
98 | 2
86 | 1
86 | 6
85 | 6
67 | 2
67 | 7

Ⅵ 如何對PHP二維數組根據第二維某鍵值去重和排序

1 需要排序的數組如下:
$array = array(
array('name'=>'手機','brand'=>'諾基亞','price'=>1050),
array('name'=>'筆記本電腦','brand'=>'lenovo','price'=>4300),
array('name'=>'剃須刀','brand'=>'飛利浦','price'=>3100),
array('name'=>'跑步機','brand'=>'三和松石','price'=>4900),
array('name'=>'手錶','brand'=>'卡西歐','price'=>960),
array('name'=>'液晶電視','brand'=>'索尼','price'=>6299),
array('name'=>'激光列印機','brand'=>'惠普','price'=>1200)
);
2 排序的函數:
function arr_sort($array,$key,$order="asc"){//asc是升序 desc是降序
$arr_nums=$arr=array();
foreach($array as $k=>$v){
$arr_nums[$k]=$v[$key];
}
if($order=='asc'){
asort($arr_nums);
}else{
arsort($arr_nums);
}
foreach($arr_nums as $k=>$v){
$arr[$k]=$array[$k];
}
return $arr;
}
3 調用方式:
arr_sort($array,'price');

Ⅶ php 二維數組排序問題 某欄位按照自定義規則排序

復雜的數組排序可以用自定義的排序規則

<?php

$arr=array(
0=>array('id'=>'2014347856','name'=>'張甜','科目'=>'語文','tag'=>'期中考試','成績'=>'142'),
1=>array('id'=>'2014347856','name'=>'張甜','科目'=>'數學','tag'=>'期中考試','成績'=>'98'),
2=>array('id'=>'2014347856','name'=>'張甜','科目'=>'英語','tag'=>'期中考試','成績'=>'118'),
3=>array('id'=>'2014347856','name'=>'張甜','科目'=>'化學','tag'=>'期中考試','成績'=>'78'),
4=>array('id'=>'2014347856','name'=>'張甜','科目'=>'物理','tag'=>'期中考試','成績'=>'132'),
5=>array('id'=>'2014347856','name'=>'張甜','科目'=>'生物','tag'=>'期中考試','成績'=>'115'),
6=>array('id'=>'2014347856','name'=>'張甜','科目'=>'地理','tag'=>'期中考試','成績'=>'99'),
7=>array('id'=>'2014347856','name'=>'張甜','科目'=>'歷史','tag'=>'期中考試','成績'=>'88'),
8=>array('id'=>'2014347856','name'=>'張甜','科目'=>'政治','tag'=>'期中考試','成績'=>'125'),
9=>array('id'=>'2014347880','name'=>'李鳴','科目'=>'語文','tag'=>'期中考試','成績'=>'79'),
10=>array('id'=>'2014347880','name'=>'李鳴','科目'=>'數學','tag'=>'期中考試','成績'=>'148'),
11=>array('id'=>'2014347880','name'=>'李鳴','科目'=>'英語','tag'=>'期中考試','成績'=>'142'),
);
/*自定義排序*/
functionuserSort($a,$b)
{
if($a['name']==$b['name']){
/*排序科目*/
$subjectSort=array('語文','數學','英語','歷史','政治','地理','物理','化學','生物');
foreach($subjectSortas$index=>$item){
if($a['科目']==$item){
$tmp1=$index;
}
if($b['科目']==$item){
$tmp2=$index;
}
}

return$tmp1<$tmp2?-1:1;
}else{
/*排序name*/
$tmpArr=[$a['name'],$b['name']];
sort($tmpArr);

return$a['name']==$tmpArr[0]?-1:1;
}
}

usort($arr,'userSort');

var_mp($arr);

Ⅷ PHP 二維數組內部數組的排序問題

其實和普通排序沒什麼區別的
首先你弄清楚你這個數組的結構
該怎麼寫
你這個是二維數組的形式
那麼就可以這樣寫
$data
=
array(
(1,4,3,5,6),
(2,1,6,7,2),
(5,4,2,5,1),
(4,3,2,2,3),
(7,4,3,5,6),
)
$data[key1][key2]
其中
key1
是行
比如
$data[0]就是指(1,4,3,5,6)
那麼key2
就是指這里的值了
比如說$data[0][1]
就是指的(1,4,3,5,6)中的4
因為php中數組的索引是從0開始的
這樣的話
如果你想按照你的想法去排列的話
那麼就很好實現了
你先想想
不會再說

Ⅸ PHP中如何對二維數組按某個鍵值進行排序

你可以使用來usort這個函數進行源對$a['list']進行處理

usort($a['list'],function($a,$b){ if($a['app_down'] == $b['app_down'])return 0; return $a['app_down']>$b['app_down'] ? 1 : -1; //如果發現結果是升序,1和-1對換下位置,記不太清了});

Ⅹ PHP二維數組怎麼按某個欄位排序

請確定你說的二維數組的樣式,是這樣的?:版

    array('name1'=>'value1','name2'=>'value2');

權或者是這樣的?:

array(
array('name1'=>'value1','name2'=>'value2'),
array('name1'=>'value3','name2'=>'value4')
);