程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> PHP 檢查數組中是否存在某個值 in_array 函數

PHP 檢查數組中是否存在某個值 in_array 函數

編輯:PHP綜合

php在數組中查找指定值是否存在的方法有很多,在一開始的時候一直用foreach循環來查找的,接下來吾愛編程為大家分享一下用php內置的三個數組 函數來查找指定值是否存在於數組中,這三個數組分別是 in_array(),array_search(),array_key_exists()。
in_array() 函數用於檢查數組中是否存在某個值。

in_array()

PHP in_array() 函數檢查數組中是否存在某個值,如果存在則返回 TRUE ,否則返回 FALSE 。

語法:

bool in_array( mixed needle, array array [, bool strict] )
參數說明: 參數 說明 needle 需要在數組中搜索的值,如果是字符串,則區分大小寫 array 需要檢索的數組 strict 可選,如果設置為 TRUE ,則還會對 needle 與 array 中的值類型進行檢查

例子:

<?php
$arr_a = array("a", "b", "c", 1);
if(in_array("a", $arr_a)){
    echo '字符 a 在 $arr_a 數組中存在';
} else {
    echo '字符 a 在 $arr_a 數組中不存在';
}
?>

例子輸出結果如下:

字符 a 在 $arr_a 數組中存在

嚴格檢查的例子:

<?php
$arr_a = array("a", "b", "c", 1);
if(in_array("1", $arr_a, TRUE)){
    echo '字符 1 在 $arr_a 數組中存在';
} else {
    echo '字符 1 在 $arr_a 數組中不存在';
}
?>

例子輸出結果如下:

字符 1 在 $arr_a 數組中不存在

數組作為 needle 的例子:

<?php
$arr_a = array(array("a", "b"), 1, 2);
$arr_b = array("a", "b");
if(in_array($arr_b, $arr_a)){
	echo '數組 $arr_b 在 $arr_a 數組中存在';
} else {
	echo '數組 $arr_b 在 $arr_a 數組中不存在';
}
?>

例子輸出結果如下:

數組 $arr_b 在 $arr_a 數組中存在

array_key_exists(key,array)

該函數是判斷某個數組array中是否存在指定的 key,如果該 key 存在,則返回 true,否則返回 false。

<?php
    $a=array("a"=>"Dog","b"=>"Cat");
    if(array_key_exists("a",$a)){
	echo "Key exists!";
    }else{
	echo "Key does not exist!";
    }
?>

輸出:

Key exists!

array_search(value,array,strict)

array_search() 函數與 in_array() 一樣,在數組中查找一個鍵值。如果找到了該值,則返回匹配該元素所對應的鍵名。如果沒找到,則返回 false。注意在 PHP 4.2.0 之前,函數在失敗時返回 null 而不是 false。同樣如果第三個參數 strict 被指定為 true,則只有在數據類型和值都一致時才返回相應元素的鍵名。

<?php
    $a=array("a"=>"Dog","b"=>"Cat","c"=>5,"d"=>"5");
    echo array_search("Dog",$a);
    echo array_search("5",$a);
?>

輸出:

ad

經過實際性能對比,在數據量不大的時候,比如小於1000,查找用哪一種都行,都不會成為性能上的瓶頸。但當數據量比較大的時候,用 array_key_exists 比較合適。據測試 array_key_exist 要比 in_array 效率高十幾甚至幾十倍。

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