方法一:使用正则表达式
1//脏字典数据存放文件路径
สตริงคงที่ส่วนตัว 2 รายการ FILE_NAME="zang.txt";
3 //脏数据字典表,如:脏数据一|脏数据二|脏数据三
4 สตริงคงที่สาธารณะ DirtStr = "";
5
6 สาธารณะ ValidDirty()
7 {
8 ถ้า (HttpRuntime.Cache["Regex"]==null)
9 {
10 DirtStr=ReadDic();
11 //用于检测脏字典的正则表达式
12 Regex validateReg= ใหม่ Regex("^((?!"+dirtyStr+").(? 13 HttpRuntime.Cache.Insert("Regex" ,validateReg,null,DateTime.Now.AddMinutes(20) ,TimeSpan.Zero);
14 }
15
16 }
17 สตริงส่วนตัว ReadDic()
18 {
19 FILE_NAME=สภาพแวดล้อม.CurrentDirectory+" \"+FILE_NAME ;
20
21 ถ้า (!File.Exists(FILE_NAME))
22 {
23 Console.WriteLine("{0} ไม่มีอยู่.", FILE_NAME);
24 กลับ "";
25 }
26 StreamReader sr = File.OpenText(FILE_NAME);
27 อินพุตสตริง = "";
28 ในขณะที่ (sr.Peek() > -1)
29 {
30 อินพุต += sr.ReadLine() ;
31 }
32
33 sr.ปิด();
34 ส่งคืนอินพุต;
35
36 }
37
38
39 บูลสาธารณะ ValidByReg (str สตริง)
40 {
41 Regex reg=(Regex)HttpRuntime.Cache["Regex"];
42 ส่งคืน reg.IsMatch(str) ;
43
44 }
感觉这种方法的执行效率不是很高,简单的测试了一下 1000字的文章,脏字典有800多个关键字式了一下1.238秒,大家有没有更好的方法,请不吝赐教!
เหตุผลหลัก:
บูลสาธารณะ ValidGeneral (string str)
-
ถ้า(!File.Exists(FILE_NAME))
-
Console.WriteLine("文件路径或者文件路径不存在错误信息") ;
กลับเท็จ;
-
อื่น
-
StreamReader objReader = StreamReader ใหม่ (FILE_NAME,System.Text.Encoding.GetEncoding("gb2312"));
สตริง sLine="";
ArrayList arrText = ใหม่ ArrayList();
ในขณะที่ (sLine != null)
-
sLine = objReader.ReadLine();
ถ้า (sLine != null)
arrText.Add(sLine);
-
objReader.ปิด();
foreach (สตริง sOutput ใน arrText)
-
string[] strArr=sOutput.Split('|');
สำหรับ (int i = 0; i < strArr.Length; i++)
-
ถ้า (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=ใหม่ ValidDirty() ;
54 Console.WriteLine(vd.ValidByReg(str)); ;
55 DateTime t2 =วันที่และเวลาตอนนี้;
56 ช่วงเวลา ts=t2-t1;
57 Console.WriteLine(ts.TotalMilliseconds) ;
58 Console.Read() ;
算法 |
检索文本文件长度/ 耗费时间( ms ) |
正则算法 |
10 个汉字/ 980 |
100 个汉字/999 |
1,000 个汉字/1234 |
普通算法 |
10 个汉字/234 |
100 个汉字/234 |
1,000 个汉字/265 |
脏字典下载