敏感词过滤的经典算法DFA ,看完相关资料后,自己实现了一下,同时做了评估实验

先上代码

#!/usr/bin/python2.6

# -*- coding: utf-8 -*-

import time

class Node(object):

def __init__(self):

self.children = None

# The encode of word is UTF-8

def add_word(root,word):

node = root

for i in range(len(word)):

if node.children == None:

node.children = {}

node.children[word[i]] = Node()

elif word[i] not in node.children:

node.children[word[i]] = Node()

node = node.children[word[i]]

def init(path):

root = Node()

fp = open(path,'r')

for line in fp:

line = line[0:-1]

#print len(line)

#print line

#print type(line)

add_word(root,line)

fp.close()

return root

# The encode of word is UTF-8

# The encode of message is UTF-8

def is_contain(message, root):

for i in range(len(message)):

p = root

j = i

while (j

p = p.children[message[j]]

j = j + 1

if p.children==None:

#print '---word---',message[i:j]

return True

return False

def dfa():

print '----------------dfa-----------'

root = init('/tmp/word.txt')

message = '四处乱咬乱吠,吓得家中11岁的女儿躲在屋里不敢出来,直到辖区派出所民警赶到后,才将孩子从屋中救出。最后在征得主人同意后,民警和村民合力将这只发疯的狗打死'

#message = '不顾'

print '***message***',len(message)

start_time = time.time()

for i in range(1000):

res = is_contain(message,root)

#print res

end_time = time.time()

print (end_time - start_time)

def is_contain2(message,word_list):

for item in word_list:

if message.find(item)!=-1:

return True

return False

def normal():

print '------------normal--------------'

path = '/tmp/word.txt'

fp = open(path,'r')

word_list = []

message = '四处乱咬乱吠,吓得家中11岁的女儿躲在屋里不敢出来,直到辖区派出所民警赶到后,才将孩子从屋中救出。最后在征得主人同意后,民警和村民合力将这只发疯的狗打死'

print '***message***',len(message)

for line in fp:

line = line[0:-1]

word_list.append(line)

fp.close()

print 'The count of word:',len(word_list)

start_time = time.time()

for i in range(1000):

res = is_contain2(message,word_list)

#print res

end_time = time.time()

print (end_time - start_time)

if __name__ == '__main__':

dfa()

normal()

测试结果:

1) 敏感词 100个

----------------dfa-----------

***message*** 224

0.325479984283

------------normal--------------

***message*** 224

The count of word: 100

0.107350111008

2) 敏感词 1000 个

----------------dfa-----------

***message*** 224

0.324251890182

------------normal--------------

***message*** 224

The count of word: 1000

1.05939006805

从上面的实验我们可以看出,在DFA 算法只有在敏感词较多的情况下,才有意义。在百来个敏感词的情况下,甚至不如普通算法

下面从理论上推导时间复杂度,为了方便分析,首先假定消息文本是等长的,长度为lenA;每个敏感词的长度相同,长度为lenB,敏感词的个数是m。

1) DFA算法的核心是构建一棵多叉树,由于我们已经假设,敏感词的长度相同,所以树的最大深度为lenB,那么我们可以说从消息文本的某个位置(字节)开始的某个子串是否在敏感词树中,最多只用经过lenB次匹配.也就是说判断一个消息文本中是否有敏感词的时间复杂度是lenA * lenB

2) 再来看看普通做法,是使用for循环,对每一个敏感词,依次在消息文本中进行查找,假定字符串是使用KMP算法,KMP算法的时间复杂度是O(lenA + lenB)

那么对m个敏感词查找的时间复杂度是 (lenA + lenB ) * m

综上所述,DFA 算法的时间复杂度基本上是与敏感词的个数无关的。

python实现dfa过滤算法_DFA 算法实现敏感词过滤(python 实现)相关推荐

  1. dfa算法c语言,DFA跟trie字典树实现敏感词过滤(python和c语言)

    DFA和trie字典树实现敏感词过滤(python和c语言) 现在做的项目都是用python开发,需要用做关键词检查,过滤关键词,之前用c语言做过这样的事情,用字典树,蛮高效的,内存小,检查快. 到了 ...

  2. DFA算法 使用C# 实现 敏感词过滤

    DFA,全称 Deterministic Finite Automaton 即确定有穷自动机:从一个状态通过一系列的事件转换到另一个状态,即 state -> event -> state ...

  3. 敏感词过滤的php代码,PHP敏感词过滤

    /** * 禁词过滤 * 执行效率:每篇用时0.05秒 * @author liuxu * */ class Logic_BlackWord { const APP_FORUM = 1; const ...

  4. Java实现敏感词过滤

    敏感词.文字过滤是一个网站必不可少的功能,如何设计一个好的.高效的过滤算法是非常有必要的.前段时间我一个朋友(马上毕业,接触编程不久)要我帮他看一个文字过滤的东西,它说检索效率非常慢.我把它程序拿过来 ...

  5. 【Lilishop商城】No3-2.模块详细设计,系统设置(系统配置、行政区划、物流公司、滑块验证码图片、敏感词过滤)的详细设计

     仅涉及后端,全部目录看顶部专栏,代码.文档.接口路径在: [Lilishop商城]记录一下B2B2C商城系统学习笔记~_清晨敲代码的博客-CSDN博客 全篇会结合业务介绍重点设计逻辑,其中重点包括接 ...

  6. 算法-DFA算法-敏感词过滤算法(OC、Swift、Python)

    前言 前段时间,公司的IM SDK想做敏感词过滤,但是后端的小伙伴<比较忙>,在开产品需求会的时候想把敏感词过滤放到前端,让iOS.安卓自己搞,但是前端小伙伴写了一个方法来检测一段文本,耗 ...

  7. 敏感词过滤 - DFA算法[确定有穷自动机]的Java 实现

    文章目录 敏感词过滤 - DFA算法[确定有穷自动机]的Java 实现 敏感词过滤 - DFA算法[确定有穷自动机]的Java 实现 代码如下 package utils;import com.goo ...

  8. java使用DFA算法实现敏感词过滤

    Java使用DFA算法实现敏感词过滤 DFA,全称 Deterministic Finite Automaton 即确定有穷自动机. 其特征为:有一个有限状态集合和一些从一个状态通向另一个状态的边,每 ...

  9. java dfa 敏感词_java利用DFA算法实现敏感词过滤功能

    前言 敏感词过滤应该是不用给大家过多的解释吧?讲白了就是你在项目中输入某些字(比如输入xxoo相关的文字时)时要能检 测出来,很多项目中都会有一个敏感词管理模块,在敏感词管理模块中你可以加入敏感词,然 ...

最新文章

  1. spring中这些能升华代码的技巧,可能会让你爱不释手
  2. edit filter rules in sql source control
  3. 2019.08.07【NOIP提高组】模拟 A 组 总结
  4. Boost:额外的bimap的测试程序
  5. PB编译错误:Mismatched time stamp on .rel file for module nk.exe requesting kernel fixup. Valid .rel file
  6. js 用下标获取map值_javascript怎么获取map的值?
  7. 安装Windows7出现:”安装程序无法创建新的系统分区 也无法定位系统分区“ 终极解决方案...
  8. HDFView 3.1.2 在WIN10系统安装后打开出现黑框闪退的解决方法
  9. poj 1035 Spell checker(hash)
  10. ajax jsonp不触发后台_JsonP
  11. Sublime Text3自定义主题
  12. 【RuoYi-Vue-Plus】扩展笔记 01 - 集成 JavaMail 发送邮件(源码)
  13. Lenovo Y50-70 1080p Hackintosh Catalina
  14. 只能看,不能读的文章
  15. 关于如何修复移动热点无网络(无互联网连接)的问题
  16. Oracle中获取系统当前时间 和 进行时间间隔操作
  17. maven 跳过单元测试打包
  18. 仪表板工具Stimulsoft Dashboards中的面板组件介绍
  19. 服务器散热风扇的制作流程,散热风扇生产操作工艺--制作流程
  20. 【ART-PI】使用STM32H750的隐藏2MB ROM

热门文章

  1. Java中的char究竟能存中文吗?
  2. OpenCV学习第二篇之读取视频
  3. IDEA中找不到tomcat
  4. RK3568平台开发系列讲解(环境篇)瑞芯微原厂源码目录介绍
  5. 录音转文字助手怎么操作?详细步骤教你使用,会议纪录轻松完成
  6. Python读取CSV文件写入Mysql数据库
  7. 十块钱做个好看的心形彩灯
  8. 做程序员的前途怎么样?就业前景好吗?
  9. 计算机主机内部防尘装置,一种计算机主机防尘装置的制作方法
  10. MPS和MRP的关系