php中關聯數據用法與一些關聯數組的一些小技巧,包括添加,刪除,編輯,遍歷,交換鍵和值,排序,查詢等等關聯數組的一些實例.
1、添加數組元素
PHP是一種弱類型語言,這意味著你不需要顯示聲明一個數組及其大小,相反,你可以同時聲明并填充數組,代碼如下:
- $capitals = array(
- 'Alabama' => 'Montgomery',
- 'Alaska' => 'Juneau',
- 'Arizona' => 'Phoenix'
- );
額外的數組元素可以象下面這樣追加:
$capitals['Arkansas'] = 'Little Rock'; 如果你正在處理數字索引數組,你可能想使用顯示命名的函數前置和追加元素,如array_push()和array_unshift()函數,但這些函數不能操作關聯數組.
2、刪除數組元素
如果要從數組中刪除一個元素,請使用unset()函數,代碼如下:
unset($capitals['California']);
使用數字索引數組時,刪除數組元素的辦法更多,更靈活,可以使用array_shift()和array_pop()函數分別從數組的開頭和末尾刪除一個元素.
3、交換鍵和值
假設你想創建一個名叫$states的新數組,使用州府作為索引,使用州名作為關聯值,使用array_flip()函數很容易完成這個任務,代碼如下:
- $capitals = array(
- 'Alabama' => 'Montgomery',
- 'Alaska' => 'Juneau',
- 'Arizona' => 'Phoenix'
- );
- $states = array_flip($capitals);
- // $states = array(
- // 'Montgomery' => string 'Alabama',
- // 'Juneau' => string 'Alaska',
- // 'Phoenix' => string 'Arizona'
- // );
4、合并數組
假設前面的數組由一個基于Web的“FlashCard”服務使用,你想提供一種方法測試學生對美國各州首府的掌握情況,你可以使用array_merge()函數合并包含州和首府的數組,代碼如下:
- $stateCapitals = array(
- 'Alabama' => 'Montgomery',
- 'Alaska' => 'Juneau',
- 'Arizona' => 'Phoenix'
- );
- $countryCapitals = array (
- 'Australia' => 'Canberra',
- 'Austria' => 'Vienna',
- 'Algeria' => 'Algiers'
- );
- $capitals = array_merge($stateCapitals, $countryCapitals);
5、編輯數組值
假設在數組中的數據包含大小寫錯誤,在插入到數據庫之前,你想糾正這些錯誤,你可以使用array_map()函數給每個數組元素應用一個回調,代碼如下:
- function capitalize($element)
- {
- $element = strtolower($element);
- return ucwords($element);
- }
- $capitals = array(
- 'Alabama' => 'montGoMEry',
- 'Alaska' => 'Juneau',
- 'Arizona' => 'phoeniX'
- );
- $capitals = array_map("capitalize", $capitals);
6、按鍵對數組排序
FlashCard程序常常使用各種排序,如按字母順序排序,你可以使用ksort()函數按鍵對關聯數組進行排序,代碼如下:
- $capitals = array(
- 'Arizona' => 'Phoenix',
- 'Alaska' => 'Juneau',
- 'Alabama' => 'Montgomery'
- );
- ksort($capitals);
因為數組是通過參數傳遞給ksort()函數的,意味著你不再需要將排序結果分配給另一個變量.
7、隨機數組排序
在FlashCard程序中還涉及到另一種隨機排序技術,這時你要使用shuffle()函數實現數組項目的隨機排序,代碼如下:
- $capitals = array(
- 'Arizona' => 'Phoenix',
- 'Alaska' => 'Juneau',
- 'Alabama' => 'Montgomery'
- );
- shuffle($capitals);
如果不需要打亂數組順序,你只是想隨機選擇一個值,那么使用array_rand()函數即可.
8、確定鍵和值是否存在
你可以使用in_array()函數確定一個數組元素是否存在,代碼如下:
- $capitals = array(
- 'Arizona' => 'Phoenix',
- 'Alaska' => 'Juneau',
- 'Alabama' => 'Montgomery'
- );
- if (in_array("Juneau", $capitals))
- {
- echo "Exists!";
- } else {
- echo "Does not exist!";
- }
很少有人知道這個函數也可以確定一個數組鍵是否存在,在這一點上,它和array_key_exists()函數的功能一樣,代碼如下:
- $capitals = array(
- 'Arizona' => 'Phoenix',
- 'Alaska' => 'Juneau',
- 'Alabama' => 'Montgomery'
- );
- if (array_key_exists("Alaska", $capitals))
- {
- echo "Key exists!";
- } else {
- echo "Key does not exist!";
- }
9、搜索數組
你可能想搜索數組資源,這樣用戶就可以方便地用一個特定的州府檢索關聯的州,可以通過array_search()函數實現數組搜索,代碼如下:
- $capitals = array(
- 'Arizona' => 'Phoenix',
- 'Alaska' => 'Juneau',
- 'Alabama' => 'Montgomery'
- );
- $state = array_search('Juneau', $capitals);
- // $state = 'Alaska'
10、標準PHP庫
標準PHP庫(Standard PHP Library,SPL)為開發人員提供了許多數據結構,迭代器,接口,異常和其它以前PHP語言沒有的功能,使用這些功能可以通過面向對象的語法遍歷數組,代碼如下:
- $capitals = array(
- 'Arizona' => 'Phoenix',
- 'Alaska' => 'Juneau',
- 'Alabama' => 'Montgomery'
- );
- $arrayObject = new ArrayObject($capitals);
- foreach ($arrayObject as $state => $capital)
- {
- printf("The capital of %s is %s<br />", $state, $capital);
- }
- // The capital of Arizona is Phoenix
- // The capital of Alaska is Juneau
- // The capital of Alabama is Montgomery
遍歷關聯數組的三種方法:
foreach,代碼如下:
- <?php
- $sports = array(
- 'football' => 'good',
- 'swimming' => 'very well',
- 'running' => 'not good'
- );
- foreach ($sports as $key => $value) {
- echo $key.": ".$value."<br />";
- }
- ?>
- /*
- 程序運行結果:
- football: good
- swimming: very well
- running: not good
- */
each,代碼如下:
- <?php
- $sports = array(
- 'football' => 'good',
- 'swimming' => 'very well',
- 'running' => 'not good'
- );
- while ($elem = each($sports)) {
- echo $elem['key'].": ".$elem['value']."<br />";
- }
- ?>
- /*
- 程序運行結果:
- football: good
- swimming: very well
- running: not good
- */
list & each,代碼如下:
- <?php
- $sports = array(
- 'football' => 'good',
- 'swimming' => 'very well',
- 'running' => 'not good'
- );
- while (list($key, $value) = each($sports)) {
- echo $key.": ".$value."<br />";
- }
- ?>
- /*
- 程序運行結果:
- football: good
- swimming: very well
- running: not good
- */
哈希表== Hash Table
有一份用戶名列表,存儲了 10000 個用戶名,沒有重復項;
還有一份黑名單列表,存儲了 2000 個用戶名,格式與用戶名列表相同;
現在需要從用戶名列表中刪除處在黑名單里的用戶名,要求用盡量快的時間處理.
這個問題是一個小規模的處理量,如果實際一點,2 個表都可能很大,比如有 2 億條記錄.
我最開始想到的方法,就是做一個嵌套的循環,設用戶名表有 M 條記錄,黑名單列表有 N 條記錄,那么,循環的次數是 M * N 次.
PHP 版代碼:
- <?php
- foreach($arrayM as $keyM => $nameM) {
- foreach($arrayN as $nameN) {
- if ($nameM == $nameN) {
- // 本行執行了 M * N 次!
- unset($arrayM[$keyM]);
- }
- }
- }
- return $arrayM;
- ?>
另一種方式,利用數組索引.
PHP 是一種弱類型的語言,不像 C 語言那樣有嚴格的變量類型限制,C 語言的數組,每一個元素的類型必須一致,而且索引都是從 0 開始.
PHP 的數組,可以用字符串作為索引,也稱為關聯數組.
數組索引,有一個天然的限制就是不會重復,而且訪問的時候不需要查找,可以直接定位.
還是剛才的那個問題,我們采用另一種辦法,把黑名單列表的用戶名組織到一個數組里,數組的索引就是用戶名,然后,遍歷用戶列表的時候,只需直接用 isset 查詢那個用戶名是否存在即可,代碼如下:
- <?php
- $arrayHash = array();
- foreach($arrayN as $nameN) {
- // 本行執行了 N 次。
- $arrayHash[$nameN] = 1;
- }
- foreach($arrayM as $keyM => $nameM) {
- if (isset($arrayHash[$nameM])) {
- // 本行執行了 M 次!
- unset($arrayM[$keyM]);
- }
- }
- return $arrayM;
- ?>
可以看到,優化過的代碼,循環次數是 M + N 次.
假如 M 和 N 都是 10000,優化前,循環了 1 億次,優化后,只循環了 20000 次,差了 5000 倍,如果第二個程序耗時 1 秒,則第一個程序需要將近一個半小時.
新聞熱點
疑難解答