国内最全IT社区平台 联系我们 | 收藏本站
华晨云阿里云优惠2
您当前位置:首页 > php开源 > php教程 > php数组搜索(多维数组搜索)

php数组搜索(多维数组搜索)

来源:程序员人生   发布时间:2014-02-02 18:54:21 阅读次数:3810次

在php中要实现数组搜索方法有很多种,我知道最简单的就是in_array与遍历数组后再一个个对比,其它还有更多更好方法,下面我来介绍介绍。

一维数组搜索很简单in_array()

如果 value 参数是字符串,且 type 参数设置为 true,则搜索区分大小写,代码如下:

  1. <?php 
  2. $people = array("Peter""Joe""Glenn""Cleveland"); 
  3. if (in_array("Glenn",$people)) 
  4.   { 
  5.   echo "Match found"
  6.   } 
  7. else 
  8.   { 
  9.   echo "Match not found"
  10.   } 
  11. ?> 

输出:Match found

array_key_exists()函数

如果在一个数组中找到一个指定的键,函数array_key_exists()返回true,否则返回false,其形式如下:

boolean array_key_exists(mixed key,array array); 

下面的例子将在数组键中搜索apple,如果找到,将输出这个水果的颜色,代码如下:

  1. $fruit["apple"] = "red"
  2. $fruit["banana"] = "yellow"
  3. $fruit["pear"] = "green"
  4. if(array_key_exists("apple"$fruit)){ 
  5.  printf("apple's color is %s",$fruit["apple"]); 
  6. //apple's color is red 

array_search()函数

array_search()函数在一个数组中搜索一个指定的值,如果找到则返回相应的键,否则返回false,其形式如下:

mixed array_search(mixed needle,array haystack[,boolean strict])

下面的例子在$fruits中搜索一个特定的日期(December 7),如果找到,则返回有关信息,代码如下:

  1. $fruits["apple"] = "red"
  2. $fruits["banana"] = "yellow"
  3. $fruits["watermelon"]="green"
  4. $founded = array_search("green"$fruits); 
  5. if($founded)  
  6.  printf("%s was founded on %s.",$founded$fruits[$founded]); 
  7. //watermelon was founded on green. 

array_keys()函数

array_keys()函数返回一个数组,其中包含所搜索数组中找到的所有键,其形式如下:

array array_keys(array array[,mixed search_value]) 

如果包含可选参数search_value,则只会返回与该值匹配的键,下面的例子将输出$fruit数组中找到的所有数组,代码如下:

  1. $fruits["apple"] = "red"
  2. $fruits["banana"] = "yellow"
  3. $fruits["watermelon"]="green"
  4. $keys = array_keys($fruits); 
  5. print_r($keys); 
  6. //Array ( [0] => apple [1] => banana [2] => watermelon ) 

array_values()函数

array_values()函数返回一个数组中的所有值,并自动为返回的数组提供数值索引,其形式如下:

array array_values(array array) 

下面的例子将获取$fruits中找到的各元素的值,代码如下:

  1. $fruits["apple"] = "red"
  2. $fruits["banana"] = "yellow"
  3. $fruits["watermelon"]="green"
  4. $values = array_values($fruits); 
  5. print_r($values); 
  6. //Array ( [0] => red [1] => yellow [2] => green ) 

上面讲到的都只是一维数组搜索了,如果要实现二维数据或多维数据我们可参考下面实例.

php搜索多维数组的键值,如下面例子:

  1. $foo[1]['a']['xx'] = 'bar 1'
  2. $foo[1]['b']['xx'] = 'bar 2'
  3. $foo[2]['a']['bb'] = 'bar 3'
  4. $foo[2]['a']['yy'] = 'bar 4'
  5. $foo[3]['c']['dd'] = 'bar 3'
  6. $foo[3]['f']['gg'] = 'bar 3'
  7. $foo['info'][1] = 'bar 5'

如果要查找 bar 3 怎么进行查找呢,有三个结果,而这三个结果都要,看下面的函数:

  1. function array_search_re($needle$haystack$a=0, $nodes_temp=array()){ 
  2. global $nodes_found
  3. $a++; 
  4. foreach ($haystack as $key1=>$value1) { 
  5.     $nodes_temp[$a] = $key1
  6.     if (is_array($value1)){    
  7.       array_search_re($needle$value1$a$nodes_temp); 
  8.     } 
  9.     else if ($value1 === $needle){ 
  10.       $nodes_found[] = $nodes_temp
  11.     } 
  12. return $nodes_found

这个函数就可以把上面要查找到的内容全部返回出键名来.

  1. $result = array_search_re('bar 3'$foo); 
  2. print_r($result); 
  3. //输出结果为如下: 
  4. Array ( [0] => Array ( [1] => 2 [2] => a [3] => bb ) 
  5.           [1] => Array ( [1] => 3 [2] => c [3] => dd ) 
  6.           [2] => Array ( [1] => 3 [2] => f [3] => gg ) 

php搜索多维数组的键名,代码如下:

  1. function array_search_key($needle$haystack){ 
  2. global $nodes_found
  3. foreach ($haystack as $key1=>$value1) { 
  4.  
  5.  if ($key1=== $needle){ 
  6.  
  7.   $nodes_found[] = $value1
  8.         
  9.    } 
  10.     if (is_array($value1)){    
  11.       array_search_key($needle$value1); 
  12.     } 
  13.     
  14.     
  15. return $nodes_found
  16. $result = array_search_key('a'$foo); 
  17. print_r($result); 
  18. //输出结果为如下: 
  19. Array 
  20.     [0] => Array 
  21.         ( 
  22.             [xx] => bar 1 
  23.         ) 
  24.     [1] => Array 
  25.         ( 
  26.             [bb] => bar 3 
  27.         ) 
  28.     [2] => Array 
  29.         ( 
  30.             [yy] => bar 4 
  31.         ) 
生活不易,码农辛苦
如果您觉得本网站对您的学习有所帮助,可以手机扫描二维码进行捐赠
程序员人生
------分隔线----------------------------
分享到:
------分隔线----------------------------
关闭
程序员人生