程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> php中數組合並操作

php中數組合並操作

編輯:關於PHP編程

將多個數組合並起來
1.合並數組
array_merge()函數將數組合並到一起,返回一個聯合的數組。所得到的數組以第一個輸入數組參數開始,按後面數組參數出現的順序依次迫加。其形式為:


view sourceprint?1 array array_merge (array array1 array2…,arrayn)


 

將一個或多個數組的單元合並起來,一個數組中的值附加在前一個數組的後面。返回作為結果的數組。
如果輸入的數組中有相同的字符串鍵名,則該鍵名後面的值將覆蓋前一個值。然而,如果數組包含數字鍵名,後面的值將不會覆蓋原來的值,而是附加到後面。
如果只給了一個數組並且該數組是數字索引的,則鍵名會以連續方式重新索引。
實例如下:


view sourceprint?1 $face = array("j","q","k","a"); 

2 $numbered = array("2","3","4","5","6","7","8","9"); 

3 $cards = array_merge($face, $numbered); 

4 shuffle($cards); 

5 print_r($cards);


 

這將返回如下所示的結果,運行代碼:


view sourceprint?array ( [0] => a [1] => 4 [2] => 9 [3] => 3 [4] => k [5] => 7 [6] => 5 [7] => q [8] => 6 [9] => 8 [10] => 2 [11] => j )


 

 

2.遞歸追加數組
array_merge_recursive()函數與array_merge()相同,可以將兩個或多個數組合並在一起,形成一個聯合的數組.兩者之間的區別在於,當某個輸入數組中的某個鍵己經存在於結果數組中時該函數會采取不同的處理方式.array_merge()會覆蓋前面存在的鍵/值對,替換為當前輸入數組中的鍵/值對,而array_merge_recursive()將把兩個值合並在一起,形成一個新的數組,並以原有的鍵作為數組名。還有一個數組合並的形式,就是遞歸追加數組。其形式為:


view sourceprint?array array_merge_recursive( array key,array values )


 

示例如下:


view sourceprint?1 $class1 = array("john" => 100, "james" => 85); 

2 $class2 = array("micky" => 78, "john" => 45); 

3 $classscores = array_merge_recursive($class1, $class2); 

4 print_r($classscores);


 

這將返回如下結果:


view sourceprint?array ( [john] => array ( [0] => 100 [1] => 45 ) [james] => 85 [micky] => 78 )


 

 

3.連接兩個數組
array_combine()函數會得到一個新數組,它由一組提交的鍵和對應的值組成。其形式為:


view sourceprint?array array_merge(array array1,array array2[…,array arrayn])


 

注意,兩個輸入數組必須大小相同,不能為空。示例如下:


view sourceprint?1 $abbreviations = array("al","ak","az","ar"); 

2 $states = array("alabama","alaska","arizona","arkansas"); 

3 $statemap = array_combine($abbreviations,$states); 

4 print_r($statemap);


 

這會返回:


view sourceprint?1 array ( [al] => alabama [ak] => alaska [az] => arizona [ar] => arkansas )

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved