摘要:像其他變量一樣,使用運(yùn)算符可以改變數(shù)組元素的內(nèi)容。數(shù)組的基本操作定義數(shù)組在中聲明數(shù)組的方式主要有兩種用函數(shù)聲明數(shù)組,直接為數(shù)組元素賦值。
概述要訪問一個(gè)變量的內(nèi)容,可以直接使用其名稱。如果該變量是一個(gè)數(shù)組,可以使用變量名稱和關(guān)鍵字或索引的組合來訪問其內(nèi)容。
像其他變量一樣,使用運(yùn)算符=可以改變數(shù)組元素的內(nèi)容。數(shù)組單元可以通過 array[key] 語法來訪問。
數(shù)組的基本操作php定義數(shù)組:
$array = array();
$array["key"] = "values";
?>
在PHP中聲明數(shù)組的方式主要有兩種:
1.用array()函數(shù)聲明數(shù)組,
2.直接為數(shù)組元素賦值。
//array數(shù)組
$users = array("phone","computer","dos","linux");
echo $users;//只會(huì)打印出數(shù)據(jù)類型Array
print_r($users);//Array ( [0] => phone [1] => computer [2] => dos [3] => linux )
$numbers = range(1,5);//創(chuàng)建一個(gè)包含指定范圍的數(shù)組
print_r($numbers);//Array ( [0] => 1 [1] => 2 [2] => 3 [3] => 4 [4] => 5 )
print_r(true);//1
var_dump(false);//bool(false)
//print_r可以把字符串和數(shù)字簡單地打印出來,數(shù)組會(huì)以Array開頭并已鍵值形式表示,print_r輸出布爾值和null的結(jié)果沒有意義,因此用var_dump更合適
//通過循環(huán)來顯示數(shù)組里所有的值
for($i = 0 ;$i < 5;$i++){
echo $users[$i];
echo "
";
}
//通過count/sizeof統(tǒng)計(jì)數(shù)組中單元數(shù)目或?qū)ο笾械膶傩詡€(gè)數(shù)
for($i = 0; $i < count($users);$i++){
echo $users[$i];
echo "
";
}
//還可以通過foreach循環(huán)來遍歷數(shù)組,這種好處在于不需要考慮key
foreach($users as $value){
echo $value."
";//點(diǎn)號(hào)為字符串連接符號(hào)
}
//foreach循環(huán)遍歷 $key => $value;$key和$value是變量名,可以自行設(shè)置
foreach($users as $key => $value){
echo $key."
";//輸出鍵
}
?>
創(chuàng)建自定義鍵的數(shù)組
//創(chuàng)建自定義鍵的數(shù)組
$ceo = array("apple"=>"jobs","microsoft"=>"Nadella","Larry Page","Eric");
//如果不去聲明元素的key,它會(huì)從零開始
print_r($ceo);//Array ( [apple] => jobs [microsoft] => Nadella [0] => Larry Page [1] => Eric )
echo $ceo["apple"];//jobs
//php5.4起的用法
$array = [
"foo" => "bar",
"bar" => "foo",
];
print_r($array);//Array ( [foo] => bar [bar] => foo )
?>
從php5.4 起可以使用短數(shù)組定義語法,用 [] 替代 array()。有點(diǎn)類似于javascript中數(shù)組的定義。
each()的使用
//通過為數(shù)組元素賦值來創(chuàng)建數(shù)組
$ages["trigkit4"] = 22;
echo $ages."
";//Array
//因?yàn)橄嚓P(guān)數(shù)組的索引不是數(shù)字,所以無法通過for循環(huán)來進(jìn)行遍歷操作,只能通過foreach循環(huán)或list()和each()結(jié)構(gòu)
//each的使用
//each返回?cái)?shù)組中當(dāng)前的鍵/值對并將數(shù)組指針向前移動(dòng)一步
$users = array("trigkit4"=>22,"mike"=>20,"john"=>30);
//print_r(each($users));//Array ( [1] => 22 [value] => 22 [0] =>
trigkit4 [key] => trigkit4 )
//相當(dāng)于:$a =
array([0]=>trigkit4,[1]=>22,[value]=>22,[key]=>trigkit4);
$a = each($users);//each把原來的數(shù)組的第一個(gè)元素拿出來包裝成新數(shù)組后賦值給$a
echo $a[0];//trigkit4
//!!表示將真實(shí)存在的數(shù)據(jù)轉(zhuǎn)換成布爾值
echo !!each($users);//1
?>
each的指針指向第一個(gè)鍵值對,并返回第一個(gè)數(shù)組元素,獲取其鍵值對,并包裝成新數(shù)組
list()的使用
list用來把數(shù)組用的值賦給一些變量,看下面例子:
$a = ["2","abc","def"];
list($var1,$var2) = $a;
echo $var1."
";//2
echo $var2;//abc
$a = ["name"=>"trigkit4","age"=>22,"0"=>"boy"];
//list只認(rèn)識(shí)key為數(shù)字的索引
list($var1,$var2) = $a;
echo $var1;//boy
?>
注:list只認(rèn)識(shí)key為數(shù)字的索引
數(shù)組元素的排序
反向排序:sort()、asort()和 ksort()都是正向排序,當(dāng)然也有相對應(yīng)的反向排序.
實(shí)現(xiàn)反向:rsort()、arsort()和 krsort()。
array_unshift()函數(shù)將新元素添加到數(shù)組頭,array_push()函數(shù)將每個(gè)新元素添加到數(shù)組 的末尾。
array_shift()刪除數(shù)組頭第一個(gè)元素,與其相反的函數(shù)是 array_pop(),刪除并返回?cái)?shù)組末 尾的一個(gè)元素。
array_rand()返回?cái)?shù)組中的一個(gè)或多個(gè)鍵。
函數(shù)shuffle()將數(shù)組個(gè)元素進(jìn) 行隨機(jī)排序。
函數(shù) array_reverse()給出一個(gè)原來數(shù)組的反向排序
數(shù)組的各類API的使用
count()和 sizeof()統(tǒng)計(jì)數(shù)組下標(biāo)的個(gè)數(shù)
array_count_values()統(tǒng)計(jì)數(shù)組內(nèi)下標(biāo)值的個(gè)數(shù)
$numbers = array("100","2");
sort($numbers,SORT_STRING);//按字符串排序,字符串只比較第一位大小
print_r($numbers);//Array ( [0] => 100 [1] => 2 )
$arr = array("trigkit4","banner","10");
sort($arr,SORT_STRING);
print_r($arr);//Array ( [0] => 10 [1] => banner [2] => trigkit4 )
shuffle($arr);
print_r($arr);//隨機(jī)排序
$array = array("a","b","c","d","0","1");
array_reverse($array);
print_r($array);//原數(shù)組的反向排序。
Array ( [0] => a [1] => b [2] => c [3] => d [4] => 0 [5] => 1 )
//數(shù)組的拷貝
$arr1 = array( "10" , 2);
$arr2 = &$arr1 ;
$arr2 [] = 4 ; // $arr2 被改變了,$arr1仍然是array("10", 3)
print_r($arr2);//Array ( [0] => 10 [1] => 2 [2] => 4 )
//asort的使用
$arr3 = & $arr1 ;//現(xiàn)在arr1和arr3是一樣的
$arr3 [] = "3" ;
asort($arr3);//對數(shù)組進(jìn)行排序并保留原始關(guān)系
print_r($arr3);// Array ( [1] => 2 [2] => 3 [0] => 10 )
//ksort的使用
$fruits = array("c"=>"banana","a"=>"apple","d"=>"orange");
ksort($fruits);
print_r($fruits);//Array ( [a] => apple [c] => banana [d] => orange
)
//unshift的使用
array_unshift($array,"z");//開頭處添加一元素
print_r($array);//Array ( [0] => z [1] => a [2] => b [3] => c [4] => d [5] => 0 [6] => 1 )
//current(pos)的使用
echo current($array);//z;獲取當(dāng)前數(shù)組中的當(dāng)前單元
//next的使用
echo next($array);//a;將數(shù)組中的內(nèi)部指針向前移動(dòng)一位
//reset的使用
echo reset($array);//z;將數(shù)組內(nèi)部指針指向第一個(gè)單元
//prev的使用
echo next($array);//a;
echo prev($array);//z;倒回一位
//sizeof的使用
echo sizeof($array);//7;統(tǒng)計(jì)數(shù)組元素的個(gè)數(shù)
//array_count_values
$num = array(10,20,30,10,20,1,0,10);//統(tǒng)計(jì)數(shù)組元素出現(xiàn)的次數(shù)
print_r(array_count_values($num));//Array ( [10] => 3 [20] => 2 [30]
=> 1 [1] => 1 [0] => 1 )
?>
current():每個(gè)數(shù)組都有一個(gè)內(nèi)部指針指向他的當(dāng)前單元,初始指向插入到數(shù)組中的第一個(gè)元素
for循環(huán)遍歷
$value = range(0,120,10);
for($i=0;$i$value);$i++){
print_r($value[$i]." ");//0 10 20 30 40 50 60 70 80 90 100 110 120
}
?>
數(shù)組的實(shí)例array_pad函數(shù)的使用
//array_pad函數(shù),數(shù)組數(shù)組首尾選擇性追加
$num = array(1=>10,2=>20,3=>30);
$num = array_pad($num,4,40);
print_r($num);//Array ( [0] => 10 [1] => 20 [2] => 30 [3] => 40
)
$num = array_pad($num,-5,50);//array_pad(array,size,value)
print_r($num);//Array ( [0] => 50 [1] => 10 [2] => 20 [3] => 30
[4] => 40 )
?>
size:指定的長度。整數(shù)則填補(bǔ)到右側(cè),負(fù)數(shù)則填補(bǔ)到左側(cè)。
unset()的使用
//unset()的使用
$num = array_fill(0,5,rand(1,10));//rand(min,max)
print_r($num);//Array ( [0] => 8 [1] => 8 [2] => 8 [3] => 8 [4]
=> 8 )
echo "
";
unset($num[3]);
print_r($num);//Array ( [0] => 8 [1] => 8 [2] => 8 [4] => 8 )
?>
array_fill()的使用
//array_fill()的使用
$num = range("a","e");
$arrayFilled = array_fill(1,2,$num);//array_fill(start,number,value)
echo "
";
print_r($arrayFilled);
?>
array_combine()的使用
$number = array(1,2,3,4,5);
$array = array("I","Am","A","PHP","er");
$newArray = array_combine($number,$array);
print_r($newArray);//Array ( [1] => I [2] => Am [3] => A [4] =>
PHP [5] => er )
?>
array_splice()刪除數(shù)組成員 :
$color = array("red", "green", "blue", "yellow");
count ($color); //得到4
array_splice($color,1,1); //刪除第二個(gè)元素
print_r(count ($color)); //3
echo $color[2]; //yellow
echo $color[1]; //blue
?>
array_unique刪除數(shù)組中的重復(fù)值:
$color=array("red", "green", "blue", "yellow","blue","green");
$result = array_unique($color);
print_r($result);//Array ( [0] => red [1] => green [2] => blue [3]
=> yellow )
?>
array_flip()交換數(shù)組的鍵值和值
$array = array("red","blue","red","Black");
print_r($array);
echo "
";
$array = array_flip($array);//
print_r($array);//Array ( [red] => 2 [blue] => 1 [Black] => 3 )
?>
array_search()搜索數(shù)值
$array = array("red","blue","red","Black");
$result=array_search("red",$array)//array_search(value,array,strict)
if(($result === NULL)){
echo "不存在數(shù)值red";
}else{
echo "存在數(shù)值 $result";//存在數(shù)值 0
}
?>
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/22738.html
摘要:個(gè)人前端文章整理從最開始萌生寫文章的想法,到著手開始寫,再到現(xiàn)在已經(jīng)一年的時(shí)間了,由于工作比較忙,更新緩慢,后面還是會(huì)繼更新,現(xiàn)將已經(jīng)寫好的文章整理一個(gè)目錄,方便更多的小伙伴去學(xué)習(xí)。 showImg(https://segmentfault.com/img/remote/1460000017490740?w=1920&h=1080); 個(gè)人前端文章整理 從最開始萌生寫文章的想法,到著手...
摘要:像其他變量一樣,使用運(yùn)算符可以改變數(shù)組元素的內(nèi)容。數(shù)組的基本操作定義數(shù)組在中聲明數(shù)組的方式主要有兩種用函數(shù)聲明數(shù)組,直接為數(shù)組元素賦值。 概述 要訪問一個(gè)變量的內(nèi)容,可以直接使用其名稱。如果該變量是一個(gè)數(shù)組,可以使用變量名稱和關(guān)鍵字或索引的組合來訪問其內(nèi)容。 像其他變量一樣,使用運(yùn)算符=可以改變數(shù)組元素的內(nèi)容。數(shù)組單元可以通過 array[key] 語法來訪問。 showImg(...
摘要:是企業(yè)與區(qū)塊鏈相遇的地方。的框架旨在成為開發(fā)區(qū)塊鏈解決方案的支柱。以太坊,主要是針對工程師使用進(jìn)行區(qū)塊鏈以太坊開發(fā)的詳解。 如果你想將區(qū)塊鏈合并到一個(gè)Java項(xiàng)目中,現(xiàn)在我們來看看就是這個(gè)細(xì)分領(lǐng)域中三個(gè)最大的OSS玩家。 好的伙計(jì)們,我們都聽說過比特幣,以太坊或其他加密貨幣,其中有一些時(shí)髦的名字圍繞著我們常見的新聞,但我們作為Java開發(fā)人員知道如何輕松地與這些區(qū)塊鏈技術(shù)進(jìn)行交互嗎?以...
摘要:哪吒社區(qū)技能樹打卡打卡貼函數(shù)式接口簡介領(lǐng)域優(yōu)質(zhì)創(chuàng)作者哪吒公眾號(hào)作者架構(gòu)師奮斗者掃描主頁左側(cè)二維碼,加入群聊,一起學(xué)習(xí)一起進(jìn)步歡迎點(diǎn)贊收藏留言前情提要無意間聽到領(lǐng)導(dǎo)們的談話,現(xiàn)在公司的現(xiàn)狀是碼農(nóng)太多,但能獨(dú)立帶隊(duì)的人太少,簡而言之,不缺干 ? 哪吒社區(qū)Java技能樹打卡?【打卡貼 day2...
閱讀 3286·2021-11-24 09:38
閱讀 2158·2021-11-23 09:51
閱讀 1750·2021-10-13 09:39
閱讀 2624·2021-09-23 11:53
閱讀 1408·2021-09-02 15:40
閱讀 3660·2019-08-30 15:54
閱讀 1135·2019-08-30 13:04
閱讀 2566·2019-08-30 11:01