PHPmultidimensional arraysearch(按特定值查找关键字)

我有这个multidimensional array。 我需要search它,只返回匹配“slug”值的键。 我知道有关于searchmultidimensional array的其他线程,但我不是很了解适用于我的情况。 非常感谢您的帮助!

所以我需要一个像这样的function:

myfunction($products,'breville-one-touch-tea-maker-BTM800XL'); // returns 1 

这是数组:

 $products = array ( 1 => array( 'name' => 'The Breville One-Touch Tea Maker', 'slug' => 'breville-one-touch-tea-maker-BTM800XL', 'shortname' => 'The One-Touch Tea Maker', 'listprice' => '299.99', 'price' => '249.99', 'rating' => '9.5', 'reviews' => '81', 'buyurl' => 'http://www.amazon.com/The-Breville-One-Touch-Tea-Maker/dp/B003LNOPSG', 'videoref1' => 'xNb-FOTJY1c', 'videoref2' => 'WAyk-O2B6F8', 'image' => '812BpgHhjBML.jpg', 'related1' => '2', 'related2' => '3', 'related3' => '4', 'bestbuy' => '1', 'quote' => '', 'quoteautor' => 'K. Martino', ), 2 => array( 'name' => 'Breville Variable-Temperature Kettle BKE820XL', 'slug' => 'breville-variable-temperature-kettle-BKE820XL', 'shortname' => 'Variable Temperature Kettle', 'listprice' => '199.99', 'price' => '129.99', 'rating' => '9', 'reviews' => '78', 'buyurl' => 'http://www.amazon.com/Breville-BKE820XL-Variable-Temperature-1-8-Liter-Kettle/dp/B001DYERBK', 'videoref1' => 'oyZWBD83xeE', 'image' => '41y2B8jSKmwL.jpg', 'related1' => '3', 'related2' => '4', 'related3' => '5', 'bestbuy' => '1', 'quote' => '', 'quoteautor' => '', ), ); 

很简单:

 function myfunction($products, $field, $value) { foreach($products as $key => $product) { if ( $product[$field] === $value ) return $key; } return false; } 

另一个可能的解决scheme是基于array_search()函数。 您需要使用PHP 5.5.0或更高版本。

 $userdb=Array ( (0) => Array ( (uid) => '100', (name) => 'Sandra Shush', (url) => 'urlof100' ), (1) => Array ( (uid) => '5465', (name) => 'Stefanie Mcmohn', (pic_square) => 'urlof100' ), (2) => Array ( (uid) => '40489', (name) => 'Michael', (pic_square) => 'urlof40489' ) ); $key = array_search(40489, array_column($userdb, 'uid')); echo ("The key is: ".$key); //This will output- The key is: 2 

说明

函数array_search()有两个参数。 第一个是你想要search的值。 其次是函数应该在哪里search。 函数array_column()获取键是'uid'的元素的值。

概要

所以你可以使用它:

 array_search('breville-one-touch-tea-maker-BTM800XL', array_column($products, 'slug')); 

或者,如果您愿意:

 // define function function array_search_multidim($array, $column, $key){ return (array_search($key, array_column($array, $column));); } // use it array_search_multidim($products, 'slug', 'breville-one-touch-tea-maker-BTM800XL'); 

最初的例子(由xfoxawy)可以在DOCS上find。
array_column() 页面 。


更新

由于Vael的评论,我很好奇,所以我做了一个简单的testing,以确保使用array_search的方法的性能和接受的答案上提出的方法。

我创build了一个包含1000个数组的数组,结构如下(所有数据都是随机的):

 [ { "_id": "57fe684fb22a07039b3f196c", "index": 0, "guid": "98dd3515-3f1e-4b89-8bb9-103b0d67e613", "isActive": true, "balance": "$2,372.04", "picture": "http://placehold.it/32x32", "age": 21, "eyeColor": "blue", "name": "Green", "company": "MIXERS" },... ] 

我运行searchtesting100次search名称字段的不同值,然后计算平均时间(以毫秒为单位) 。 在这里你可以看到一个例子。

结果表明,在这个答案上提出的方法需要大约2E-7来find价值,而接受的答案方法需要大约8E-7。

就像我之前说过的,对于使用具有这个大小的数组的应用程序,这两次都是相当可观的。 如果尺寸增长很多,我们说1M元素,那么这个小小的差异也会增加。

这个类的方法可以在多个条件下search数组:

 class Stdlib_Array { public static function multiSearch(array $array, array $pairs) { $found = array(); foreach ($array as $aKey => $aVal) { $coincidences = 0; foreach ($pairs as $pKey => $pVal) { if (array_key_exists($pKey, $aVal) && $aVal[$pKey] == $pVal) { $coincidences++; } } if ($coincidences == count($pairs)) { $found[$aKey] = $aVal; } } return $found; } } // Example: $data = array( array('foo' => 'test4', 'bar' => 'baz'), array('foo' => 'test', 'bar' => 'baz'), array('foo' => 'test1', 'bar' => 'baz3'), array('foo' => 'test', 'bar' => 'baz'), array('foo' => 'test', 'bar' => 'baz4'), array('foo' => 'test4', 'bar' => 'baz1'), array('foo' => 'test', 'bar' => 'baz1'), array('foo' => 'test3', 'bar' => 'baz2'), array('foo' => 'test', 'bar' => 'baz'), array('foo' => 'test', 'bar' => 'baz'), array('foo' => 'test4', 'bar' => 'baz1') ); $result = Stdlib_Array::multiSearch($data, array('foo' => 'test4', 'bar' => 'baz1')); var_dump($result); 

会产生:

 array(2) { [5]=> array(2) { ["foo"]=> string(5) "test4" ["bar"]=> string(4) "baz1" } [10]=> array(2) { ["foo"]=> string(5) "test4" ["bar"]=> string(4) "baz1" } } 

我发现了一个棘手的情况,第一个答案(抱歉,没有足够的声誉来评论它)。

当你find你正在查找的值,并且关联的键是0.如果在此之后使用条件语句,不仅要检查返回值,还要键入(相同)。

 $key = myfunction($products, $field, $value); // Good if($key !== FALSE){ } if($key === FALSE){ } // Not Good if($key != FALSE){ } if($key == FALSE){ } 
 function search($array, $key, $value) { $results = array(); if (is_array($array)) { if (isset($array[$key]) && $array[$key] == $value) $results[] = $array; foreach ($array as $subarray) $results = array_merge($results, search($subarray, $key, $value)); } return $results; } 

尝试这个

 function recursive_array_search($needle,$haystack) { foreach($haystack as $key=>$value) { $current_key=$key; if($needle==$value['uid'] OR (is_array($value) && recursive_array_search($needle,$value) !== false)) { return $current_key; } } return false; }