正则表达式(入门)

定锚点,去噪点,取数据

1、入门:正则字符

关于正则字符,很多文章都会讲到,足足有一篇文章才能描述清楚,我这里就不多说,对于我,平时,常用的有:

  1. . 匹配不包括换行的任意字符,在php的s修饰符下面可以匹配换行,如$pattern=‘#<div>(.*?)</div>#s‘;就可以匹配div内容有换行的数据。
  2. \s 空格、tab
  3. * 匹配零个或多个
  4. + 匹配一个或多个,即至少一个
  5. \ 转义

    一个特殊字符前加\就表示转义,说明把它当普通字符用

  6. [] 单字符取一个,比如[abc]会匹配a或b或c

    但是,如果[]里面加上^则会变成排除这个字符,如[^abc]就表示不是a、不是b、也不是c 
    另外,在[]里面可以使用-表示一个范围,如[0-9]表示从0到9,类似的还有[a-zA-Z],如果要包含-字符,可以给它加上转义[\-]

  7. ^ 一行字符串开始(虚拟字符,不实际存在)

    这里的^跟[]里面用的^是同一个字符,但是却不是一个意思,这里它表示一行字符串的开始,比如^www表示以www开头的字符串,注意区分,不在[]里面的是开始符,在里面的排除

  8. $ 一行字符串结束(虚拟字符,不实际存在)
  9. {1,3} 循环次数

    [0-9]{1,3}表示在0-9的范围里面循环1个、2个或者3个,可能结果有5、20、415等

  10. ? 有两个用法

    (1) 匹配一个或零个,比如https?匹配的https(一个s)或者http(零个s)

    (2)非贪婪模式

    所谓非贪婪模式,就是匹配尽可能少的内容,比如,对于源字符串

  1. <div>
  2. a
  3. </div>
  4. <div>
  5. b
  6. </div>

使用<div>(.*?)</div>会得到2个结果:

  1. <div>
  2. a
  3. </div>

  1. <div>
  2. b
  3. </div>

因为,当遇到第一个</div>,非贪婪模式就不会再往后找了。 
而使用<div>(.*)</div>(贪婪模式)则会得到整个字符串

  1. <div>
  2. a
  3. </div>
  4. <div>
  5. b
  6. </div>

,因为它会匹配所有字符直到后面再找不到</div>。 
11. | 多个数据选一(常用于多字符) 
前面提到[]里面的字符有选一个字符功能,但是假如不是一个字符,比如:http|ftp|svn 就需要用|分开,|的作用域是一直往后直到遇到括号,比如,对于源字符串

  1. http abc
  2. ftp abc
  3. svn abc

http|ftp|svn abc匹配的结果是:

  1. http

  1. ftp

  1. svn abc

想要匹配 http abcftp abcsvn abc就要使用括号把前边的协议括起来,如(http|ftp|svn) abc 可以得到预期的结果。 
12. () 数据分界和取数据

上面例子(http|ftp|svn) abc就是数据分界的例子,然后,匹配结果会得到一个[1]的子集数据,这里就是子模式的概念,利用子模式,可以得到想要取出来的数据。子模式1、2、3的计算方法为左括号的计数,从左到右,从1开始,比如: 
(http|ftp|svn)://([^/]+),[1]得到的是(http|ftp|svn)里面的数据,[2]得到([^/]+)里面的数据,对于嵌套括号也是点左括号即可。 
13. (?:) 非捕获组 
上面说到()作为子模式可以得到它里面的数据,但是,有些时候,()只是作为数据分界功能,并不需要取出来,这时候就要用到非捕获组的概念了。比如:(http|ftp|svn)://([^/]+)只想得到域名,也就是[2],那么(http|ftp|svn)就只是数据分界的功能,这里不需要捕获,因此使用非捕获组功能,(?:http|ftp|svn)屏蔽这部分的数据获取,此时,(?:这个左括号要排除出[1]、[2]计数,也就是(?:http|ftp|svn)://([^/]+)中的([^/]+)变成[1]了。



关于常用字符的使用差不多到这里,还有更多的请参考正则表达式30分钟入门教程,这是我看过比较全面的正则入门资料。

2、 操作:定锚点

每一个正则都是有针对性的,只有这样正则才有意义。因此,写正则之前,先观察你要解析的数据,找准唯一的锚点,比如,你要解析一个页面的title标签,得到title内容,那么这个title就是锚点。有时候,所要取的数据确实无法定位一个唯一的锚点,那么,你可以分解数据,先通过一个唯一锚点锁定你的数据块,取出来之后,再对这个数据块取数据即可。比如,有这么一段源字符串:

  1. <div id="module_1">
  2. <div class="content">
  3. content 1
  4. </div>
  5. </div>
  6. <div id="module_2">
  7. <div class="content">
  8. content 2
  9. </div>
  10. </div>

你直接通过class="content"来匹配数据的话很明显会得到两个,那么,你可以扩展它的数据域,先以id="module_1"作为锚点,获取整个

  1. <div id="module_1">
  2. <div class="content">
  3. content 1
  4. </div>
  5. </div>

然后在对这个数据块的数据处理,得到class="contents"的内容即可。 
因此,这里用到2个正则:

(1)<div id="module_1">(.*?)</div>\s*<div id="module_2"> 
(2)<div class="content">(.*?)</div>

总结:锚点,就是能唯一定位你数据的标识

3、 操作:去噪点

所谓去噪点,就是把无关的东西都当浮云,用通配符过掉它,只关心我们想要的数据,比如: 
<meta content="text/html; charset=utf-8" http-equiv="content-type"> 
要从这里得到字符集utf-8,我们需要怎么做? 
首先,定位锚点,有<meta 、charset=和utf-8后面的",其他都是浮云~ 
因此得到正则: 
<meta[^>]*charset=([^"]+)" 
即可,用子模式取数据[1]就能得到utf-8

总结:关心的留下,不关心的都是浮云

4、 操作:取数据

关于取数据,上面一大篇下来大家应该有概念了,就是利用子模式来获取,这里不再赘述。

总结:子模式计数,数左括号从1开始,排除非捕获组的左括号

正则表达式(入门),布布扣,bubuko.com

时间: 2024-10-08 23:23:58

正则表达式(入门)的相关文章

正则表达式入门(c#)

本文是对该教程的学习练习 http://www.jb51.net/tools/zhengze.html 1.\bContent\b static void Main(string[] args) { string str = "Act game - Uncharted3, act Game - God of war"; Regex rex = new Regex(@"\bact\b"); var result = rex.Match(str); if (result

正则表达式入门学习

\b-元字符,代表单词的开头或结尾,也就是单词的分界处. \bHi\b     下列未进行说明的都是元字符. .  匹配除了换行符以外的任意字符. * 指定*前边的内容可以连续重复使用任意次以使整个表达式得到匹配.(不包含换行的字符) \bHi\b.*\bLucy\b \d 匹配一位数字(0或1或2......或9)  0\d\d-\d\d\d\d\d\d\d\d - 不是元字符 ,只匹配它本身. 避免重复 0\d{2}-\d{8}  {2}({8})指前面\d必须连续重复匹配2次(8次). \

php正则表达式入门-常用语法格式

原文地址:http://www.jbxue.com/article/24467.html 分享下php正则表达式中的一些常用语法格式,用于匹配字母.数字等,个人感觉还不错. 语法格式:位于定界符"/"之间.较为常用的元字符包括: “+”, “*”,以及 “?”.其中, “+”元字符规定其前导字符必须在目标对象中连续出现一次或多次, “*”元字符规定其前导字符必须在目标对象中出现零次或连续多次, 而“?”元字符规定其前导对象必须在目标对象中连续出现零次或一次. /jim{2,6}/<

Python正则表达式入门

Python正则表达式入门 一. 正则表达式基础 1.1. 简单介绍 正则表达式并不是Python的一部分. 正则表达式是用于处理字符串的强大工具, 拥有自己独特的语法以及一个独立的处理引擎, 效率上可能不如str自带的方法, 但功能十分强大. 得益于这一点, 在提供了正则表达式的语言里, 正则表达式的语法都是一样的, 区别只在于不同的编程语言实现支持的语法数量不同; 但不用担心, 不被支持的语法通常是不常用的部分. 如果已经在其他语言里使用过正则表达式, 只需要简单看一看就可以上手了. 下图展

有shi以来最详细的正则表达式入门教程

原文:有shi以来最详细的正则表达式入门教程 本篇文章文字内容较多,但是要学习正则就必须耐心读下去,正则表达式是正则表达式其实并没有想像中的那么困难,但是想要熟练的掌握它,还是需要下功夫勤加练习的.这里讲一些正则表达式的语法和学习方法,大家还要多参考前辈们写的正则表达式,才能达到熟练精通的地步. 一.正则表达式到底是什么东西?                                                  正则表达式,又称正规表示法.常规表示法(英语:Regular Expre

正则表达式入门教程&amp;&amp;经典Javascript正则表达式----share

前言 例子: ^[email protected]+\\..+$ 这样的代码曾经多次把我自己给吓退过.可能很多人也是被这样的代码给吓跑的吧.继续阅读本文将让你也可以自由应用这样的代码. 正文 教程:正则表达式30分钟入门教程 一个学习正则表达式不错的教程,对正则表达式有兴趣,但不太了解的童鞋可以参考下 以下内容摘自 常用JQuery数字类型验证正则表达式整理  和    经典Javascript正则表达式         [  留个备份 :) ~~  ]     常用JQuery数字类型验证正则

JavaScript正则表达式详解(一)正则表达式入门

JavaScript正则表达式是很多JavaScript开发人员比较头疼的事情,也很多人不愿意学习,只是必要的时候上网查一下就可以啦~本文中详细的把JavaScript正则表达式的用法进行了列表,希望对于大家学习JavaScript正则表达式有一定的帮助. 建立正则表达式对象语法 re = new RegExp(/pattern/[flags]) flags 参数说明: g (全文查找出现的所有 pattern) i (忽略大小写) m (多行查找) 普通字符 描述 \ 将下一个字符标记为一个特

Python 正则表达式入门

Python 正则表达式入门(初级篇) 本文主要为没有使用正则表达式经验的新手入门所写.转载请写明出处 中级篇介绍子表达式,向前向后查找,回溯引用 链接:http://www.cnblogs.com/chuxiuhong/p/5907484.html 引子 首先说 正则表达式是什么? 正则表达式,又称正规表示式.正规表示法.正规表达式.规则表达式.常规表示法(英语:Regular Expression,在代码中常简写为regex.regexp或RE),计算机科学的一个概念.正则表达式使用单个字符

js中的正则表达式入门

js中的正则表达式入门 什么是正则表达式呢? 正则表达式(regular expression)描述了一种字符串匹配的模式,可以用来检查一个字符串是否含有某种子串.将匹配的子串做替换或者从某个字符串中取出符合某个条件的子串等. 说白了正则表达式就是处理字符串的,我们可以用它来处理一些复杂的字符串. 为什么要学习正则表达式 我们直接用一个例子来说明 //找出这个字符串中的所有数字 var str = 'abc123de45fgh6789qqq111'; //方法1 function findNum

Java正则表达式入门

众所周知,在程序开发中,难免会遇到需要匹配.查找.替换.判断字符串的情况发生,而这些情况有时又比较复杂,如果用纯编码方式解决,往往会浪费程序员的时间及精力.因此,学习及使用正则表达式,便成了解决这一矛盾的主要手段. 大 家都知道,正则表达式是一种可以用于模式匹配和替换的规范,一个正则表达式就是由普通的字符(例如字符a到z)以及特殊字符(元字符)组成的文字模式,它 用以描述在查找文字主体时待匹配的一个或多个字符串.正则表达式作为一个模板,将某个字符模式与所搜索的字符串进行匹配.  自从jdk1.4