当前位置: 首页 > 图文教程 > 网络编程 > 正则表达式 > 正则表达式匹配 非XXX的行

正则表达式
无殇 javascript正则练习器
javascript用正则表达式把1234567890替换为abcdefghij
一个匹配形如“#100”的正则表达式
又一不错的应用-正则来查找替换字符串
[asp]中的正则表达式运用代码
asp 正则表达式检测http开头的函数
javascript下正则匹配百分比的代码
javascript下一个还原html代码的正则
JS正则表达式提取字符串中所有汉字的脚本
[asp]匹配网址的正则
[js]一个只删除所有font标签的正则函数
[原创]正则替换字符串功能
javascript 正则 判断是否是数字的脚本
[a] 1 [/a]转换为网址的UBB的正则
PHP下ereg实现匹配ip的正则
[js]用JAVASCRIPT正则表达式限制文本字节数的代码
dw(dreamweaver)正则表达式函数列表
[原创]java 正则表达式基础,实例学习资料收集大全
asp下替换非数字为空的正则
javascript利用正则快速找出两个字符串的不同字符

正则表达式匹配 非XXX的行


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-13   浏览: 50 ::
收藏到网摘: n/a

问题:如何匹配"非:.+123.123.123.10.+ " 行
1111111111111
前边有内容,不定123.123.123.10后边有内容,不定
3333333333333
4444444444444

如何匹配"非:.+123.123.123.10.+ "

匹配结果是,
1111111111111
3333333333333
4444444444444
结论:
^(?!.*123.123.123.10).*$
或C#里这么操作:
textBox2.Text = Regex.Replace(textBox1.Text, @"\n.*123\.123\.123\.10.*\n", "\n\r\n");
string result = Regex.Replace(str, @"^.*?123\.123\.123\.10.*$", "", RegexOptions.Multiline);
Regex reg =new Regex(@"(?<=^|\r\n)(?!123\.123\.123\.10).+");
总结:
匹配非“非内容”的行的表达式应该写成:^(?!.*非内容).*$

===================================
另,再来个例子:
2008-07-14 15:44:40 W3SVC491 60.27.236.4 GET /Item/How-To-Connection-My-Computer-Flow-IP-yongfa365.html - 80 - 74.6.22.106 Mozilla/5.0+(compatible;+Yahoo!+Slurp;+http://help.yahoo.com/help/us/ysearch/slurp) 200 0 0
2008-07-14 15:44:51 W3SVC491 60.27.236.4 GET /item/Clear.bat-System-Windows-98-XP-2003-yongfa365.html - 80 - 124.73.140.102 Mozilla/4.0+(compatible;+MSIE+6.0;+Windows+NT+5.0) 200 0 64
2008-07-14 15:44:51 W3SVC491 60.27.236.4 GET /item/Clear.bat-System-Windows-98-XP-2003-yongfa365.html - 80 - 124.73.140.102 Mozilla/4.0+(compatible;+MSIE+6.0;+Windows+NT+5.0) 206 0 64
2008-07-14 15:47:11 W3SVC491 60.27.236.4 GET /Articles.xml - 80 - 65.214.44.28 Bloglines/3.1+(http://www.bloglines.com;+1+subscriber) 200 0 64
2008-07-14 15:47:47 W3SVC491 60.27.236.4 GET /Item/SQL-Server-Store-More-Than-8000-WRITETEXT-UPDATETEXT-yongfa365.html - 80 - 59.125.118.13 Trend+Micro+Web+Protection+Add-On+1.10.1144 200 0 0
找出上而面的行里的,不是以“200 0 64”结尾的行,然后删除
^(?!.*200 0 64).*$
而我一直是这么测试的:
^(?!.*200 0 64)$
没有后边的.* 因为我觉得后边已经没有内容了,所以没写 .* 而不写就不对,写了才行,哪位高人可以再指点下。