對於PHP的二維數組,我們經常需要判斷某個鍵值對是否存在於數組中,本文將介紹幾種常見的方法。
in_array函數可以用來判斷一個值是否在數組中存在,但它只能判斷一維數組,無法判斷在二維數組中的鍵值對。我們可以使用它的變體in_array_recursive函數,透過遞歸的方式來判斷二維數組中的鍵值對是否存在。
範例程式碼:
function in_array_recursive($needle, $haystack, $strict = false) { foreach ($haystack as $value) { if ((!$strict && $needle == $value) || ($strict && $needle === $value)) { return true; } if (is_array($value) && in_array_recursive($needle, $value, $strict)) { return true; } } return false; } $array = array( array('id' => 1, 'name' => '张三'), array('id' => 2, 'name' => '李四'), array('id' => 3, 'name' => '王五'), ); if (in_array_recursive(array('id' => 1, 'name' => '张三'), $array)) { echo '存在'; } else { echo '不存在'; }
array_column函數可以提取一個二維數組中的某一列作為新的一維數組,我們可以用它來判斷數組中某個鍵是否存在。
範例程式碼:
$array = array( array('id' => 1, 'name' => '张三'), array('id' => 2, 'name' => '李四'), array('id' => 3, 'name' => '王五'), ); $ids = array_column($array, 'id'); if (in_array(1, $ids)) { echo '存在'; } else { echo '不存在'; }
#array_search函數可以在陣列中找到某個鍵值的位置,如果找到則傳回該鍵的索引,否則傳回false。但它只能找一維數組,無法找到二維數組中的鍵值對。我們可以使用其第三個參數來制定查找鍵的值。
範例程式碼:
$array = array( array('id' => 1, 'name' => '张三'), array('id' => 2, 'name' => '李四'), array('id' => 3, 'name' => '王五'), ); foreach ($array as $key => $value) { if (array_search(1, $value)) { echo '存在'; break; } else { echo '不存在'; } }
以上是三種較常見的二維陣列判斷方法,可以根據具體情況選擇合適的方法。
以上是php二維數組怎麼判斷指定鍵值是否存在的詳細內容。更多資訊請關注PHP中文網其他相關文章!