查看: 7705|回复: 0
打印 上一主题 下一主题

脏字典过滤:用正则表达式来过滤脏数据

[复制链接]
跳转到指定楼层
1#
发表于 2010-2-27 14:35:24 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
台州网址导航
方法一:使用正则表达式

1//脏字典数据存放文件路径
2 private static string FILE_NAME="zang.txt";
3 //脏数据字典表,如:脏数据一|脏数据二|脏数据三
4 public static string dirtyStr="";
5
6 public ValidDirty()
7 {
8 if (HttpRuntime.Cache["Regex"]==null)
9 {
10 dirtyStr=ReadDic();
11 //用于检测脏字典的正则表达式


12 Regex validateReg= new Regex("^((?!"+dirtyStr+").(?<!"+dirtyStr+"))*$",RegexOptions.Compiled|RegexOptions.ExplicitCapture);
13 HttpRuntime.Cache.Insert("Regex" ,validateReg,null,DateTime.Now.AddMinutes(20) ,TimeSpan.Zero);
14 }
15
16 }
17 private string ReadDic()
18 {
19 FILE_NAME=Environment.CurrentDirectory+"\\"+FILE_NAME;
20
21 if (!File.Exists(FILE_NAME))
22 {
23 Console.WriteLine("{0} does not exist.", FILE_NAME);
24 return "";
25 }
26 StreamReader sr = File.OpenText(FILE_NAME);
27 String input="";
28 while (sr.Peek() > -1)
29 {
30 input += sr.ReadLine() ;
31 }
32
33 sr.Close();
34 return input;
35
36 }
37
38
39 public bool ValidByReg(string str)
40 {
41 Regex reg=(Regex)HttpRuntime.Cache["Regex"];
42 return reg.IsMatch(str) ;
43
44 }


感觉这种方法的执行效率不是很高,简单的测试了一下 1000字的文章,脏字典有800多个关键字

测试了一下是 1.238秒,大家有没有更好的方法,请不吝赐教!

方法二:普通循环查找方法

public bool ValidGeneral(string str)
{

if(!File.Exists(FILE_NAME))
{
Console.WriteLine("文件路径或者文件路径不存在错误信息") ;
return false;
}
else
{
StreamReader objReader = new StreamReader(FILE_NAME,System.Text.Encoding.GetEncoding("gb2312"));
string sLine="";
ArrayList arrText = new ArrayList();

while (sLine != null)
{
sLine = objReader.ReadLine();
if (sLine != null)
arrText.Add(sLine);

}
objReader.Close();


foreach (string sOutput in arrText)
{
string[] strArr=sOutput.Split('|');

for (int i = 0; i < strArr.Length; i++)
{
if (str.IndexOf(strArr)!=-1)
{
return false;
}

}

}
return true;

}

}


以下是测试的方法,有什么问题还大家请指出!

1DateTime t1 =DateTime.Now;
2 string str="213";
3 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
4 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
5 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
6 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
7 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
8 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
9 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
10 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
11 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
12 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
13 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
14 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
15 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
16 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
17 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
18 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
19 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
20 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
21 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
22 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
23 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
24 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
25 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
26 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
27 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
28 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
29 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
30 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
31 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
32 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
33 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
34 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
35 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
36 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
37 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
38 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
39 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
40 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
41 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
42 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
43 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
44 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
45 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
46 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
47 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
48 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
49 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
50 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
51 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
52 str+="台州站长之家台州站长之家台州站长之家台州站长之家";
53 ValidDirty vd=new ValidDirty() ;
54 Console.WriteLine(vd.ValidByReg(str)) ;
55 DateTime t2 =DateTime.Now;
56 TimeSpan ts=t2-t1;
57 Console.WriteLine(ts.TotalMilliseconds) ;
58 Console.Read() ;


算法

检索文本文件长度 / 耗费时间(ms)

正则算法

10个汉字/ 980
100个汉字/999
1000个汉字/1234

普通算法

10个汉字/ 234
100个汉字/234
1000个汉字/265
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 转播转播 分享分享 分享淘帖
台州维博网络(www.tzweb.com)专门运用PHP+MYSQL/ASP.NET+MSSQL技术开发网站门户平台系统等。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

网站推广
关于我们
  • 台州朗动科技(Tzweb.com)拥有多年开发网站平台系统门户手机客户端等业务的成功经验。主要从事:政企网站,系统平台,微信公众号,各类小程序,手机APP客户端,浙里办微应用,浙政钉微应用、主机域名、虚拟空间、后期维护等服务,满足不同企业公司的需求,是台州地区领先的网络技术服务商!

Hi,扫描关注我

Copyright © 2005-2026 站长论坛 All rights reserved

Powered by 站长论坛 with TZWEB Update Techonolgy Support

快速回复 返回顶部 返回列表