本文目錄一覽:
- 1、如何對PHP二維數組根據第二維某鍵值去重和排序
- 2、php二維數組自定義排序
- 3、php循環的二維數組如何排序
- 4、php 二維數組的排序問題
- 5、thinkPHP二維數組排序
- 6、PHP中怎麼根據二維數組中的子數組的某個元素進行排序
如何對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二維數組自定義排序
function pSort($arr)
{
$TimeSort = array();
foreach ($arr as $key = $value) {
$TimeSort[$key] = $value[‘age’];
}
asort($TimeSort);
$data = array();
foreach ($TimeSort as $key = $value) {
$data[] = $arr[$key];
}
$i = 0;
foreach ($arr as $k = $v) {
$arr[$k] = $data[$i];
$i++;
}
return $arr;
}
主要部分,你也可以考慮用那個多為數組排序的那個函數,上面這個是我前幾天自己寫的,不知道在你這能用不
php循環的二維數組如何排序
$num=$arr[$a]-18按$num排序其實就是按$arr[$a]來排,只需在循環前對$arr排序就行了。出來的結果自然是按 $num排序
?php
$arr=array(30,15,40,38);
rsort($arr);
for($a=0; $a4; $a++){
$num=$arr[$a]-18;
if($num0){
$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 二維數組的排序問題
對二維數組排序,得用到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
thinkPHP二維數組排序
從兩個不同的表中獲取各自的4條數據,然後整合(array_merge)成一個數組,再根據數據的創建時間降序排序取前4條。
遇到這個要求的時候就不是 ORDER BY 能解決的問題了。因此翻看 PHP 手冊查找到了如下方法,做此筆記。
廢話少說,奉上代碼,清單如下:
[php] view plain copy
?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_dump($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中怎麼根據二維數組中的子數組的某個元素進行排序
//先用array_column 多維數組按照縱向(列)取出
$date = array_column($arr, ‘0’);
//上面得到的結果:array()
//再用array_multisort 結合array_column得到的結果對$arr進行排序
array_multisort($date,SORT_ASC,$arr);
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/243588.html