免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1625 | 回复: 0
打印 上一主题 下一主题

正则表达式 --PHP [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-07-14 16:15 |只看该作者 |倒序浏览

                                                                   最近一直在做审计邮件、帖子的工作,所以得首先学会正则。虽说网上对正则表达式解释的已经够详尽的了, 但是把网上的试子照搬到php中,还是有一些惹人厌的问题:
譬如在
正则表达式30分钟入门教程
中有个这样的式子(?).*(?=)用于匹配不包含属性的简单HTML标签内里的内容,按道理来说直接在preg_match中运用应该没什么问题,可实际呢:
$str = "aaaaaabbbbbbcccccccddddddfffff";
preg_match("/(?).*(?=)/s", $str, $matches);
var_dump($matches);
结果报错:
Warning: preg_match(): Compilation failed: lookbehind assertion is not fixed length at offset 11...于是把\w+直接写成font:
preg_match("/(?).*(?=)/s", $str, $matches);
YYD,结果尽然为空,这个问题困扰了我好久,瞎猫碰死耗子,将\1无名组换成有名组尽然成了:
preg_match("/(?font)>).*(?=)/s", $str, $matches);
终于成功了,但是那些失败的例子都在正则的
测试工具
里试过了,不知道为什么...
下面举几个经典正则的小例子:
  • \b((?!abc)\w)+\b , 匹配不包含连续字符串abc的单词,对于字符串"asdf abcaa abcbb abab", 它会取出asdf 和 abab。
  • ((?!).|(?R))* 递归匹配,给出上面的字符串aaaaaabbbbbbcccccccddddddfffff,其会从中引出两组:0组,aaaaaabbbbbbcccccccdddddd 1组,dddddd。其它的以后再写。
    给出几其他人的好文章:
    C#基础回顾:正则表达式
    正则表达式30分钟入门教程
    正则表达式高级技巧背后的关键概念
    表达式的递归匹配
    递归深度匹配 正则表达式
                   
                   
                   
                   
                   
                   
                   
                   

    本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u1/54338/showart_1995965.html
  • 您需要登录后才可以回帖 登录 | 注册

    本版积分规则 发表回复

      

    北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
    未成年举报专区
    中国互联网协会会员  联系我们:huangweiwei@itpub.net
    感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

    清除 Cookies - ChinaUnix - Archiver - WAP - TOP