>  기사  >  백엔드 개발  >  선택 쿼리 결과는 두 가지가 있는데 그 중 하나는 내용(텍스트)이고 다른 하나는 욕설에 내용이 나타나는 횟수를 계산하는 방법입니다.

선택 쿼리 결과는 두 가지가 있는데 그 중 하나는 내용(텍스트)이고 다른 하나는 욕설에 내용이 나타나는 횟수를 계산하는 방법입니다.

PHP中文网
PHP中文网원래의
2016-08-04 09:20:09918검색

완벽한 해결책이 생각나지 않아 결국 여전히 쓰레기입니다.

안 좋은 방법이 생각났는데 한번 보세요:

$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(&#39;2b&#39;, &#39;fuck&#39;);
$con = array(
        array(
            &#39;content&#39;=>&#39;asdfasdf2bsdfasdf2dfasdfuck&#39;
            ),
        array(
            &#39;content&#39;=>&#39;asdfasdf2asdfasdf2dfasdfuck&#39;
            ),
        array(
            &#39;content&#39;=>&#39;asdfasdfuckbsdfasdf2dfasdfuck&#39;
            ),
    );
foreach($con as $ck => $cv) {
    foreach ($arr as $av) {
        if (($pos = strpos($cv[&#39;content&#39;], $av)) !== false) {
            $cv[&#39;checkCount&#39;][$av] = recursionSearch($cv[&#39;content&#39;], $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을 사용하여 총계를 계산합니다. 감사합니다 ^_^

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.