완벽한 해결책이 생각나지 않아 결국 여전히 쓰레기입니다.
안 좋은 방법이 생각났는데 한번 보세요:
$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;
약을 바꾸지 않고 국물 바꾸기
1. 모든 욕 키워드의 테이블을 만듭니다.
2. 전체 텍스트 인덱싱을 위한 콘텐츠 컨텍스트 3. 찾기를 검색하려면 mysql에 포함된 기능을 사용하거나$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 ) ) ) **/