学习正则!超基础简单例子
这类url地址追加参数变为:http://gimoo.net?a=1&b=2
但是怎么知道已经存在相同参数名呢,例如有这种情况:http://gimoo.net?a=1&a=2
这个虽然不会有什么大错误,但是地址栏这样看起来很不好。那怎么办呢?用正则解决吧(本来我想用php的字符串处理解决的,但是后来觉得要学一下正则了就用正则做吧)
以下是我用于返回上一页的后台处理方法
function _goBack($msg=null,$get=array()) {
$url = $_SESSION['BACKURL'];
if($get!=array())
foreach ($get as $k=>$g){
$url.='&'.$k.'='.$g;//先追加所有要追加的参数,不管是否重复
if(count(explode("&{$k}=",$url))>2){//假如以"&a="这种格式分割目前url字符串发现有超过两个的分割数组,即表明该字符串有重复参数
$url=preg_replace("/{$k}=[a-zA-Z0-9]*&/",'',$url);//正则替换所有"&a=x"为空
}
}
unset($_SESSION['BACKURL']);
$this->alert($msg,$url);
}
简单的解释:
“/{$k}=[a-zA-Z0-9]*&/”假如我们假设$k=”a”,即”/a=[a-zA-Z0-9]*&/”
不知道有没理解错,这个意思其实是匹配以"a="开头,紧跟任意数字字母组合([a-zA-Z0-9]*:意思是任意单个数字或者字母字符,可以把*理解为对前面那个任意字符的重复,如u*可以理解为:uuuu.....,不限制个数的u排列,这里的*可以用{0,}代替),再紧跟"&"。
这是个很简单的例子,但是看网上的关于正则语法的描述,总感觉看不明白,不知道是我理解能力问题还是写得人说得太深奥。
另外解释一下,为什么这样就可以去除重复,原理很简单,http://gimoo.net?a=1&a=2被替换”&a=x”格式字符的时候最后一个正好不会被删除,要知道我们循环中每次我们都是把新参数放在最后面的。
匹配5到10位无重复数字的正则表达式
对于有重复的5到10位数字可以使用d{5,10}这样的正则无重复的5到10位数字我考虑了一下还不会,最然只好查网上。有一个版本还不错,反正RegexBuddy测试
DW 查找某字符串前的所有字符的正则表达式
我使用DW这个所见所得的编辑器来写html时,喜欢写上注释,如!--header--等等的注释,在一次比较大的改动时,需要批量查找替换,为了批量操作,于是我
用正则查找html中有id属性的html标签
如:字符串divstyle="float:left"id="ab"123213/divdivclass="a123"21314423/div不匹配divclass="a123"……/div的内容写这个例子可以用[a-zA-Z0-9][^]+?id=[^]+?.*?/div匹配上一个php例