两个select查询结果,其中一个content(text),另一个是脏话词. 如何统计content在脏话词里面出现的次数.

发布于 2022-09-03 08:45:41 字数 304 浏览 13 评论 0

图片描述

图片描述

是每一个 content 内容里面脏话的次数,基于另一个数组. 写到后面没什么思路了,应该怎么统计. ^_^

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

薯片软お妹 2022-09-10 08:45:41

想到一个比较丑的方法,看看就行:

$str = "1111111111111112b22222222caonima22222222";
$words = ['2b','caonima'];
$res = [];
foreach($words as $word){
    $res[$word] = count(explode($word, $str))-1;
}
return $res;
好多鱼好多余 2022-09-10 08:45:41

1,所有的脏话的关键词建立一个表.
2,内容context 做全文索引.
3,使用mysql自带的函数检索locate,或者你用like也可以.

牛↙奶布丁 2022-09-10 08:45:41
$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
                )

        )

)
**/
苏佲洛 2022-09-10 08:45:41

谢谢回答合各位的回答,学习了多种写法。 用了qvga提供的第一种,后面加上array_sum统计了总数。 在次谢谢^_^

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文