溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

PHP中有哪些操作數(shù)組的方法

發(fā)布時(shí)間:2021-03-19 16:27:22 來源:億速云 閱讀:125 作者:Leah 欄目:開發(fā)技術(shù)

這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)碛嘘P(guān)PHP中有哪些操作數(shù)組的方法,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

概述
要訪問一個(gè)變量的內(nèi)容,可以直接使用其名稱。如果該變量是一個(gè)數(shù)組,可以使用變量名稱和關(guān)鍵字或索引的組合來訪問其內(nèi)容。
像其他變量一樣,使用運(yùn)算符=可以改變數(shù)組元素的內(nèi)容。數(shù)組單元可以通過 array[key] 語法來訪問。

PHP中有哪些操作數(shù)組的方法

數(shù)組的基本操作
php定義數(shù)組:

<?php 
  $array = array(); 
  $array["key"] = "values"; 
?>

在PHP中聲明數(shù)組的方式主要有兩種:

1.用array()函數(shù)聲明數(shù)組,
2.直接為數(shù)組元素賦值。

<?php
  //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ù)字簡(jiǎn)單地打印出來,數(shù)組會(huì)以Array開頭并已鍵值形式表示,print_r輸出布爾值和null的結(jié)果沒有意義,因此用var_dump更合適

//通過循環(huán)來顯示數(shù)組里所有的值
  for($i = 0 ;$i < 5;$i++){
    echo $users[$i];
    echo '<br/>';
  }

//通過count/sizeof統(tǒng)計(jì)數(shù)組中單元數(shù)目或?qū)ο笾械膶傩詡€(gè)數(shù)

  for($i = 0; $i < count($users);$i++){
    echo $users[$i];
    echo '<br/>';
  }
//還可以通過foreach循環(huán)來遍歷數(shù)組,這種好處在于不需要考慮key
  foreach($users as $value){
    echo $value.'<br/>';//點(diǎn)號(hào)為字符串連接符號(hào)
  }
//foreach循環(huán)遍歷 $key => $value;$key和$value是變量名,可以自行設(shè)置
  foreach($users as $key => $value){
    echo $key.'<br/>';//輸出鍵
  }
?>

創(chuàng)建自定義鍵的數(shù)組

<?php

  //創(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()的使用

<?php
  //通過為數(shù)組元素賦值來創(chuàng)建數(shù)組
  $ages['trigkit4'] = 22;
  echo $ages.'<br/>';//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)前的鍵/值對(duì)并將數(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è)鍵值對(duì),并返回第一個(gè)數(shù)組元素,獲取其鍵值對(duì),并包裝成新數(shù)組

list()的使用
list用來把數(shù)組用的值賦給一些變量,看下面例子:

<?php

  $a = ['2','abc','def'];
  list($var1,$var2) = $a;
  echo $var1.'<br/>';//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)然也有相對(duì)應(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ù)

<?php
  $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);//對(duì)數(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)遍歷

<?php
  $value = range(0,120,10);
  for($i=0;$i<count($value);$i++){
    print_r($value[$i].' ');//0 10 20 30 40 50 60 70 80 90 100 110 120 
  }
?>

數(shù)組的實(shí)例
array_pad函數(shù)的使用

<?php
  //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()的使用

 <?php
  //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 '<br/>';

  unset($num[3]);
  print_r($num);//Array ( [0] => 8 [1] => 8 [2] => 8 [4] => 8 ) 
?>

array_fill()的使用

<?php
  //array_fill()的使用
  $num = range('a','e');
  $arrayFilled = array_fill(1,2,$num);//array_fill(start,number,value)
  echo '<pre>';

  print_r($arrayFilled);

?>

array_combine()的使用

<?PHP
  $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ù)組成員

<?php
  $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ù)值

<?php
  $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ù)組的鍵值和值

<?PHP
  $array = array("red","blue","red","Black");
  print_r($array);
  echo "<br />";
  $array = array_flip($array);//
  print_r($array);//Array ( [red] => 2 [blue] => 1 [Black] => 3 ) 
?>

array_search()搜索數(shù)值

<meta charset="utf-8">
<?php
  $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 
  }
?>

上述就是小編為大家分享的PHP中有哪些操作數(shù)組的方法了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI