3種取不同值的方法:1、比較陣列鍵值並返回一個包含不同值的差集陣列,語法「array_diff(陣列1,陣列2)」。2、比較陣列鍵名並返回一個包含不同值的差集陣列,語法「array_diff_key(陣列1,陣列2)」。3、比較陣列的鍵名和鍵值,並返回一個包含不同值的差集陣列,語法「array_diff_assoc(陣列1,陣列2)」。
本教學操作環境:windows7系統、PHP8.1版、DELL G3電腦
php獲取兩個陣列不同值,就是比較兩個陣列,獲取差集。
而PHP比較陣列有三種情況:只比較鍵值、只比較鍵名、比較鍵值和鍵名。分別對應三個內建函數:
array_diff()
array_diff_key()
array_diff_assoc()
下面我們通過範例來了解一下:
1、使用array_diff()函數--比較陣列的鍵值
array_diff() 函數用於比較兩個(或更多個)陣列的值,並返回差集。
array_diff(array1,array2,array3...);
該函數比較兩個(或更多個)陣列的值(key=>value 中的 value),並返回一個差集陣列,該陣列包括了所有在被比較的陣列(array1)中,但是不在任何其他引數陣列(array2 或 array3 等等)中的值。
<?php header("Content-type:text/html;charset=utf-8"); $arr1=array(1,2,3,4,5,6); $arr2=array(2,4,6,8,10,12); var_dump($arr1); var_dump($arr2); echo "兩個陣列的不同值:"; $result=array_diff($arr1,$arr2); var_dump($result); ?>
2、使用array_diff_key()函數--比較陣列的鍵名
array_diff_key() 函數用於比較兩個(或更多個)陣列的鍵名 ,並返回差集。
array_diff_key(array1,array2,array3...);
該函數比較兩個(或更多個)陣列的鍵名,並返回一個差集陣列,該陣列包括了所有在被比較的陣列(array1)中,但是不在任何其他引數陣列(array2 或 array3 等等)中的鍵名。
<?php header("Content-type:text/html;charset=utf-8"); $arr1=array("a"=>"red","b"=>"green","c"=>"blue","d"=>"yellow"); $arr2=array("a"=>"orange","b"=>"green","e"=>"red","r"=>"yellow"); var_dump($arr1); var_dump($arr2); echo "兩個陣列的不同值:"; $result=array_diff_key($arr1,$arr2); var_dump($result); ?>
而在上面的範例,$arr1陣列和$arr2陣列中有兩個鍵名不相同,以陣列$arr1為準就會得到值「"c"=>"blue"
」和「"d"=>"yellow"
」,因此輸出的結果為:
3、使用array_diff_assoc()函數--比較陣列的鍵名和鍵值
array_diff_assoc() 函數用於比較兩個(或更多個)陣列的鍵名和鍵值 ,並返回差集。
array_diff_assoc(array1,array2,array3...);
該函數比較兩個(或更多個)陣列的鍵名和鍵值,並返回一個差集陣列,該陣列包括了所有在被比較的陣列(array1)中,但是不在任何其他引數陣列(array2 或 array3 等等)中的鍵名和鍵值。
<?php header("Content-type:text/html;charset=utf-8"); $arr1=array("a"=>"red","b"=>"green","c"=>"blue","d"=>"yellow"); $arr2=array("a"=>"orange","b"=>"green","e"=>"red","r"=>"yellow"); var_dump($arr1); var_dump($arr2); echo "兩個陣列的不同值:"; $result=array_diff_assoc($arr1,$arr2); var_dump($result); ?>
上例中,$arr1陣列和$arr2陣列進行比較,有三個不相同的元素,然後以陣列$arr1為準會得到值「"a"=>"red"
」、「"c"=>"blue"
」、「"d"=>"yellow"
」,因此輸出的結果為:
推薦學習:《》
前端(VUE)入門到精通:
以上就是php怎麼取兩個陣列的不同值的詳細內容,更多請關注TW511.COM其它相關文章!