提问者:小点点

PHP-通过字符串搜索/过滤多维数组


我有一个多维数组,如下所示:

$testarray = array(
    array(
        'First name' => 'Johnny',
        'Last name' => 'Milthers',
        'Age' => '24'
    ),
    array(
        'First name' => 'Toby',
        'Last name' => 'Thomson',
        'Age' => '25'), 
    ),
    array(
        'First name' => 'Jack',
        'Last name' => 'Johnson',
        'Age' => '25'),
    );

如何传递搜索字符串(如“John”),使数组$testarray仅包含第一个和最后一个数组?。

我需要传递一个搜索项,如果任何键值包含该字符串,它将返回整个子数组。

另外,如果我通过“jackjohnson”,那么$testarray应该只包含最后一个数组。

  • 这是可能的,还是我走错了方向?数据库的正常搜索结果是如何工作的

我一直在看很多堆栈溢出页面(和PHP手册谷歌),但没有任何帮助我,如果我发布的东西已经有了答案,请评论我的链接。

太谢谢你了!


共2个答案

匿名用户

这里有一种方法,请记住,只有当搜索数组直接嵌套在外部搜索数组中时,它才会起作用。

function search_array($text, $array) {
    return array_filter($array, function($a) use($text){

       return stristr(implode(" ", $a), $text);

    });
}

http://sandbox.onlinephpfunctions.com/code/09e1187ccedba0804de5d797c350e218b05951cd

匿名用户

我还没有测试过这个,但这个应该可以用。。。

function find_in_array($search, $testarray) {
  $pattern = '*'.$search.'*';
  $array = array_filter($testarray, function($entry) use ($pattern) {
    foreach($entry as $key=>$value) {
      if (fnmatch($pattern, $value)) return true;
    }
    return false;
  });
  return $array;
 }