方法一:使用正则表达式
1//隐藏数据存放文件路径
2 私有静态字符串FILE_NAME="zang.txt";
3 // 脏数据字典表,如:脏数据一|脏数据二|脏数据三
4 公共静态字符串 dirtyStr="";
5
6 公共 ValidDirty()
7 {
8 if (HttpRuntime.Cache["Regex"]==null)
9 {
10、dirtyStr=ReadDic();
11 //用于检测字典的正则表达式
12 正则表达式 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 私有字符串ReadDic()
18{
19 FILE_NAME=Environment.CurrentDirectory+" \"+FILE_NAME ;
20
21 if (!File.Exists(FILE_NAME))
22{
23 Console.WriteLine("{0}不存在。", FILE_NAME);
24返回“”;
25}
26 StreamReader sr = File.OpenText(FILE_NAME);
27 字符串输入=“”;
28 while (sr.Peek() > -1)
29{
30 输入 += sr.ReadLine() ;
31}
32
33 sr.关闭();
34返回输入;
35
36}
37
38
39 public bool ValidByReg(字符串 str)
40{
41 正则表达式 reg=(Regex)HttpRuntime.Cache["Regex"];
42 返回 reg.IsMatch(str) ;
43
44 }
感觉这种方法的执行效率不太好,简单的测试页面1000字的文章,藏字典有800多个关键字式页面是1.238秒,大家没有更好的方法,请不吝赐教!
方法二:普通循环查找方法
public bool ValidGeneral(string str)
{
if(!File.Exists(FILE_NAME))
{
Console.WriteLine("文件路径或者文件路径不存在错误信息") ;
返回假;
}
别的
{
StreamReader objReader = new StreamReader(FILE_NAME,System.Text.Encoding.GetEncoding("gb2312"));
字符串 sLine="";
ArrayList arrText = new ArrayList();
while (sLine != null)
{
sLine = objReader.ReadLine();
if (sLine != null)
arrText.Add(sLine);
}
objReader.Close();
foreach(arrText 中的字符串 sOutput)
{
string[] strArr=sOutput.Split('|');
for (int i = 0; i < strArr.Length; i++)
{
if (str.IndexOf(strArr[i])!=-1)
{
返回假;
}
}
}
返回真;
}
}
以下是测试的方法,有什么问题还请大家指出!
1DateTime t1 =DateTime.Now;
2 字符串 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 日期时间 t2 =日期时间.Now;
56 时间跨度 ts=t2-t1;
57 Console.WriteLine(ts.TotalMilliseconds);
58 Console.Read();
算法 |
检索文本文件长度/ 成分时间( ms ) |
正则表达式 |
10 个汉字/980 |
100 个汉字/999 |
1000 个汉字/1234 |
普通算法 |
10 个汉字/234 |
100 个汉字/234 |
1000 个汉字/265 |
脏字典下载