学习正则!超基础简单例子

问题是这样的,某个情况下要给:http://jb51.net?a=1

这类url地址追加参数变为:http://jb51.net?a=1&b=2

但是怎么知道已经存在相同参数名呢,例如有这种情况:http://jb51.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://jb51.net?a=1&a=2被替换”&a=x”格式字符的时候最后一个正好不会被删除,要知道我们循环中每次我们都是把新参数放在最后面的。

时间: 2024-10-12 00:17:33

学习正则!超基础简单例子的相关文章

学习正则!超基础简单例子_正则表达式

问题是这样的,某个情况下要给:http://jb51.net?a=1 这类url地址追加参数变为:http://jb51.net?a=1&b=2 但是怎么知道已经存在相同参数名呢,例如有这种情况:http://jb51.net?a=1&a=2 这个虽然不会有什么大错误,但是地址栏这样看起来很不好.那怎么办呢?用正则解决吧(本来我想用php的字符串处理解决的,但是后来觉得要学一下正则了就用正则做吧) 以下是我用于返回上一页的后台处理方法 复制代码 代码如下: function _goBack

学php正则!超基础简单例子

问题是这样的,某个情况下要给:http://jb51.net?a=1 这类url地址追加参数变为:http://jb51.net?a=1&b=2 但是怎么知道已经存在相同参数名呢,例如有这种情况:http://jb51.net?a=1&a=2 这个虽然不会有什么大错误,但是地址栏这样看起来很不好.那怎么办呢?用正则解决吧(本来我想用php的字符串处理解决的,但是后来觉得要学一下正则了就用正则做吧) 以下是我用于返回上一页的后台处理方法 复制代码 代码如下: function _goBack

Python网络编程学习:Socket基础

1. Socket基础 客户端与服务器连接有两种方式:TCP和UDP,TCP是面向连接的方式(三次握手.四次挥手等),可靠但耗资源,而UDP采用无连接方式,不可靠但速度快.这里面的学问很多,但大部分人知道这些就足够了 2. 一个简单的TCP例子(阻塞方式) 不管是Python还是其它语言,Socket编程几乎都有一个固定模板,下面看一个简单例子,用于计算阶乘和,比如客户端发送5,服务器端返回5!+4!+3!+2!+1!. Server端Python代码: import socket sock =

学习网页制作基础入门教程(8)框架标签

教程|入门教程|网页 相关文章: 学习网页制作基础入门教程(1)网页编写 学习网页制作基础入门教程(2)排版标签 学习网页制作基础入门教程(3)字体标签 学习网页制作基础入门教程(4)图象标签 学习网页制作基础入门教程(5)图象标签 学习网页制作基础入门教程(6)连接标签 学习网页制作基础入门教程(7)表格标签 框架概念 1. 首先,各位先看看右边这张图片,将利用这张图来做解释,这样子,讲起来可能会清楚一些. 我们可以看见,右边的这个图片,一共分为 1 . 2 . 3 三个框架,每一个框架,各有

学习网页制作基础入门教程(2)排版标签

教程|入门教程|网页 相关文章: 学习网页制作基础入门教程(1)网页编写 文字上的分隔标签 1. 使用方法:强制断行标签<BR> .强制分段标签<P> 2. 标签解说:我们在写文章时,有时候在特定的地方会强迫断行(<BR> ),或是在写完某一段的时候便会分段(<P>),制作网页也一样,而且更需要断行及分段的功能,以免整个网页看起来乱糟糟的. 3. 使用范例: 原始代码 显示结果  这是一个断行的例子 <BR> 看出来了吗?网页教学网 这是一个断行

WML的简单例子及编辑、测试方法第1/2页_WML教程

                        完成WAP服务器的建立和WAP浏览器的安装之后,我们接下来就可以使用WML语言来编写WAP网页或应用,并通过WAP服务器及浏览器进行调试.从本章开始我们将系统地学习WML语言,本章主要讲解WML语言的基础知识,下一章全面讲解WML的语法.标签和规则. 2.1 WML的简单例子及编辑.测试方法 无限标记语言WML(Wireless Markup Language)是一种基于扩展标记语言XML(Extension Markup Language)的语言

学习网页制作基础入门教程(7)表格标签

教程|入门教程|网页 相关文章: 学习网页制作基础入门教程(1)网页编写 学习网页制作基础入门教程(2)排版标签 学习网页制作基础入门教程(3)字体标签 学习网页制作基础入门教程(4)图象标签 学习网页制作基础入门教程(5)图象标签 学习网页制作基础入门教程(6)连接标签 表格单元格对齐位置设定 1. 首先我们来看一个最简单的表格: 原始代码 显示结果 <TABLE BORDER=1><TR><TD>1</TD></TR></TABLE&g

学习网页制作基础入门教程(6)连接标签

教程|入门教程|网页 相关文章: 学习网页制作基础入门教程(1)网页编写 学习网页制作基础入门教程(2)排版标签 学习网页制作基础入门教程(3)字体标签 学习网页制作基础入门教程(4)图象标签 学习网页制作基础入门教程(5)图象标签 网页内部的连接 1. 使用方法: 先在欲连接处作记号:<A NAME="here"> 这里是你想连接的点 </A> 设定连接:<A HREF="#here"> 连接 </A> 2. 标签解

学习网页制作基础入门教程(4)图象标签

教程|入门教程|网页 相关文章: 学习网页制作基础入门教程(1)网页编写 学习网页制作基础入门教程(2)排版标签 学习网页制作基础入门教程(3)字体标签 图象标签 1. 使用方法:<IMG SRC="/UploadPic/2007-7/200777152731585.gif" ALT="本站特约模特儿" ALIGN=RIGHT BORDER=0 HSPACE=2 VSPACE=2 HEIGHT=56 WIDTH=32> 2. 标签解释:目前常见的网页图形