Trie树,又称字符查找树、前缀树,主要用于字符匹配(详见http://en.wikipedia.org/wiki/Trie)。适合做关键词查找,比如查找文章中的关键字然后给他们加链接。 当然对脏词的过滤应用也是样,只是把替换连接的工作换成了替换字符。

当前的代码还只是进行简单的替换,并没有做一些字符的处理,比如“昨天见到你妈,逼我要买房”,这本身不是脏词,因为有逗号,所以程序里要增加字符的范围判断。

程序中的skip就是用来过滤脏词的简单变体,比如“找*小*姐”,默认是最多跳过3个字符,这个可以随便调整了。总之是一个Trie的锻炼吧。

  1. public class TrieTree
  2. {
  3. private readonly Dictionary<char, TrieTree> Children;
  4. public bool End { get; set; }
  5. public TrieTree()
  6. {
  7. Children = new Dictionary<char, TrieTree>();
  8. }
  9. public void AddKey(string keyword)
  10. {
  11. if (String.IsNullOrEmpty(keyword))
  12. {
  13. return;
  14. }
  15. var cNode = this;
  16. foreach (var key in keyword)
  17. {
  18. if (cNode.Children.ContainsKey(key))
  19. {
  20. cNode = cNode.Children[key];
  21. }
  22. else
  23. {
  24. var node = new TrieTree();
  25. cNode.Children.Add(key, node);
  26. cNode = node;
  27. }
  28. }
  29. cNode.End = true;
  30. }
  31. public void Replace(ref string text)
  32. {
  33. for (var i = 0; i < text.Length; i++)
  34. {
  35. var cNode = this;
  36. var key = text[i];
  37. //碰到脏词的第一个词
  38. if (cNode.Children.ContainsKey(key))
  39. {
  40. cNode = cNode.Children[key];
  41. //查找是否包含脏词后面的词
  42. var skip = 0;
  43. for (var j = i + 1; j < text.Length; j++)
  44. {
  45. if (cNode.Children.ContainsKey(text[j]))
  46. {
  47. cNode = cNode.Children[text[j]];
  48. skip = 0;
  49. }
  50. else
  51. {
  52. //允许略过过几个字符
  53. skip++;
  54. if (skip > 3)
  55. {
  56. break;
  57. }
  58. }
  59. if (cNode.End)
  60. {
  61. var len = j + 1 - i;
  62. text = text.Replace(text.Substring(i, len), string.Empty.PadLeft(len, '*'));
  63. i += len;
  64. break;
  65. }
  66. }
  67. }
  68. }
  69. }
  70. }

使用方法如下:

  1. class Program
  2. {
  3. static void Main(string[] args)
  4. {
  5. var trie = new TrieTree();
  6. var keywords = "我操,妓女,fuck".Split(',');
  7. foreach (var key in keywords)
  8. {
  9. trie.AddKey(key);
  10. }
  11. var text = @"我擦啊,尼玛,,fuck you,你这个妓女,贱人。";
  12. trie.Replace(ref text);
  13. Console.WriteLine(text);
  14. Console.Read();
  15. }
  16. }

执行的结果:

转自http://blog.csdn.net/maddemon/article/details/7011699

Trie树-脏词过滤应用的更多相关文章

  1. 转,敏感词过滤,PHP实现的Trie树

    原文地址:http://blog.11034.org/2012-07/trie_in_php.html 项目需求,要做敏感词过滤,对于敏感词本身就是一个CRUD的模块很简单,比较麻烦的就是对各种输入的 ...

  2. [转载]敏感词过滤,PHP实现的Trie树

    原文地址:http://blog.11034.org/2012-07/trie_in_php.html 项目需求,要做敏感词过滤,对于敏感词本身就是一个CRUD的模块很简单,比较麻烦的就是对各种输入的 ...

  3. [原创] Trie树 php 实现敏感词过滤

    目录 背景 简介 存储结构 PHP 其他语言 字符串分割 示例代码 php 优化 缓存字典树 常驻服务 参考文章 背景 项目中需要过滤用户发送的聊天文本, 由于敏感词有将近2W条, 如果用 str_r ...

  4. DFA和trie特里实现敏感词过滤(python和c语言)

    今天的项目是与完成python开展,需要使用做关键词检查,筛选分类,使用前c语言做这种事情.有了线索,非常高效,内存小了,检查快. 到达python在,第一个想法是pip基于外观的c语言python特 ...

  5. web系统安全运营之基础- 基于DFA算法的高性能的敏感词,脏词的检测过滤算法类(c#).

    [概述]做好一个web系统的安全运维,除了常规的防注入,防入侵等,还有一个检测并过滤敏感词,脏词..  这件事做得不好,轻则导致一场投诉或纠纷,重则导致产品被勒令关闭停运. 废话少说,先看下代码,可以 ...

  6. 字典树Trie--实现敏感词过滤

    序言 Trie树 资料 https://blog.csdn.net/m0_37907797/article/details/103272967?utm_source=apphttps://blog.c ...

  7. 转:鏖战双十一-阿里直播平台面临的技术挑战(webSocket, 敏感词过滤等很不错)

    转自:http://www.infoq.com/cn/articles/alibaba-broadcast-platform-technology-challenges 鏖战双十一-阿里直播平台面临的 ...

  8. 用php实现一个敏感词过滤功能

    周末空余时间撸了一个敏感词过滤功能,下边记录下实现过程. 敏感词,一方面是你懂的,另一方面是我们自己可能也要过滤一些人身攻击或者广告信息等,具体词库可以google下,有很多. 过滤敏感词,使用简单的 ...

  9. 浅析敏感词过滤算法(C++)

    为了提高查找效率,这里将敏感词用树形结构存储,每个节点有一个map成员,其映射关系为一个string对应一个TreeNode. STL::map是按照operator<比较判断元素是否相同,以及 ...

随机推荐

  1. Python re模块 正则表达式

    1 简介 就其本质而言,正则表达式(或 RE)是一种小型的.高度专业化的编程语言,(在Python中)它内嵌在Python中,并通过 re 模块实现.正则表达式模式被编译成一系列的字节码,然后由用 C ...

  2. catkin_simple 的使用

    Catkin simple 可用于规范catkin package, 并简化CMakeLists  Dependencies are just listed once as build-depend  ...

  3. m元素集合的n个元素子集

    理论: 假设有5个元素的集点,取出3个元素的可能子集如下:{1 2 3}.{1 2 4 }.{1 2 5}.{1 3 4}.{1 3 5}.{1 4 5}.{2 3 4}.{2 3 5}.{2 4 5 ...

  4. poj 2774 最长公共子--弦hash或后缀数组或后缀自己主动机

    http://poj.org/problem?id=2774 我想看看这里的后缀数组:http://blog.csdn.net/u011026968/article/details/22801015 ...

  5. Hadoop中SequenceFile的使用

    1.对于某些应用而言,须要特殊的数据结构来存储自己的数据. 对于基于MapReduce的数据处理.将每一个二进制数据的大对象融入自己的文件里并不能实现非常高的可扩展性,针对上述情况,Hadoop开发了 ...

  6. 四、Mp3文件类型及其判断

    根据前两篇文章的分析,帧分为标签帧和数据帧,MP3文件类型是根据数据帧的类型来分的,文件类型如下表: 位率相等(Constant BitRate) CBR  Mp3文件 位率不等(Variable B ...

  7. C# winform平台下使用spread控件导出excel表格

    //首先要引入两个控件:1.根据自己的office 版本在项目->添加引用->microsoft office object 12.0 library (2010版) //2.在.net中 ...

  8. struts1:Struts配置文件初解

    struts-config.xml是Struts的核心文件.该文件可配置各种组件,包括,FormBeans,Actions,ActionMappings,全局转发GlobalForwards,数据源D ...

  9. Ubuntu安装tftp服务器

    一.安装如下软件包: sudo apt-get install xinetd tftpd tftp 二.在/etc/xinetd.d/目录下创建tftp文件,并输入如下内容. 执行命令:sudo vi ...

  10. C# 读取xml节点类容

    这是一个测试节点类容的获取 这是控制台代码部分 注意的应用文件 :using.system.Xml using System; using System.Collections.Generic; us ...