42

如何检查 a 是否$string包含数组中表示的任何项目?

$string = 'My nAmE is Tom.';
$array = array("name","tom");
if(contains($string,$array))
{
// do something to say it contains
}

有任何想法吗?

4

14 回答 14

101

我不认为有一个内置函数可以处理你想要的。但是,您可以轻松编写一个contains()函数:

function contains($str, array $arr)
{
    foreach($arr as $a) {
        if (stripos($str,$a) !== false) return true;
    }
    return false;
}
于 2010-01-23T20:22:30.363 回答
25

那是你想要的吗?我希望代码正在编译:)

$string = 'My nAmE is Tom.';
$array = array("name","tom");
if(0 < count(array_intersect(array_map('strtolower', explode(' ', $string)), $array)))
{
  //do sth
}
于 2010-01-23T20:21:11.680 回答
15

使用公认的答案:

$string = 'My nAmE is Tom.';
$array = array("name","tom");
if(0 < count(array_intersect(array_map('strtolower', explode(' ', $string)), $array)))
{
  //do sth
}

请注意,if 语句可以更改为:

if(0 < count(array_intersect(explode(' ', strtolower($string)), $array)))

因为实际上没有必要使用 array_map 来应用于strtolower每个元素。而是将其应用于初始字符串。

于 2013-09-05T08:23:44.330 回答
9

contains 函数的另一种解决方法

function contains($string, $array, $caseSensitive = true)
{
    $stripedString = $caseSensitive ? str_replace($array, '', $string) : str_ireplace($array, '', $string);
    return strlen($stripedString) !== strlen($string);
}

PS。至于我,我只是在没有功能的情况下使用它..

if (strlen(str_replace($array, '', $string)) !== strlen($string)) {
    // do it
}
于 2015-11-25T09:45:49.337 回答
7

像这样的东西会起作用:

$string = 'My nAmE is Tom.';
$array = array("name", "tom");
foreach ($array as $token) {
    if (stristr($string, $token) !== FALSE) {
        print "String contains: $token\n";
    }
}
于 2010-01-23T20:22:31.337 回答
5

我们可以检查给定字符串中是否存在数组的任何元素。

$string = 'My nAmE is Tom.';
$array = array("name","tom");

if(str_replace($array, '', strtolower($string)) !== strtolower($string)) {
   // If String contains an element from array      
   // Do Something
}
于 2021-04-07T12:00:39.563 回答
2
<?php

$input = preg_quote('blu', '~'); // don't forget to quote input string!
$data = array('orange', 'blue', 'green', 'red', 'pink', 'brown', 'black');

$result = preg_grep('~' . $input . '~', $data);
print_r($result);

?>
于 2016-06-22T06:08:41.767 回答
1

这会做这项工作吗?

$words = explode(" ", $string);
$wordsInArray = array();
foreach($words as $word) {
    if(in_array($word, $array)) {
        $wordsInArray[] = $word;
    }
}
于 2010-01-23T20:20:37.433 回答
0
function contains($str, $arr)
{
  $ptn = '';
  foreach ($arr as $s) {
    if ($ptn != '') $ptn .= '|';
    $ptn .= preg_quote($s, '/');
  }
  return preg_match("/$ptn/i", $str);
}

echo contains('My nAmE is Tom', array('name', 'tom'));
于 2010-01-23T20:27:05.783 回答
0

使用 array_intersect() 函数的另一种方法,试试下面的代码:

function checkString(array $arr, $str) {

  $str = preg_replace( array('/[^ \w]+/', '/\s+/'), ' ', strtolower($str) ); // Remove Special Characters and extra spaces -or- convert to LowerCase

  $matchedString = array_intersect( explode(' ', $str), $arr);

  if ( count($matchedString) > 0 ) {
    return true;
  }
  return false;
}
于 2017-08-17T06:42:12.687 回答
0

有更简单的方法

   $string = 'My nAmE is Tom.';
   $convert=explode(" ",$string,5);
   if(in_array("My", $convert)){

      echo "Ja";
   }else{

      echo "Nein";
   }
于 2022-01-04T19:37:08.423 回答
0

我做了一些测试,因为我需要根据我们不允许的单词列表检查用户输入。

我发现将所有内容都转换为小写(因为我的列表是小写的)然后使用数组相交是迄今为止最快的。

    **First Option I Tested**
    $tempString= explode(' ',strtolower($string));
    $foundWords = array_intersect($tempString,$profanities);
    Time taken: 0.00065207481384277 

    **The second option I tested**
    $tempWords = explode(' ',$words);
    foreach ($tempWords as $word)
    {
        foreach ($profanities as $profanity)
        {
            if (stripos($word,$profanity) !== false) return true;
        }
    }
    Time Taken: 0.024131059646606
于 2021-07-14T15:40:37.707 回答
0

由于我必须获得匹配计数,因此我使用了 preg_match_all

preg_match_all("/" . implode(' | ', $array) . "/i", " ".str_replace([':', '-'], ' ',$string)." ", $matches);
count($matches[0]);
于 2022-02-28T12:22:25.980 回答
-4

更简单,请参考链接in_array

$os = array("Mac", "NT", "Irix", "Linux");
if (in_array("Irix", $os)) {
echo "Es Irix";
}
于 2012-08-28T15:35:41.407 回答