清那位大虾讲一下正则表达式的用法!初次接触,不懂! 一下两下真是讲不清的,自己看看《PHP高级编程》吧,想学PHP的值得买一本的 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 通常上, 正则表达式会用到以下的几个"符号": ^ - 代表字串前面一定要有这样的字, 如^http://, 代表前面一定要有http:// $ - 代表字串后面一定要有这样的字. ? (一个问号) - 它代表一个或没有字元 * (一个*) - 它代表没有或者更多前面的字元 . (一个句点) - 它代表任何一个字元 + (一个加) - 它代表至少一个或更多前面的字元 [xyz] - 它代表任何一个字元, 或x, 或y, 或z [a-z] - 它代表任何一个字元, 由a至z [[:alnum:]] - 代表由a至z, 0至9 [[:digit:]] - 代表由0至9 当使用正则表达式时, 必需注意ereg及eregi可大大不同喔~ ereg是非常敏感的 (意即大小字母都分得非常清楚), 而eregi则不是 (只要记着i代表case-insensitive就可以了) 这里举一些例子: $regexp = eregi("a?c", "abc"); //-- 这是对的, 因?可以代表"一个"或没有字元 $regexp = eregi("a?c", "ac"); //-- 这也是对的, 因?可以代表一个或"没有"字元 $regexp = eregi("a?c", "a"); //-- 这样就不对了, 纵使有a, 可是还是要有c $regexp = eregi("[abc]", "a"); //-- 这是对的, 因a是大括号里的其中一个字元 $regexp = eregi("[a-z]", "c"); //-- 这是对的, 因c包括在a至z里 $regexp = eregi("[a-z]", "0"); //-- 这是不对的, 因0并不包括在a至z里面 $regexp = eregi("a.c", "abc"); //-- 这是对的, 因一个.代表"任何"一个字 $regexp = eregi("a.c", "ac"); //-- 这可就不对了, 因.代表"一个"字元, 所以放abbc也是不对的 $regexp = eregi("a+c", "aaaac"); //-- 这是对的, 因+代表一人或"更多"前面的字元 $regexp = eregi("a+c", "abbc"); //-- 这样是不对的, +代表一个或更多"前面的字元", 而不是代表任何一个字元 $regexp = eregi("a+c", "abc"); //-- 这样也是不对的, 注释如上 $regexp = eregi("[^abc]", "a"); //-- 这是比较不同的一点, 那就是如果^出现在[]里面, 代表"除"了里面的字, 全部都是对的. $regexp = eregi("[^abc]", "d"); //-- 这是对的, 因d并不在abc里面 $regexp = eregi("[^[:alnum:]]", "9"); //--这是对的, 因~并不包括在a至z, 0至9里面 当然, [[:digit:]]用法也是相同: $regexp = eregi("[^[:digit:]]", "a"); //-- 这是对的, 因a并不包括在0至9里面 最后, 举个有用的例子, 比如说, 我要每个人的密码都不准拥有0至9, 可以这样试验: $regexp = eregi("^[^0-9]+$", "aaa9"); //--把aaa9当做密码 if ($regexp == "") { echo "密码拥有号码, 请改过"; } else { echo "密码没有号码, 通过"; } 测验显示, 密码拥有号码, 请改过. 相信每个人都看到, [^0-9]前后各有^及$, 这是为了确保前后不能拥有号码, 而+则确保中间没有任何的号码, []里面的^, 则是"除了0至9之外, 其他一律通过" 所以只要将9拿去, 就会显示"密码没有号码, 通过"了 ! 现在就来看看eregi_replace的强大功能 :) 在这里先介绍一下, ereg_replace与eregi_replace的不同点, ereg_replace是极为敏感的, 而eregi_replace则不是, 除此之外, 运用eregi_replace, 我们还可将一个字串的格式改变呢 ! 就拿一个普通的例子吧: <a href=http://www.testing.com>testing</a>, 我们当如何将之改变为 testing 的网址为 http://www.testing.com 这样的格式呢 ? 以下就会谈到如何运用它及运用的步骤 (一) 首先, 将欲改变的字串放进一个变数里: $string = "<a href=http://www.testing.com>testing</a>"; (二) 由$string可知, <a href> 及 </a>是永远不会改变的, 我们就定义为 $string = "<a href=http://www.testing.com>testing</a>"; $regexp = eregi_replace("<a href=></a>", "", $string); (三) a与href之间都一定要有空格, 等于符号左右可以有空格, </a>也可写成< /a>或</a >或更多写法, 所以就要去除之间的空格 $string = "<a href=http://www.testing.com>testing</a>"; $regexp = eregi_replace("<a[[:space:]]+href[[:space:]]*=[[:space:]]*><[[:space:]]*/a[[:space:]]*>", "", $string); //-- 记着[[:space:]]+意思为至少要有一个空格, 而[[:space:]]*则可以或没有空格 (四) 现在定义href=之后的网址, 也就是我们想得到的, 我们可以用()将它包起来 $string = "<a href=http://www.testing.com>testing</a>"; $regexp = eregi_replace("<a[[:space:]]+href[[:space:]]*=[[:space:]]*([^>]+)><[[:space:]]*/a[[:space:]]*>", "", $string); //-- 运用[^>]+, 是因为我们至少要有一个字, 而这个字不可以是">" (五) 接下来就是定义<a></a>之间的字串, 也是我们想要的, 所以也要用()将它包起来: $string = "<a href=http://www.testing.com>testing</a>"; $regexp = eregi_replace("<a[[:space:]]+href[[:space:]]*=[[:space:]]*([^>]+)>([[:alnum:]]+)<[[:space:]]*/a[[:space:]]*>", "", $string); //-- 运用[[:alnum:]]+, 这是因为这里我们可以放数目字, 或是其他的字, 而+代表至少一个字 (六) 定义好之后, 各位应该还记得刚刚用()包起来的, 是我们想要的吧, 我们可以运用像array的方式将()里的值 取出来, 例子第一个()里的值, 我们就用\\1取它出来, 第二个(), 我们就用\\2取它出来, 并将它echo出来 $string = "<a href=http://www.testing.com>testing</a>"; $regexp = eregi_replace("<a[[:space:]]+href[[:space:]]*=[[:space:]]*([^>]+)>([[:alnum:]]+)<[[:space:]]*/a[[:space:]]*>", "\\2 的网址为 \\1", $string); echo $regexp; 我们可以发现, 它echo出来的值是'testing 的网址为 http://www.testing.com', 这也就代表着我们成功了 ! URL 重定向的问题 apache链接mysql出错~~求解~~~ 请大伙忙看看这个语句怎么改!谢 了 乱码问题 mysql的close有没有必要? 乱码问题,好怪的问题,大家帮忙看看了.. php如何连接access和sql anywhere数据库? 關於PHP從WINDOWS平台上移到linux下面(在線等) 求解一段代码,比较费解 php的proc_open打开大文件执行tac命令会报Broken pipe错误然后僵死 php在IIS上配置的问题? 如何禁止对目录进行访问
^ - 代表字串前面一定要有这样的字, 如^http://, 代表前面一定要有http://
$ - 代表字串后面一定要有这样的字.
? (一个问号) - 它代表一个或没有字元
* (一个*) - 它代表没有或者更多前面的字元
. (一个句点) - 它代表任何一个字元
+ (一个加) - 它代表至少一个或更多前面的字元
[xyz] - 它代表任何一个字元, 或x, 或y, 或z
[a-z] - 它代表任何一个字元, 由a至z
[[:alnum:]] - 代表由a至z, 0至9
[[:digit:]] - 代表由0至9 当使用正则表达式时, 必需注意ereg及eregi可大大不同喔~
ereg是非常敏感的 (意即大小字母都分得非常清楚), 而eregi则不是 (只要记着i代表case-insensitive就可以了) 这里举一些例子: $regexp = eregi("a?c", "abc"); //-- 这是对的, 因?可以代表"一个"或没有字元
$regexp = eregi("a?c", "ac"); //-- 这也是对的, 因?可以代表一个或"没有"字元
$regexp = eregi("a?c", "a"); //-- 这样就不对了, 纵使有a, 可是还是要有c $regexp = eregi("[abc]", "a"); //-- 这是对的, 因a是大括号里的其中一个字元
$regexp = eregi("[a-z]", "c"); //-- 这是对的, 因c包括在a至z里
$regexp = eregi("[a-z]", "0"); //-- 这是不对的, 因0并不包括在a至z里面 $regexp = eregi("a.c", "abc"); //-- 这是对的, 因一个.代表"任何"一个字
$regexp = eregi("a.c", "ac"); //-- 这可就不对了, 因.代表"一个"字元, 所以放abbc也是不对的 $regexp = eregi("a+c", "aaaac"); //-- 这是对的, 因+代表一人或"更多"前面的字元
$regexp = eregi("a+c", "abbc"); //-- 这样是不对的, +代表一个或更多"前面的字元", 而不是代表任何一个字元
$regexp = eregi("a+c", "abc"); //-- 这样也是不对的, 注释如上 $regexp = eregi("[^abc]", "a"); //-- 这是比较不同的一点, 那就是如果^出现在[]里面, 代表"除"了里面的字, 全部都是对的.
$regexp = eregi("[^abc]", "d"); //-- 这是对的, 因d并不在abc里面
$regexp = eregi("[^[:alnum:]]", "9"); //--这是对的, 因~并不包括在a至z, 0至9里面
当然, [[:digit:]]用法也是相同:
$regexp = eregi("[^[:digit:]]", "a"); //-- 这是对的, 因a并不包括在0至9里面 最后, 举个有用的例子,
比如说, 我要每个人的密码都不准拥有0至9, 可以这样试验:
$regexp = eregi("^[^0-9]+$", "aaa9"); //--把aaa9当做密码
if ($regexp == "") {
echo "密码拥有号码, 请改过";
} else {
echo "密码没有号码, 通过";
} 测验显示, 密码拥有号码, 请改过.
相信每个人都看到, [^0-9]前后各有^及$, 这是为了确保前后不能拥有号码, 而+则确保中间没有任何的号码,
[]里面的^, 则是"除了0至9之外, 其他一律通过"
所以只要将9拿去, 就会显示"密码没有号码, 通过"了 !
现在就来看看eregi_replace的强大功能 :)
在这里先介绍一下, ereg_replace与eregi_replace的不同点, ereg_replace是极为敏感的, 而eregi_replace则不是,
除此之外, 运用eregi_replace, 我们还可将一个字串的格式改变呢 !
就拿一个普通的例子吧: <a href=http://www.testing.com>testing</a>, 我们当如何将之改变为
testing 的网址为 http://www.testing.com 这样的格式呢 ?
以下就会谈到如何运用它及运用的步骤 (一)
首先, 将欲改变的字串放进一个变数里:
$string = "<a href=http://www.testing.com>testing</a>"; (二)
由$string可知, <a href> 及 </a>是永远不会改变的, 我们就定义为
$string = "<a href=http://www.testing.com>testing</a>";
$regexp = eregi_replace("<a href=></a>", "", $string); (三)
a与href之间都一定要有空格, 等于符号左右可以有空格, </a>也可写成< /a>或</a >或更多写法, 所以就要去除之间的空格
$string = "<a href=http://www.testing.com>testing</a>";
$regexp = eregi_replace("<a[[:space:]]+href[[:space:]]*=[[:space:]]*><[[:space:]]*/a[[:space:]]*>", "", $string);
//-- 记着[[:space:]]+意思为至少要有一个空格, 而[[:space:]]*则可以或没有空格 (四)
现在定义href=之后的网址, 也就是我们想得到的, 我们可以用()将它包起来
$string = "<a href=http://www.testing.com>testing</a>";
$regexp = eregi_replace("<a[[:space:]]+href[[:space:]]*=[[:space:]]*([^>]+)><[[:space:]]*/a[[:space:]]*>", "", $string);
//-- 运用[^>]+, 是因为我们至少要有一个字, 而这个字不可以是">" (五)
接下来就是定义<a></a>之间的字串, 也是我们想要的, 所以也要用()将它包起来:
$string = "<a href=http://www.testing.com>testing</a>";
$regexp = eregi_replace("<a[[:space:]]+href[[:space:]]*=[[:space:]]*([^>]+)>([[:alnum:]]+)<[[:space:]]*/a[[:space:]]*>", "", $string);
//-- 运用[[:alnum:]]+, 这是因为这里我们可以放数目字, 或是其他的字, 而+代表至少一个字 (六)
定义好之后, 各位应该还记得刚刚用()包起来的, 是我们想要的吧, 我们可以运用像array的方式将()里的值
取出来, 例子第一个()里的值, 我们就用\\1取它出来, 第二个(), 我们就用\\2取它出来, 并将它echo出来
$string = "<a href=http://www.testing.com>testing</a>";
$regexp = eregi_replace("<a[[:space:]]+href[[:space:]]*=[[:space:]]*([^>]+)>([[:alnum:]]+)<[[:space:]]*/a[[:space:]]*>", "\\2 的网址为 \\1", $string);
echo $regexp;
我们可以发现, 它echo出来的值是'testing 的网址为 http://www.testing.com', 这也就代表着我们成功了 !