用戶自定義的比較函數對數組中的值進行排序(function中有兩個參數,0表示相等,正數表示第一個大於第二個,負數表示第一個小於第二個)保留鍵名的數組排序
經過鍵名對數組排序
ksort($arr);按照鍵名正序排序
krsort($arr);按照鍵名逆序排序
uksort($arr,"function");使用用戶自定義的比較函數對數組中的鍵名進行排序(function中有兩個參數,0表示相等,正數表示第一個大於第二個,負數表示第一個小於第二個)
天然排序法排序
natsort($arr);天然排序(忽略鍵名)
natcasesort($arr);天然排序(忽略大小寫,忽略鍵名)
7、數組的計算
數組元素的求和
array_sum($arr);對數組內部的全部元素作求和運算
數組的合併
array_merge($arr1,$arr2);合併兩個或多個數組(相同的字符串鍵名,後面的覆蓋前面的,相同的數字鍵名,後面的不會作覆蓋操做,而是附加到後面)
「+」$arr1+$arr2;對於相同的鍵名只保留後一個
array_merge_recursive($arr1,$arr2); 遞歸合併操做,若是數組中有相同的字符串鍵名,這些值將被合併到一個數組中去。若是一個值自己是一個數組,將按照相應的鍵名把它合併爲另外一個數組。當數組 具備相同的數組鍵名時,後一個值將不會覆蓋原來的值,而是附加到後面
數組的差集
array_diff($arr1,$arr2);返回差集結果數組
array_diff_assoc($arr1,$arr2,$arr3);返回差集結果數組,鍵名也作比較
數組的交集
array_intersect($arr1,$arr2);返回交集結果數組
array_intersect_assoc($arr1,$arr2);返回交集結果數組,鍵名也作比較
8、其餘的數組函數
range(0,12);建立一個包含指定範圍單元的數組
array_unique($arr);移除數組中重複的值,新的數組中會保留原始的鍵名
array_reverse($arr,TRUE);返回一個單元順序與原數組相反的數組,若是第二個參數爲TRUE保留原來的鍵名
//srand((float)microtime()*10000000); 隨機種子觸發器
array_rand($arr,2);從數組中隨機取出一個或 多個元素
shuffle($arr);將數組的順序打亂
本類函數容許用多種方法來操做數組和與之交互。數組的本質是儲存,管理和操做一組變量。
PHP 支持一維和多維數組,能夠是用戶建立或由另外一個函數建立。有一些特定的數據庫處理函數能夠從數據庫查詢中生成數組,還有一些函數返回數組。
array_change_key_case — 返回字符串鍵名全爲小寫或大寫的數組
array_chunk — 將一個數組分割成多個
array_combine — 建立一個數組,用一個數組的值做爲其鍵名,另外一個數組的值做爲其值
array_count_values — 統計數組中全部的值出現的次數
array_diff_assoc — 帶索引檢查計算數組的差集
array_diff_key — 使用鍵名比較計算數組的差集
array_diff_uassoc — 用用戶提供的回調函數作索引檢查來計算數組的差集
array_diff_ukey — 用回調函數對鍵名比較計算數組的差集
array_diff — 計算數組的差集
array_fill_keys — Fill an array with values, specifying keys
array_fill — 用給定的值填充數組
array_filter — 用回調函數過濾數組中的單元
array_flip — 交換數組中的鍵和值
array_intersect_assoc — 帶索引檢查計算數組的交集
array_intersect_key — 使用鍵名比較計算數組的交集
array_intersect_uassoc — 帶索引檢查計算數組的交集,用回調函數比較索引
array_intersect_ukey — 用回調函數比較鍵名來計算數組的交集
array_intersect — 計算數組的交集
array_key_exists — 檢查給定的鍵名或索引是否存在於數組中
array_keys — 返回數組中全部的鍵名
array_map — 將回調函數做用到給定數組的單元上
array_merge_recursive — 遞歸地合併一個或多個數組
array_merge — 合併一個或多個數組
array_multisort — 對多個數組或多維數組進行排序
array_pad — 用值將數組填補到指定長度
array_pop — 將數組最後一個單元彈出(出棧)
array_product — 計算數組中全部值的乘積
array_push — 將一個或多個單元壓入數組的末尾(入棧)
array_rand — 從數組中隨機取出一個或多個單元
array_reduce — 用回調函數迭代地將數組簡化爲單一的值
array_reverse — 返回一個單元順序相反的數組
array_search — 在數組中搜索給定的值,若是成功則返回相應的鍵名
array_shift — 將數組開頭的單元移出數組
array_slice — 從數組中取出一段
array_splice — 把數組中的一部分去掉並用其它值取代
array_sum — 計算數組中全部值的和
array_udiff_assoc — 帶索引檢查計算數組的差集,用回調函數比較數據
array_udiff_uassoc — 帶索引檢查計算數組的差集,用回調函數比較數據和索引
array_udiff — 用回調函數比較數據來計算數組的差集
array_uintersect_assoc — 帶索引檢查計算數組的交集,用回調函數比較數據
array_uintersect_uassoc — 帶索引檢查計算數組的交集,用回調函數比較數據和索引
array_uintersect — 計算數組的交集,用回調函數比較數據
array_unique — 移除數組中重複的值
array_unshift — 在數組開頭插入一個或多個單元
array_values — 返回數組中全部的值
array_walk_recursive — 對數組中的每一個成員遞歸地應用用戶函數
array_walk — 對數組中的每一個成員應用用戶函數
array — 新建一個數組
arsort — 對數組進行逆向排序並保持索引關係
asort — 對數組進行排序並保持索引關係
compact — 創建一個數組,包括變量名和它們的值
count — 計算數組中的單元數目或對象中的屬性個數
current — 返回數組中的當前單元
each — 返回數組中當前的鍵/值對並將數組指針向前移動一步
end — 將數組的內部指針指向最後一個單元
extract — 從數組中將變量導入到當前的符號表
in_array — 檢查數組中是否存在某個值
key — 從關聯數組中取得鍵名
krsort — 對數組按照鍵名逆向排序
ksort — 對數組按照鍵名排序
list — 把數組中的值賦給一些變量
natcasesort — 用「天然排序」算法對數組進行不區分大小寫字母的排序
natsort — 用「天然排序」算法對數組排序
next — 將數組中的內部指針向前移動一位
pos — current() 的別名
prev — 將數組的內部指針倒回一位
range — 創建一個包含指定範圍單元的數組
reset — 將數組的內部指針指向第一個單元
rsort — 對數組逆向排序
shuffle — 將數組打亂
sizeof — count() 的別名
sort — 對數組排序
uasort — 使用用戶自定義的比較函數對數組中的值進行排序並保持索引關聯
uksort — 使用用戶自定義的比較函數對數組中的鍵名進行排序
usort — 使用用戶自定義的比較函數對數組中的值進行排序
使用數組
在前面的章節中,咱們所介紹的變量都是標量變量,這些變量只能存儲單個數據。數組是一個能夠存儲一組或一系列數值的變量。一個數組能夠具備許多個元素。每一個元素有一個值,例如文本、數字或另外一個數組。一個包含其餘數組的數組稱爲多維數組。
3.1 什麼是數組
一個標量變量就是一個用來存儲數值的命名區域。一樣,一個數組就是一個用來存儲一系列變量值的命名區域,所以,可使用數組組織標量變量。
存儲在數組中的值稱爲數組元素。每一個數組元素有一個相關的索引(也稱爲關鍵字),它能夠用來訪問元素。在大多數編程語言中,數組都具備數字索引,並且這些索個一般是從0或1開始的。
3.2 數字索引數組
在PHP中,數字索引的默認值是從0開始的,固然也能夠改變它。
3.2.1 數字索引數組的初始化
$porducts = array( 'Tires', 'Oil', 'Spark Plugs' );
就像echo語句同樣,array()其實是一個語言結構,而不是一個函數。
根據對數組內容的需求不一樣,可能不須要再像以上例子同樣對它們進行手工的初始化操做。若是所需數據保存在另外一個數組中,可使用運算符「=」簡單地將數組複製到另外一個數組。
若是須要將按升序排列的數字保存在一個數組中,可使用range()函數自動建立這個數組。以下這行代碼將建立一個從1到10的數字數組:$numbers = range(1,10);
range()函數具備一個可選的第三個參數,這個參數容許設定值之間的步驟。例如,如需創建一個1到10之間的奇數數組,可使用以下代碼:$odds = range(1,10,2);
range()函數也能夠對字符進行操做,如:$letters = range('a', 'z');
3.2.2 訪問數組的內容
要訪問一個變量的內容,能夠直接使用其名稱。若是該變量是一個數組,可使用變量名稱和關鍵字或索引的組合來訪問其內容。關鍵字或索引將指定咱們要訪問的變量。索引在變量名稱後面用方括號括起來。
在默認的狀況下,0元素是數組的第一個元素。
請注意,雖然PHP的字符串解析功能很是強大和智能,可是可能會引發混淆。當你將數組或其餘變量嵌入雙引號中的字符串時,若是不能正確解釋它們,能夠將它們放置在雙引號以外,或者查找第4章的「字符串操做與正則表達式」得到更復雜的語法。
就像PHP的其餘變量同樣,數組不須要預先初始化或建立。在第一次使用它們的時候,它們會自動建立。
3.2.3. 使用循環訪問數組
因爲數組使用有序的數字做爲索引,因此使用一個for循環就能夠很容易地顯示數組的內容。
for ($i=0; $i<3; $i++)
echo "$products[$i]";
使用一個簡單的循環就能夠訪問每一個元素是數字索引數組的一個很是好的特性。也可使用foreach循環,這個循環語句是專門爲數組而設計的。如:
foreach ($products as $current)
echo $current. ' ';
3.3 使用不一樣索引的數組
PHP還支持相關數組。在相關數組中,能夠將每一個變量值與任何關鍵字或索引關聯起來。
3.3.1 初始化相關數組
以下所示的代碼能夠建立一個以產品名稱做爲關鍵字、以價格做爲值的相關數組:
$prices = array( 'Tires'=>100, 'Oil'=>10, 'Spark Plugs'=>4 );
關鍵字和值之間的符號只是一個大於號與等於符號。
3.3.2 訪問數組元素
一樣,可使用變量名稱和關鍵字來訪問數組的內容。例如$prices['Tires']。
3.3.3 使用循環語句
由於相關數組的索引不是數字,所以沒法在for循環語句中使用一個簡單的計數器對數組進行操做。可是可使用foreach循環或list()和each()結構。
當使用foreach循環語句對相關數組進行操做時,foreach()循環具備不一樣的結構。能夠按以下方式使用關鍵字:
foreach ($prices as $key => $value)
echo $key.'=>'.$value.'<br />';
以下所示的代碼將使用each()結構打印$prices數組的內容:
while( $element = each($prices))
{
echo $element['key'];
echo ' - ';
echo $element['value'];
echo '<br />';
}
each()函數將返回數組的當前元素,並將下一個元素做爲當前元素。由於在while循環中調用each()函數,它將按順序返回數組中每一個元素,而且當它到達數組末尾時,循環操做將終止。
在 這段代碼中,變量$element是一個數組。當調用each()時,它將返回一個帶有4個數值和4個指向數組位置的索引的數組。位置key和0包含了當 前元素的關鍵字,而位置value和1包含了當前元素的值。雖然這與選哪種方法沒什麼不一樣,但咱們選擇了使用命名位置,而不是數字索引位置。
此外,還有一種更爲高級和常見的方式來完成相同的操做。函數list()能夠用來將一個數組分解爲一系列的值。能夠按照以下方式將函數each()返回的兩個值分開:list( $product, $price) = each( $price);
以上代碼使用each()從$prices數組中取出當前元素,而且將它做爲數組返回,而後再指向下一個元素。它還使用list()將從each()返回的數組中所包含0、1兩個元素變爲兩個名爲$product和$price的新蠻量。
咱們能夠循環遍歷整個$prices數組,使用以下所示的簡短腳本顯示它的內容:
while(list($prodct, $pirce) = each($prices))
echo "$product - $price<br />";
這段代碼的輸出結果與前面腳本的輸出結果相同,但它更容易閱讀,由於list()容許爲新變量命名。
須要注意的一點是,當使用each()函數時,數組將記錄當前元素。若是但願在相同的腳本中兩次使用該數組,就必須使用函數reset()將當前元素從新設置到數組開始處。要再次遍歷prices數組,可使用以下所示的代碼:
reset($prices);
while(list($product, $price) = each($prices))
echo "$product - $price<br />";
3.4 數組操做符
+聯合,==等價,===恆等,!=不等價,<>不等價,!==不恆等。
聯合操做符嘗試將$b中的元素添加到$a的末尾。若是$b中的元素與$a中的一些元素具備相同的索引,它們將不會被添加。即$a中的元素將不會被覆蓋。
3.5 多維數組
數組不必定就是一個關鍵字和值的簡單列表——數組中的每一個位置還能夠保存另外一個數組。使用這種方法,能夠建立一個二維數組。能夠把二維數組當成一個矩陣,或者是一個具備寬度和高度或者行和列的網絡。
3.6 數組排序
3.6.1 使用sort()函數
sort()函數是區分字母大小寫的。全部的你們字母都在小寫字母的前面。因此‘A’小於‘Z’,而'Z'小於‘a’。
該 函數的第二個參數是可選的。這個可選參數能夠傳遞SORT_REGULAR(默認值)、SORT_NUMERIC或SORT_STRING。指定排序類型 的功能是很是有用的,例如,當要比較可能包含有數字2和12的字符串時。從數學角度看,2要小於12,可是做爲字符串,‘12’卻要小於‘2’。
3.6.2 使用asort()函數和ksort()函數對相關數組排序
函數asort()根據數組的每一個元素值進行排序。ksort()函數是按關鍵字排序而不是按值排序。
3.6.3 反向排序
函數rsort()將一個一維數字索引數組按降序排序。函數arsort()將一個一維相關數組按每一個元素值的降序排序。函數krsort()針根據數組元素的關鍵字將一維數組按照降序排序。
爲了訪問一個一維數組中的數據,須要使用數組的名稱和元素的索引,除了一個元素具備兩個索引——行和列外,二維數組和一維數組是相似的。
可使用雙重for循環來實現一樣的效果:
for ( $row=0; $row<3; $row++ )
{
for ( $column=0; $column<3; $column++ )
{
echo '|'.$products[$row][$column];
|
echo '|<br />';
}
若是對一個大數組使用這種代碼,那麼將簡潔得多。
你可能更喜歡建立列名稱來代替數字。可使用以下代碼:
$products = array ( array ( 'Code'=>'TIR', 'Descrīption'=>'Tires', 'Price'=>100 ), array ( 'Code'=>'OIL', 'Descrīption'=>'Oil', 'Price'=>10 ), array ( 'Code'=>'SPK', 'Descrīption'=>'Spark Plugs', 'Price'=>4 ) };
若是但願檢索單個值,那麼使用這個數組會容易得多。請記住,將所描述的內容保存到用它的名 稱命名的列中,與將其保存到所謂的第一列中相比,前者更容易記憶。使用描述性索引,不須要記住某個元素是存放在[x][y]位置的。使用一對有意義的行和 列的名稱做爲索引可使用你很容易找到所需的數據。
而後,咱們卻不能使用一個簡單的for循環按順序遍歷每一列。可使用for循環遍歷外部的數 字索引數組$products。$products數組的每一行都是一個具備描述性索引的數組。在while循環中使用each()和list()函數, 能夠遍歷整個內部數組。所以,須要一個內嵌有while循環的for循環。
for ( $row = 0; $row < 3; $row++ }
{
while ( list ( $key, $value ) = each ( $products[$row] ) )
{
echo "|$value";
}
echo '|<br />';
}
三維數組具備高、寬、深的概念。若是能輕鬆地將一個二維數組想像成一個有行和列的表格,那麼就能夠將三維數組想像成一堆像這樣的表格。每一個元素能夠經過層、行和列進行引用。
根據建立多維數組的方法,能夠建立四維、五維或六維數組。在PHP中,並無設置數組維數的限制,但人們很難設想一個多於三維的數組。大多數的實際問題在邏輯上只須要使用三維或者更少維的數組結構就能夠了。
3.7 多維數組的排序
對 多於一維的數組進行排序,或者不按字母和數字的順序進行排,要複雜得多。PHP知道如何比較兩個數字或字符串,但在多維數組中,每一個元素都是一個數組。 PHP不知道如何比較兩個數組,因此須要創建一個比較它們的方法。在大多數狀況下,單詞和數字的順序是顯而易見的——但對於複雜的對象,問題就會多一些。
3.7.1 用戶定義排序
usort()中的「u」表明「user」,由於這個函數要求傳入用戶定義的比較函數。asort和ksort對應的版本uasort()和uksort()也要求傳入用戶定義的比較函數。
相似於asort(),當對非數字索引數組的值進行排序時,uasort()纔會被使用。若是值是簡單的數字或文本則可使用asort。若是要比較的值像數組同樣複雜,能夠定義一個比較函數,而後使用uasort()。
相似於ksort(),當對非數字索引數組的關鍵字進行排序時才使用uksort()。若是值是簡單的數字或文本就使用ksort。若是要比較的對象像數組同樣複雜,能夠定義一個比較函數,而後使用uksort()。
3.7.2 反向用戶排序
函數sort()、asort()和ksort()都分別對應一個帶字母「r」的反向排序函數。用戶定義的排序沒有反向變體,但能夠對一個多維數組進行反向排序。
3.8 對數組進行從新排序
3.8.1 使用shuffle()函數
在PHP的早期版本中,shuffle()要求調用srand()函數時首先提供一個隨機數生成器。現在,這個步驟已經再也不須要了。
若是這個函數對你很是重要,能夠在程序中應用該函數以前在服務器上測試它。
因爲並不須要真正從新排序整個數組,使用array_rand()函數能夠實現相同的功能。
3.8.2 使用array_reverse()函數
array_reverse()函數使用一個數組做參數,返回一個內容與參數數組相同但順序相反的數組。
由於單獨使用range()函數將建立一個升序序列,因此必須使用sort()函數或array_reverse()函數將數組中的數字變爲降序。或者,也可使用for循環經過一次一個元素的方式建立這個數組。如:
$numbers = array();
for ($i=10; $i>0; $i--)
array_push( $numbers, $i );
一個for循環能夠像這樣按降序方式運行。能夠將計數器
一個for循環能夠像這樣按降序方式運行。能夠將計數器的初始值設爲一個大數,在每次循環末尾使用運算符「--」將計數器減1。
在這裏,咱們建立了一個空數組,而後使用array_push()函數將每一個新元素添加到數組的末尾。請注意,和array_push()相反的函數是array_pop(),這個函數用來刪除並返回數組末尾的一個元素。
或者,也可使用array_reverse()函數將由range()函數所建立的數組進行反向排序。
請注意,array_reverse()函數將返回一個原數組修改後的副本。若是再也不須要原來的數組,好比在這個例子中,能夠用新的副本覆蓋原來的版本。
若是數據只是一系列的整數,能夠經過將-1做爲range()函數的第三個可選調參數,以相反的順序建立該數組。
3.9 從文件載入數組
使用file()函數將整個文件載入一個數組中。文件中的每行則成爲數組中的一個元素。使用了count()函數來統計數組中的元素個數。
explode("\t", $orders[$i])
explode()函數能夠將傳入的字符串分割成一個個小塊。每一個製表符成爲兩個元素之間的斷點。這個函數的可選參數limit能夠用來限制被返回的最大塊數。
可使用許多方法從字符串中提取數字。在這裏,咱們使用了intval()函數。它能夠將一個字符串轉化成一個整數。這個轉換是至關智能化的,它能夠忽略某些部分,例如標籤就不能轉換成數字。
3.10 執行其餘的數組操做
3.10.1 在數組中瀏覽:each()、current()、reset()、end()、next()、pos()和prev()
前面已經提到,每一個數組都有一個內部指針指向數組中的當前元素。當使用函數each()時,就間接地使用了這個指針,可是也能夠直接使用和操做這個指針。
若是建立一個新數組,那麼當前指針就將被初始化,並指向數組的第一個元素。
調用next()或each()將使指針前移一個元素。調用each($array_name)會在指針前移一個位置以前返回當前元素。next()函數則有些不一樣——調用next($array_name)是將指針前移,而後再返回新的當前元素。
調用end($array_name)能夠將指針移到數組末尾。
要反向遍歷一個數組,可使用end()和prev()函數。prev()函數和next()函數相反。它是將當前指針往回移一個位置而後再返回新的當前元素。
3.10.2 對數組的每個元素應用任何函數:array_walk()
array_walk()函數須要三個參數。第一個是arr,也就是須要處理的數組。第二個是func,也就是用戶自定義並將做用於數組中每一個元素的函數。第三個參數userdata是可選的,若是使用它,它能夠做爲一個參數傳遞給咱們本身的函數。
看一個銷微複雜點的例子:
function my_multiply(&$value, $key, $factor)
{
$value *= $factor;
}
array_walk(&$array, 'my_multiply', 3);
在這裏,咱們定義了一個名爲my_multiply()的函數,它能夠用所提供的乘法因子去乘以數組中的每一個元素。
此外,還有一個須要注意的問題是傳遞毿數$value的方式。在my_multiply()的函數定義中,變量前面的地址符(&)意味着$value是按引用方式傳遞的。按引用方式傳遞容許函數修改數組的內容。
3.10.3 統計數組元素個數:count()、sizeof()和array_count_values()
count()函數和sizeof()函數具備一樣的用途,均可以返回數組元素的個數。能夠獲得一個常規標量變量中的元素個數,若是傳遞給這個函數的數組是一個空數組,或者是一個沒有通過設定的變量,返回的數組個數就是0。
如 果調用array_count_values($array),這個函數將會統計每一個特定的值在數組$array中出現過的次數(這就是數組的基數集)。 這個函數將返回一個包含頻率表的相關數組。這個數組包含數組$array中的全部值,並以這些值做爲相關數組的關鍵字。每一個關鍵字所對應的數值就是關鍵字 在數組$array中出現的次數。
3.10.4 將數組轉換成標量變量:extract()
對於一個非數字索引數組,而該數組又有許多關鍵字-值對,可使用函數extract()將它們轉換成一系列的標量變量。
函數extract()的做用是經過一個數組建立一系列的標量變量,這些變量的名稱必須是數組中關鍵字的名稱,而變量值則是數組中的值。
extract()函數具備兩個可選參數:extract_type和prefix。變量extract_type將告訴extract()函數如何處理衝突。有時可能已經存在一個和數組關鍵字同名的變量,該函數的默認操做是覆蓋已有的變量。
兩個最經常使用的選項是EXTR_OVERWRITE(默認值)和EXTR_PREFIX_ALL。當知道會發生特定的衝突而且但願跳過該關鍵字或要給它加上前綴時,可能會用到其餘選項。
extract()能夠提取出一個元素,該元素的關鍵字必須是一個有效的變量名稱,這就意味着以數字開始或包含空格的關鍵字將被跳過。正則表達式