【记录】正则表达式学习

原文地址:http://www.zouzhipeng.com/2017/05/24/%E3%80%90%E8%AE%B0%E5%BD%95%E3%80%91%E6%AD%A3%E5%88%99%E8%A1%A8%E8%BE%BE%E5%BC%8F%E5%AD%A6%E4%B9%A0/

本文是慕课网 《实例妙解sed 和 awk 的秘密》 的学习记录的第一部分:正则表达式。

Linux 三大利器: grep, sed, awk.

1. 准备工作

正则表达式应用场景:查找、取出、匹配符合条件的字符或字符串

学习方法:从小到大、组合的过程。单个字符->字符串->表达式。

grep 搜索命令匹配正则表达式例子

$ grep 'root' passwd
root:*:0:0:System Administrator:/var/root:/bin/sh
daemon:*:1:1:System Services:/var/root:/usr/bin/false
_cvmsroot:*:212:212:CVMS Root:/var/empty:/usr/bin/false

2. 正则单个字符的表示方式

1. 特定字符

某个具体的字符,如 '1', 'a'

使用 grep 搜索命令进行正则表达式的匹配

$ grep '1' passwd
daemon:*:1:1:System Services:/var/root:/usr/bin/false
_taskgated:*:13:13:Task Gate Daemon:/var/empty:/usr/bin/false
_scsd:*:31:31:Service Configuration Service:/var/empty:/usr/bin/false
_eppc:*:71:71:Apple Events User:/var/empty:/usr/bin/false
...

匹配结果被标红

2. 范围内字符

  • 单个字符 []

数字字符:[0-9], [278], 表示2/7/8, 注意只匹配一个字符。

$ grep '[0-9]' passwd
  • 小写字符:[a-z]

  • 大写字符:[A-Z]

  • 大小写:[a-zA-Z]

  • 符号: [,:!%-().]

  • 反向字符: ^, 必须放在范围之前,[]内部,如

$ grep '[^0-9]' passwd

3. 任意字符

代表任何一个字符: .

注意 ., \., [.] 的区别,其中后两个的作用是一样的。

4. 其他常用字符

  • 边界字符/头尾字符

头字符 ^root, 表示以root开头的行,注意与取反字符 [^0-9] 的区别

尾字符 false$, 表示以false结尾的行。

$ grep '^root' passwd
root:*:0:0:System Administrator:/var/root:/bin/sh

$ grep 'false$' passwd
nobody:*:-2:-2:Unprivileged User:/var/empty:/usr/bin/false
daemon:*:1:1:System Services:/var/root:/usr/bin/false
...

空行: ^$, 头尾相接。

  • 元字符(代表普通字符或特殊字符)

实质上起替代的作用

\w: 匹配任何字类字符,即字母数字下划线 [a-zA-Z0-9_]

\W: 匹配任何非字类字符,即 [^a-zA-Z0-9_]

\b: 代表单词的分隔

grep '\btime\b' file

只匹配包含单词 time 的行,不匹配 timezone,showtime 等。

3. 字符组合

1. 字符串

'root', '1000', 'r..t' (r开头,t结束,长度为4的字符串)

'[A-Z][a-z]' (一个大写字母加一个小写字母)

'[0-9][0-9]' (两个连续的数字,正则为最大化匹配,所以四位数也会匹配,五位数也会匹配前四位)

2. 重复

  • *: 0-n 次匹配前面的字符或表达式

  • +: 1-n 次匹配

  • ?: 0-1 次匹配

// 可能的匹配结果: s, se, see, seee...
$ grep 'se*' passwd
// 可能的匹配结果: se, see, seee...
$ grep 'se\+' passwd
// 可能的匹配结果: s, se, 只有两种
$ grep 'se\?' passwd

后两者注意要进行转义。

// 匹配字符串,要加括号 se, sese, sese...
$ grep '\(se\)\+' passwd

注意括号也要进行转义。

  • 重复特定次数 {n,m}

*: 相当于 {0,}

+: 相当于 {1,}

?: 相当于 {0,1}

// 匹配两到三位数字
$ grep '[0-9]\{2,3\}' passwd

注意大括号也要转义。

  • 任意字符串: .*
    (即任意单字符重复0-n次)

如: ^r.*, r.*t

$ grep '^r.*' passwd
root:*:0:0:System Administrator:/var/root:/bin/sh

注意:正则贪婪匹配的规则。

$ grep '\bd.*e\b' passwd

多么贪婪,我只想要匹配类似 dislike 这种词。

这时候就不能重复任意字符了。

$ grep '\bd[a-z]*e\b' passwd

这样改就好了。

尽量去缩小要匹配的范围,才能避免踩这些坑。

3. 逻辑

  • 逻辑或 |
$ grep 'bin/\(false\|true\)' passwd

4. 正则案例

1. 匹配4-10位QQ号

$ grep '^[0-9]\{4,10\}$' file

2. 匹配15或18位身份证号,包括X

分析:

  • 第一位不能为0
  • 最后一位的范围要扩大
  • 中间为13或16位重复数字
// 先写逻辑,最后加头尾和转义
$ grep '^[1-9]\([0-9]\{13\}\|[0-9]\{16\}\)[0-9xX]$' file

3. 匹配密码

分析:

  • 密码保护字母数字下划线,使用元字符 \w
  • 可1次或多次重复 +
$ grep '^\w\+$' file
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352

推荐阅读更多精彩内容

  • 推荐几个正则表达式编辑器 Debuggex :https://www.debuggex.com/ PyRegex:...
    木易林1阅读 11,484评论 9 151
  • 几个正则表达式编辑器 Debuggex :https://www.debuggex.com/ PyRegex:ht...
    没技术的BUG开发攻城狮阅读 4,586评论 0 23
  • 正则表达式到底是什么东西?字符是计算机软件处理文字时最基本的单位,可能是字母,数字,标点符号,空格,换行符,汉字等...
    狮子挽歌阅读 2,145评论 0 9
  • 初衷:看了很多视频、文章,最后却通通忘记了,别人的知识依旧是别人的,自己却什么都没获得。此系列文章旨在加深自己的印...
    DCbryant阅读 4,004评论 0 20
  • 每次听闻生死,都升起对生命无常的觉察。 方生方死,方死方生。 瞬间即是永恒,永恒不离瞬间。 若是呼吸间都把握不住,...
    千劫尘土一杯沙阅读 210评论 0 0