php中數組的並集、交集和差集合函式介紹

來源:互聯網
上載者:User

php中的數組函數真的是非常之多,實際工作中多瞭解一些php自身存在的一些函數,將會大大提高工作的速度。這篇文章分享一下在php中如何處理兩個或多個數組的並集,交集和差集的函數。

(1)php計算兩個或多個數組的並集

並集即將兩個或多個數組合為一個數組的結果集合。php中合并數組一般都會用到 array_merge 與 + 這兩種操作。至於這兩者的區別,可參照本站文章:

PHP合并數組+與array_merge的區別

(1)php計算兩個或多個數組的交集

交集即是兩個或多個數組中都存在的那一部分的資料的集合。計算數組的交集主要用到了array_intersect系的函數,列舉如下:

array_intersect ( $arr , $arr2[……])  返回一個數組 $arr 與其他數組的交集,鍵名不變。
array_intersect_assoc( $arr, $arr2[……]) 返回一個數組 $arr 與其他數組的交集,同時比較鍵名,索引不變。
array_intersect_uassoc( $arr , $arr2 [……] , 'cmp_function ') 帶索引檢查數組的交集,用回呼函數,比較索引。
array_intersect_key ( $arr ,$arr2 [……] ) 使用鍵名比較計算數組的交集。
array_intersect_ukey( $arr , $arr2 [……],'cmp_function'); 用回呼函數比較鍵名來計算數組的交集。

array_uintersect ( $arr , $arr2 [……] , 'cmp_function' )   比較數組中的交集 用回呼函數比較資料。
array_uintersect_assoc( $arr, $arr2[……] , 'cmp_function') 帶索引檢查數組的交集 用回呼函數比較資料。
array_uintersect_uassoc($arr , $arr2 [……] , 'cmp_function' ) 帶索引檢查數組的交集 , 用回呼函數比較資料和索引。

array_intersect 樣本如下:

$array1=array('a'=>'green','red','blue');$array2=array('b'=>'green','yellow','red');$result=array_intersect($array1,$array2);

$result 的結果將為:

Array
(
   [a]=>green
   [0]=>red
)

(1)php計算兩個或多個數組的差集

差集即是除去交集之外的那一部分的資料的集合。計算數組的差集主要用到了array_diff系的函數,列舉如下:

array_diff( $arr , $arr2[……] )  返回一個數組,該數組包括了所有在$arr1 但是不在任何其他參數數組中的值,鍵名不變。
array_diff_uassoc( $arr ,$arr2 ,[……] , 'cmp_function') 用回呼函數做索引比較數組中的差集。
array_diff_assoc( $arr , $arr2[……] ) 返回一個數組,$arr 與其他數組的差集,同時比較鍵名,索引不變。

array_udiff ( $arr , $arr2 [……] , 'cmp_function') 用回呼函數比較資料來計算數組的差集。
array_udiff_uassoc (  $arr ,$arr2 ,[……]  , 'cmp_function') 帶索引檢查數組的差集,用回呼函數比較資料和索引。  
array_udiff_assoc ( $arr ,$arr2 ,[……] , 'cmp_function')  帶索引檢查數組的差集,用回呼函數比較資料,鍵名也比較。

array_diff 樣本如下:

$array1=array('a'=>'green','red','blue','red');$array2=array('b'=>'green','yellow','red');$result=array_diff($array1,$array2);

$result 的結果將為:

array(1=>'blue')

以上函數只是粗略的介紹了一下函數名稱和作用,至於各個函數的具體用法,請參考php手冊。



相關文章

Beyond APAC's No.1 Cloud

19.6% IaaS Market Share in Asia Pacific - Gartner IT Service report, 2018

Learn more >

Apsara Conference 2019

The Rise of Data Intelligence, September 25th - 27th, Hangzhou, China

Learn more >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。