正则表达式学习笔记

作者:深空 来源:蓝色理想 时间:2008-04-15 07:44:00 

最近在学习正则,一些比较有用的东西怕忘记,记下来,比较乱,想一条记录一条:

正则表达式在线测试

//匹配文本,这个偶尔比较好用,但是要小心字符中包含\E
$str = '[a-z]';
$str = preg_replace('/\G[a-z]\E/', '', $str);
echo $str; //打印空,全被替换掉了,相关大概就是preg_quote功能
复制内容到剪贴板代码:
//给匹配结果命名,这样在匹配结果中就可以用这个名称来获取值
$str = 'abc123abc';
preg_match('/(?P<num>\d )/', $str, $arr);
echo $arr['num']; //相当于echo $arr[1]

//仅用于分组的括号,匹配内容不会被变量捕获,有时候需要这样提高执行效率
$str = 'abc123abc';
preg_match('/abc(?:\d )/', $str, $arr);
echo $arr[1]; //除了$arr[0]外没有$arr[1]了,不会赋予\1

//插入的好帮手,向前、向后锚点搜索位置,每3位添加一个逗号
$str = 'fdfad123456789fdfd';
$str = preg_replace('/(?<=\d)(?=(\d{3}) (?!\d))/', ',', $str);
echo $str; //打印 fdfad123,456,789fdfd

//以最少的结果匹配
$str = 123456;
preg_match('/\d /', $str, $arr);
echo $arr[0]; //是人都知道是123456吧
preg_match('/\d ?/', $str, $arr);
echo $arr[0]; //这次是1

//一个比较有用的,可以判断前面的是否有匹配过,比如下边的例子,可以忽略等号右边是否有单引号双引号或者什么都没有
$str = <<<HTML
<font size=12></font>
<font size='13'></font>
<font size="14"></font>
<font size="15></font>
HTML;
preg_match_all('/<font\s size=([\'"]?)(\d )\1[^>]*>/', $str, $arr);
print_r($arr);
/*
Array
(
    [0] => 12
    [1] => 13
    [2] => 14
)
*/

//部分模式修饰符,模式修饰符也可以放在表达式中的
//这里匹配符合XHTML规范的style里的颜色值,大写的STYLE被忽略了,但是里面的color可以大小写无所谓
$str = '<b style="COLOR:red"></b><b STYLE="color:blue"></b><b style="color:green"></b>';
preg_match_all('/style=([\'"]?)(?i)color:(\w )\1(?-i)/', $str, $arr);
print_r($arr[2])
//也可以把匹配内容放到里面,用:隔开,就不用写结束(?-i)
//preg_match_all('/style=([\'"]?)(?i:color:(\w ))\1/', $str, $arr);
//再看一例子
$str = '<B>Style</B>';
preg_match('/<B>(?i:style)<\/B>/', $str, $arr);
print_r($arr); //可以匹配到
$str = '<B>Style</b>';
preg_match('/<B>(?i:style)<\/B>/', $str, $arr);
print_r($arr); //什么都没匹配到

//单词检索,可惜只能用在英文
$str = 'I\'m a teacher';
preg_match_all('/\b[a-z] \b/i', $str, $arr);
print_r($arr)
复制内容到剪贴板代码:
//u修饰符,按unicode匹配
$str = '你您';
$str = preg_replace('/[你您]/', 'you', $str);
echo $str; //被拆开了,打印4次you
//看下面加上u修饰符后的效果,该修饰符需要编码utf-8否则会报错
//我的文本都是gb2312,所以要转成utf-8
$str = iconv('gb2312', 'utf-8', '你您');
$regex = iconv('gb2312', 'utf-8', '/[你您]/u');
$str = preg_replace($regex, 'you', $str);
echo $str; //打印2次you

//x模式修饰符,可以忽略空白和加注释
$str = 'test Test';
preg_match('/test  #只匹配小写的test/x', $str, $arr);
print_r($arr);
复制内容到剪贴板代码:
//排除环视(?<!...) (?!...)、忽略优先 *? ? ?? 的复合使用
$str = 'test <B>test1<B> test2</B>';
preg_match('/<B>(?:.(?<!<B>))*<\/B>/i', $str, $arr);
//或者 preg_match('/<B>(?:(?!<B>).)*<\/B>/i', $str, $arr);
print_r($arr)
//当时这样写应付不了 $str = 'test <B>test1<B> test2</B> test3</B>';
//改写一下正则既可 preg_match_all('/<B>(?:(?!<\/?B>).)*<\/B>/i', $str, $arr);
//根据上面来完成一个最简单的UBB替换
$str = 'test [b]test1[b] test2[/b] test3[/b]test';
$str = preg_replace('/\[B\]((?:(?!\[\/?B\]).)*)\[\/B\]/i', '<b>\1</b>', $str);
$str = preg_replace('/\[B\]((?:(?!\[\/?B\]).)*)\[\/B\]/i', '<b>\1</b>', $str);
print_r($str)

//如果已经确认回朔并不会有匹配结果,可以使用固化分组来放弃备用状态提高效率
$str = 'Subject';
preg_match('/(\w ):/', $str, $arr);
//用以下方法代替
//在第一组匹配规则匹配到文本末尾t时匹配结束,启用第二组匹配规则:并不会找到结果,所以这个时候回朔查找,但是\w不会包含:,所以可以直接放弃,
preg_match('/(?>\w ):/', $str, $arr);

标签:正则表达式,javascript,笔记
0
投稿

猜你喜欢

  • 用VB生成DLL封装ASP代码一个例子:连接access数据库等

    2008-04-07 13:06:00
  • 兼容IE,FF的弹出层登陆界面代码

    2008-01-04 12:13:00
  • Tag与Tagging

    2009-10-15 12:59:00
  • 同时安装sql2000和sql2005,经验点滴

    2008-03-04 17:56:00
  • CSS元素类型

    2009-04-27 12:25:00
  • 面向对象的CSS

    2009-07-03 12:23:00
  • 一个ASP(VBScript)简单SQL语句构建“类”

    2008-03-12 07:08:00
  • MySQL表设计优化与索引 (九)

    2010-10-25 20:16:00
  • 潜谈产品设计中的可用性和可访问性

    2009-01-18 12:47:00
  • 探讨链接打开方式

    2009-03-16 16:55:00
  • asp程序定义变量比不定义变量速度快一倍

    2012-12-04 20:06:32
  • 带你深入了解SQL Server 2008的独到之处

    2009-01-07 14:20:00
  • 4款Javascript放大镜特效脚本

    2009-10-14 20:46:00
  • SQL 2008 FileStream数据类型

    2008-10-28 21:07:00
  • 利用SQL语句对不同数据库进行高效果分页

    2008-11-28 14:44:00
  • 写了一个小巧的jquery拾色工具

    2009-12-21 14:22:00
  • MYSQL数据库设计的一点总结

    2008-05-24 09:36:00
  • 从浏览器想开去

    2008-07-29 12:52:00
  • 如何调用SQL Server的存储过程?

    2009-11-15 20:15:00
  • 建立适当的索引是实现查询优化的首要前提

    2009-01-19 13:11:00
  • asp之家 网络编程 m.aspxhome.com