完璧な解決策は思いつきません、結局のところ、それはまだゴミです。
私は醜い方法を考えました、ちょっと見てください:
$str = "1111111111111112b22222222caonima22222222"; $words = ['2b','caonima']; $res = []; foreach($words as $word){ $res[$word] = count(explode($word, $str))-1; } return $res;
汚い言葉の数だけを数えて、各汚い言葉の数を必要としない場合、私は以前に以下に基づいて文字列を切り取る関数を書きました。複数のキー
$str = "1111111111111112b22222222caonima22222222"; $words = ['2b','caonima']; function many_explode($cutKey,$string){ $return=[]; $key=0; for($i=0;$i<strlen($string);$i++){ if(in_array($string[$i], $cutKey)){ $key++; //当前字符在 cutKey 中,跳过,并另起一行 }else{ $return[$key]=isset($return[$key])?$return[$key].$string[$i]:$string[$i]; } } return $return; } return count(many_explode($words, $str)) -1;
薬を変更せずにスープを変更します
2. コンテンツコンテキストを全文インデックスとして使用します
3.検索するには mysql が付属しています。または、 like を使用することもできます。
$arr = array('2b', 'fuck'); $con = array( array( 'content'=>'asdfasdf2bsdfasdf2dfasdfuck' ), array( 'content'=>'asdfasdf2asdfasdf2dfasdfuck' ), array( 'content'=>'asdfasdfuckbsdfasdf2dfasdfuck' ), ); foreach($con as $ck => $cv) { foreach ($arr as $av) { if (($pos = strpos($cv['content'], $av)) !== false) { $cv['checkCount'][$av] = recursionSearch($cv['content'], $av, $pos, 1); } } $con[$ck] = $cv; } print_r($con); // function recursionSearch($haystack, $needle, $offset=0, $res=0 ) { $offset += strlen($needle); if (($pos = strpos($haystack, $needle, $offset)) === false) { return $res; } else { return recursionSearch($haystack, $needle, $pos, $res+1 ); } } // 打印结果 /** Array ( [0] => Array ( [content] => asdfasdf2bsdfasdf2dfasdfuck [checkCount] => Array ( [2b] => 1 [fuck] => 1 ) ) [1] => Array ( [content] => asdfasdf2asdfasdf2dfasdfuck [checkCount] => Array ( [fuck] => 1 ) ) [2] => Array ( [content] => asdfasdfuckbsdfasdf2dfasdfuck [checkCount] => Array ( [fuck] => 2 ) ) ) **/
ご回答ありがとうございます。さまざまな書き方を学びました。 qvga によって提供される最初の値を使用し、続いて array_sum を使用して合計をカウントします。 ありがとうございます^_^