欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP array_multisort()函數(shù)的使用札記

 更新時間:2011年07月03日 21:42:01   作者:  
array_multisort 對多個數(shù)組或多維數(shù)組進行排序的函數(shù),需要的朋友可以參考下。
函數(shù)  bool array_multisort ( array &$arr [, mixed $arg = SORT_ASC [, mixed $arg = SORT_REGULAR [, mixed $...]]] )
參數(shù)說明: 函數(shù)對多個數(shù)組或多維數(shù)組進行排序
第一個參數(shù)是數(shù)組,隨后的每一個參數(shù)可能是數(shù)組,也可能是下面的排序順序標志
SORT_ASC - 默認,按升序排列
SORT_DESC - 按降序排列
隨后可以指定排序的類型
SORT_REGULAR - 默認。將每一項按常規(guī)順序排列。
SORT_NUMERIC - 將每一項按數(shù)字順序排列。
SORT_STRING - 將每一項按字母順序排列。
實例代碼
復制代碼 代碼如下:

$arr1 = array('10', 11, 100, 100, 'a');
$arr2 = array(1, 2, 3, '2', 5);
array_multisort($arr1, $arr2);

結果為:
$arr1
Array ( [0] => 10 [1] => a [2] => 11 [3] => 100 [4] => 100 )
# '10'在與11, 100, 100比較時轉換為整數(shù)10,小于其他三個數(shù)
# '10'在于'a'比較時作為字符串,其第一個字符'1'ascii碼值為49小于‘a'(ascii值為97),所以‘10'為最小元素
# 'a'在于其他三個數(shù)字比較時,轉換為整數(shù)0,小于其他三個數(shù)
$arr2
Array ( [0] => 1 [1] => 5 [2] => 2 [3] => 2 [4] => 3 )
# $arr2元素1與$arr1元素'10'位置對應,所以排在[0]位置
# $arr1[2] => 100, $arr1[3] => 100分別對應$arr2元素3, '2'。3大于'2',所以與2對應的$arr1[2] => 100排序后的下標為
3,與3對應的$arr1[3] => 100排序的下標為4
總結
1.參與排序的數(shù)組元素數(shù)保持一致
2.排序數(shù)組元素位置對應如, ‘10' => 1 , 11 => 2
3.后邊的數(shù)組在前邊數(shù)組的順序的基礎上進行排序
4.前邊的數(shù)組如遇相等的元素則比較后邊的數(shù)組

array_multisort — 對多個數(shù)組或多維數(shù)組進行排序

說明
bool array_multisort ( array $ar1 [, mixed $arg [, mixed $... [, array $... ]]] )
成功時返回 TRUE, 或者在失敗時返回 FALSE.

array_multisort() 可以用來一次對多個數(shù)組進行排序,或者根據(jù)某一維或多維對多維數(shù)組進行排序。

關聯(lián)(string)鍵名保持不變,但數(shù)字鍵名會被重新索引。

輸入數(shù)組被當成一個表的列并以行來排序——這類似于 SQL 的 ORDER BY 子句的功能。第一個數(shù)組是要排序的主要數(shù)組。數(shù)組中的行(值)比較為相同的話就按照下一個輸入數(shù)組中相應值的大小來排序,依此類推。

本函數(shù)的參數(shù)結構有些不同尋常,但是非常靈活。第一個參數(shù)必須是一個數(shù)組。接下來的每個參數(shù)可以是數(shù)組或者是下面列出的排序標志。

排序順序標志:

SORT_ASC - 按照上升順序排序
SORT_DESC - 按照下降順序排序

排序類型標志:

SORT_REGULAR - 將項目按照通常方法比較
SORT_NUMERIC - 將項目按照數(shù)值比較
SORT_STRING - 將項目按照字符串比較

每個數(shù)組之后不能指定兩個同類的排序標志。每個數(shù)組后指定的排序標志僅對該數(shù)組有效 - 在此之前為默認值 SORT_ASC 和 SORT_REGULAR。

#1 對多個數(shù)組排序
復制代碼 代碼如下:

<?php
$ar1 = array("10", 100, 100, "a");
$ar2 = array(1, 3, "2", 1);
array_multisort($ar1, $ar2);
var_dump($ar1);
var_dump($ar2);
?>

本例中經過排序后,第一個數(shù)組將包含 "10","a",100,100。第二個數(shù)組將包含 1,1,"2",3。第二個數(shù)組中的項目順序完全和第一個數(shù)組中相應的項目(100 和 100)順序一致。
復制代碼 代碼如下:

array(4) {
[0]=> string(2) "10"
[1]=> string(1) "a"
[2]=> int(100)
[3]=> int(100)
}
array(4) {
[0]=> int(1)
[1]=> int(1)
[2]=> string(1) "2"
[3]=> int(3)
}

#2 對多維數(shù)組排序
復制代碼 代碼如下:

<?php
$ar = array (array ("10", 100, 100, "a"), array (1, 3, "2", 1));
array_multisort ($ar[0], SORT_ASC, SORT_STRING,
$ar[1], SORT_NUMERIC, SORT_DESC);
?>

本例中經過排序后,第一個數(shù)組將包含 10,100,100,"a"(作為字符串上升排序),第二個數(shù)組將包含 1,3,"2",1(作為數(shù)值下降排序)。

#3 Sorting multi-dimensional array
復制代碼 代碼如下:

<?php
$ar = array(
array("10", 11, 100, 100, "a"),
array( 1, 2, "2", 3, 1)
);
array_multisort($ar[0], SORT_ASC, SORT_STRING,
$ar[1], SORT_NUMERIC, SORT_DESC);
var_dump($ar);
?>

本例中在排序后,第一個數(shù)組將變成 "10",100,100,11,"a"(被當作字符串以升序排列)。第二個數(shù)組將包含 1, 3, "2", 2, 1(被當作數(shù)字以降序排列)。
復制代碼 代碼如下:

array(2) {
[0]=> array(5) {
[0]=> string(2) "10"
[1]=> int(100)
[2]=> int(100)
[3]=> int(11)
[4]=> string(1) "a"
}
[1]=> array(5) {
[0]=> int(1)
[1]=> int(3)
[2]=> string(1) "2"
[3]=> int(2)
[4]=> int(1)
}
}

#4 對數(shù)據(jù)庫結果進行排序
本例中 data 數(shù)組中的每個單元表示一個表中的一行。這是典型的數(shù)據(jù)庫記錄的數(shù)據(jù)集合。

例子中的數(shù)據(jù)如下:

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

數(shù)據(jù)全都存放在名為 data 的數(shù)組中。這通常是通過循環(huán)從數(shù)據(jù)庫取得的結果,例如 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 升序排列。

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

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

// 將數(shù)據(jù)根據(jù) volume 降序排列,根據(jù) edition 升序排列
// 把 $data 作為最后一個參數(shù),以通用鍵排序
array_multisort($volume, SORT_DESC, $edition, SORT_ASC, $data);
?>
數(shù)據(jù)集合現(xiàn)在排好序了,結果如下:

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


Example #5 不區(qū)分大小寫字母排序

SORT_STRING 和 SORT_REGULAR 都是區(qū)分大小寫字母的,大寫字母會排在小寫字母之前。

要進行不區(qū)分大小寫的排序,就要按照原數(shù)組的小寫字母拷貝來排序。
復制代碼 代碼如下:

<?php
$array = array('Alpha', 'atomic', 'Beta', 'bank');
$array_lowercase = array_map('strtolower', $array);

array_multisort($array_lowercase, SORT_ASC, SORT_STRING, $array);

print_r($array);
?>

以上例程會輸出:

Array
(
[0] => Alpha
[1] => atomic
[2] => bank
[3] => Beta
)

【譯者注】本函數(shù)相當有用,為有助于理解,請再看下面這個例子:


Example #6 名次排列
復制代碼 代碼如下:

<?php
$grade = array("score" => array(70, 95, 70.0, 60, "70"),
"name" => array("Zhang San", "Li Si", "Wang Wu",
"Zhao Liu", "Liu Qi"));
array_multisort($grade["score"], SORT_NUMERIC, SORT_DESC,
// 將分數(shù)作為數(shù)值,由高到低排序
$grade["name"], SORT_STRING, SORT_ASC);
// 將名字作為字符串,由小到大排序
var_dump($grade);
?>

以上例程會輸出:

array(2) {
["score"]=>
array(5) {
[0]=>
int(95)
[1]=>
string(2) "70"
[2]=>
float(70)
[3]=>
int(70)
[4]=>
int(60)
}
["name"]=>
array(5) {
[0]=>
string(5) "Li Si"
[1]=>
string(6) "Liu Qi"
[2]=>
string(7) "Wang Wu"
[3]=>
string(9) "Zhang San"
[4]=>
string(8) "Zhao Liu"
}
}
本例中對包含成績的數(shù)組 $grade 按照分數(shù)(score)由高到低進行排序,分數(shù)相同的人則按照名字(name)由小到大排序。排序后李四 95 分為第一名,趙六 60 分為第五名沒有異議。張三、王五和劉七都是 70 分,他們的名次則由其姓名的字母順序排列,Liu 在前,Wang 在后而 Zhang 在最后。為了區(qū)別,三個 70 分分別用了整數(shù),浮點數(shù)和字符串來表示,可以在程序輸出中清楚地看到它們排序的結果。

相關文章

  • PHP中for循環(huán)與foreach的區(qū)別

    PHP中for循環(huán)與foreach的區(qū)別

    本文主要介紹了php中for循環(huán)與foreach的區(qū)別,具有很好的參考價值。下面跟著小編一起來看下吧
    2017-03-03
  • php將csv文件導入到mysql數(shù)據(jù)庫的方法

    php將csv文件導入到mysql數(shù)據(jù)庫的方法

    這篇文章主要介紹了php將csv文件導入到mysql數(shù)據(jù)庫的方法,通過讀取csv文件到數(shù)組再調用while循環(huán)實現(xiàn)插入數(shù)據(jù)到數(shù)據(jù)庫,是非常實用的技巧,需要的朋友可以參考下
    2014-12-12
  • PHP實現(xiàn)求連續(xù)子數(shù)組最大和問題2種解決方法

    PHP實現(xiàn)求連續(xù)子數(shù)組最大和問題2種解決方法

    這篇文章主要介紹了PHP實現(xiàn)求連續(xù)子數(shù)組最大和問題2種解決方法,涉及php針對數(shù)組的遍歷、判斷、運算等相關操作技巧,需要的朋友可以參考下
    2017-12-12
  • php建立Ftp連接的方法

    php建立Ftp連接的方法

    這篇文章主要介紹了php建立Ftp連接的方法,實例分析了php操作FTP的相關函數(shù)及使用技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-03-03
  • PHP中執(zhí)行cmd命令的方法

    PHP中執(zhí)行cmd命令的方法

    這篇文章主要介紹了PHP中執(zhí)行cmd命令的方法,需要的朋友可以參考下
    2014-10-10
  • php實現(xiàn)選擇排序法的代碼示例

    php實現(xiàn)選擇排序法的代碼示例

    選擇排序法是一種簡單的排序算法,其基本思想是每次從未排序的部分中選擇最?。ɑ蜃畲螅┑脑?然后放到已排序部分的末尾,本文給大家介紹了如何使用php實現(xiàn)選擇排序法,感興趣的朋友可以參考下
    2023-11-11
  • PHP獲取表單數(shù)據(jù)與HTML嵌入PHP腳本的實現(xiàn)

    PHP獲取表單數(shù)據(jù)與HTML嵌入PHP腳本的實現(xiàn)

    下面小編就為大家?guī)硪黄狿HP獲取表單數(shù)據(jù)與HTML嵌入PHP腳本的實現(xiàn)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-02-02
  • PHP-FPM運行狀態(tài)的實時查看及監(jiān)控詳解

    PHP-FPM運行狀態(tài)的實時查看及監(jiān)控詳解

    php-fpm和nginx一樣內建了一個狀態(tài)頁,對于想了解php-fpm的狀態(tài)以及監(jiān)控php-fpm非常有幫助。這篇文章就給大家詳細介紹了PHP-FPM運行狀態(tài)的實時查看及監(jiān)控,有需要的朋友們可以參考學習,感興趣的朋友們下面來一起看看吧。
    2016-11-11
  • PHP獲取鏈表中倒數(shù)第K個節(jié)點的方法

    PHP獲取鏈表中倒數(shù)第K個節(jié)點的方法

    這篇文章主要介紹了PHP獲取鏈表中倒數(shù)第K個節(jié)點的方法,涉及php針對鏈表的遍歷、判斷等相關操作技巧,需要的朋友可以參考下
    2018-01-01
  • PHP 危險函數(shù)解釋 分析

    PHP 危險函數(shù)解釋 分析

    在編譯 PHP 時,如無特殊需要,一定禁止編譯生成 CLI 命令行模式的 php 解析支持。
    2009-04-04

最新評論