摘要:額外的數(shù)組元素可以象下面這樣追加如果你正在處理數(shù)字索引數(shù)組,你可能想使用顯示命名的函數(shù)前置和追加元素,如和函數(shù),但這些函數(shù)不能操作關聯(lián)數(shù)組。
在使用 PHP 進行開發(fā)的過程中,或早或晚,您會需要創(chuàng)建許多相似的變量,這時候你可以把數(shù)據(jù)作為元素存儲在數(shù)組中。數(shù)組中的元素都有自己的 ID,因此可以方便地訪問它們。
關聯(lián)數(shù)組
關聯(lián)數(shù)組,它的每個 ID 鍵都關聯(lián)一個值。在存儲有關具體命名的值的數(shù)據(jù)時,使用數(shù)值數(shù)組不是最好的做法。通過關聯(lián)數(shù)組,我們可以把值作為鍵,并向它們賦值。
這里介紹10個操作PHP關聯(lián)數(shù)組的技巧,熟練運用能幫助你提高開發(fā)效率。
1、添加數(shù)組元素
PHP是一種弱類型語言,這意味著你不需要顯示聲明一個數(shù)組及其大小,相反,你可以同時聲明并填充數(shù)組。
$capitals = array(
"Alabama" => "Montgomery",
"Alaska" => "Juneau",
"Arizona" => "Phoenix"
);
額外的數(shù)組元素可以象下面這樣追加:
1
1$capitals["Arkansas"] = "Little Rock";
如果你正在處理數(shù)字索引數(shù)組,你可能想使用顯示命名的函數(shù)前置和追加元素,如array_push()和array_unshift()函數(shù),但這些函數(shù)不能操作關聯(lián)數(shù)組。
2、刪除數(shù)組元素
如果要從數(shù)組中刪除一個元素,請使用unset()函數(shù),如:
unset($capitals["California"]);
使用數(shù)字索引數(shù)組時,刪除數(shù)組元素的辦法更多,更靈活,可以使用array_shift()和array_pop()函數(shù)分別從數(shù)組的開頭和末尾刪除一個元素。
3、交換鍵和值
假設你想創(chuàng)建一個名叫$states的新數(shù)組,使用州府作為索引,使用州名作為關聯(lián)值,使用array_flip()函數(shù)很容易完成這個任務。
$capitals = array(
"Alabama" => "Montgomery",
"Alaska" => "Juneau",
"Arizona" => "Phoenix"
);
$states = array_flip($capitals);
// $states = array(
// "Montgomery" => string "Alabama",
// "Juneau" => string "Alaska",
// "Phoenix" => string "Arizona"
// );
4、合并數(shù)組
假設前面的數(shù)組由一個基于Web的“FlashCard”服務使用,你想提供一種方法測試學生對美國各州首府的掌握情況,你可以使用array_merge()函數(shù)合并包含州和首府的數(shù)組。
$stateCapitals = array(
"Alabama" => "Montgomery",
"Alaska" => "Juneau",
"Arizona" => "Phoenix"
);
$countryCapitals = array (
"Australia" => "Canberra",
"Austria" => "Vienna",
"Algeria" => "Algiers"
);
$capitals = array_merge($stateCapitals, $countryCapitals);
5、編輯數(shù)組值
假設在數(shù)組中的數(shù)據(jù)包含大小寫錯誤,在插入到數(shù)據(jù)庫之前,你想糾正這些錯誤,你可以使用array_map()函數(shù)給每個數(shù)組元素應用一個回調(diào)。
function capitalize($element)
{
$element = strtolower($element);
return ucwords($element);
}
$capitals = array(
"Alabama" => "montGoMEry",
"Alaska" => "Juneau",
"Arizona" => "phoeniX"
);
$capitals = array_map("capitalize", $capitals);
6、按鍵對數(shù)組排序
FlashCard程序常常使用各種排序,如按字母順序排序,你可以使用ksort()函數(shù)按鍵對關聯(lián)數(shù)組進行排序。
$capitals = array(
"Arizona" => "Phoenix",
"Alaska" => "Juneau",
"Alabama" => "Montgomery"
);
ksort($capitals);
因為數(shù)組是通過參數(shù)傳遞給ksort()函數(shù)的,意味著你不再需要將排序結果分配給另一個變量。
7、隨機數(shù)組排序
在FlashCard程序中還涉及到另一種隨機排序技術,這時你要使用shuffle()函數(shù)實現(xiàn)數(shù)組項目的隨機排序。
$capitals = array(
"Arizona" => "Phoenix",
"Alaska" => "Juneau",
"Alabama" => "Montgomery"
);
shuffle($capitals);
如果不需要打亂數(shù)組順序,你只是想隨機選擇一個值,那么使用array_rand()函數(shù)即可。
8、確定鍵和值是否存在
你可以使用in_array()函數(shù)確定一個數(shù)組元素是否存在。
$capitals = array(
"Arizona" => "Phoenix",
"Alaska" => "Juneau",
"Alabama" => "Montgomery"
);
if (in_array("Juneau", $capitals))
{
echo "Exists!";
} else {
echo "Does not exist!";
}
很少有人知道這個函數(shù)也可以確定一個數(shù)組鍵是否存在,在這一點上,它和array_key_exists()函數(shù)的功能一樣。
$capitals = array(
"Arizona" => "Phoenix",
"Alaska" => "Juneau",
"Alabama" => "Montgomery"
);
if (array_key_exists("Alaska", $capitals))
{
echo "Key exists!";
} else {
echo "Key does not exist!";
}
9、搜索數(shù)組
你可能想搜索數(shù)組資源,這樣用戶就可以方便地用一個特定的州府檢索關聯(lián)的州,可以通過array_search()函數(shù)實現(xiàn)數(shù)組搜索。
$capitals = array(
"Arizona" => "Phoenix",
"Alaska" => "Juneau",
"Alabama" => "Montgomery"
);
$state = array_search("Juneau", $capitals);
// $state = "Alaska"
10、標準PHP庫
標準PHP庫(Standard PHP Library,SPL)為開發(fā)人員提供了許多數(shù)據(jù)結構,迭代器,接口,異常和其它以前PHP語言沒有的功能,使用這些功能可以通過面向?qū)ο蟮恼Z法遍歷數(shù)組。
$capitals = array(
"Arizona" => "Phoenix",
"Alaska" => "Juneau",
"Alabama" => "Montgomery"
);
$arrayObject = new ArrayObject($capitals);
foreach ($arrayObject as $state => $capital)
{
printf("The capital of %s is %s", $state, $capital);
}
// The capital of Arizona is Phoenix
// The capital of Alaska is Juneau
// The capital of Alabama is Montgomery
文章版權歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.hztianpu.com/yun/22728.html
摘要:良好的排序算法具有進行最少的比較和交換的特征。冒泡排序是一個基于比較的排序算法,被認為是效率最低的排序算法之一?,F(xiàn)在讓我們使用實現(xiàn)冒泡排序算法。插入排序到目前為止,我們已經(jīng)看到了兩種基于比較的排序算法。 預警 本文適合對于排序算法不太了解的新手同學觀看,大佬直接忽略即可。因為考慮到連貫性,所以篇幅較長。老鐵們看完需要大概一個小時,但是從入門到完全理解可能需要10個小時(哈哈哈,以我自己...
摘要:下列的所有排序函數(shù)都是直接作用于數(shù)組本身,而不是返回一個新的有序的數(shù)組。倒序并保持索引關系,按鍵名排序按鍵名倒序使用用戶自定義的比較函數(shù)對數(shù)組中的值進行排序,要排序的數(shù)組需要用一種不尋常的標準進行排序,那么應該使用此函數(shù)。 數(shù)組排序,共13個 函數(shù)中有u的,能自定義比較函數(shù);有k的,按照鍵來排序;有r(reverse)的,倒序;有a(association)的,一定是鍵值關聯(lián),除了r...
摘要:但它融合了和的功能。支持對隨機訪問文件的讀取和寫入。的概述和作為集合的使用了解的概述類表示了一個持久的屬性集??杀4嬖诹髦谢驈牧髦屑虞d。屬性列表中每個鍵及其對應值都是一個字符串。 1_序列流(了解) 1.什么是序列流 序列流可以把多個字節(jié)輸入流整合成一個, 從序列流中讀取數(shù)據(jù)時, 將從被整合的第一個流開始讀, 讀完一個之后繼續(xù)讀第二個, 以此類推. 2.使用方式 整合兩個: S...
摘要:本文的分享主要圍繞以下幾個方面能做什么常見應用場景介紹如何學習語法基礎實戰(zhàn)面向?qū)ο缶幊虒崙?zhàn)練熟基礎小游戲項目的實現(xiàn)與實戰(zhàn)一能做什么一種編程語言往往可以應用于多方面,有些方面比較常用,有些方面極為常用。比如表示是一個空列表。 摘要:Python語言的教程雖然隨處可見,但是忙于日常業(yè)務/學習的你或許:一直想要找個時間學一點,但是又不知道該從何下手?本文將從Python能做什么,如何學習Py...
摘要:語言行為及特征狀態(tài)看不懂任何英語技術,英語文檔,凡事沒有培訓部在搞的,只有英文文檔的東西國內(nèi)一律沒大公司在用,都非主流,排斥英文文檔和新技術,以及各種超出他學習能力范圍的技術。 在撰寫此文前首先必須申明的是本人不鄙視任何一種框架,也無意于挑起PHP框架間的戰(zhàn)爭,更沒有貶低某個框架使用者的用意,本文純粹個人的看法。你可以認為我無知也好,或者裝逼也好,請不要試著在任何情況下,隨便發(fā)起言語的...
閱讀 2437·2021-11-24 10:27
閱讀 3659·2019-08-30 15:55
閱讀 3428·2019-08-30 15:53
閱讀 2408·2019-08-29 17:27
閱讀 1502·2019-08-26 13:47
閱讀 3621·2019-08-26 10:28
閱讀 989·2019-08-23 15:59
閱讀 2934·2019-08-23 15:19