学习Grep,Sed中的正则
浏览:4035次 出处信息
据说有这么一个段子:
毛泽东说:三天不学习,赶不上刘少奇。
刘少奇说:一天不用功,赶不上毛泽东。
到底是老百姓作的打油诗,还是政客对的对联,早已无从考证。
…
STOP!回到主题上来,正则是必须时常温习的知识,下面学习Grep,Sed中的正则。
问题:从一个文本文件里筛选出含有电话号码的行,电话号码是由七位或者八位阿拉伯数字组成(开头不是零),并且被单引号或者双引号包裹。
鉴于问题的需要,先杜撰一份数据:
# cat /path/to/data.txt
'7654321'
'7654321"
"87654321"
"87654321'
失败的尝试
# grep "(['\"])[1-9][0-9]{6,7}\1" /path/to/data.txt
grep: Invalid back reference
# sed -n "/(['\"])[1-9][0-9]{6,7}\1/p" /path/to/data.txt
sed: -e expression #1, char 25: Invalid back reference
成功的尝试
使用Basic Regular Expressions (BRE)
# grep "\(['\"]\)[1-9][0-9]\{6,7\}\1" /path/to/data.txt
'7654321'
"87654321"
# sed -n "/\(['\"]\)[1-9][0-9]\{6,7\}\1/p" /path/to/data.txt
'7654321'
"87654321"
使用Extended Regular Expressions (ERE)
# grep -E "(['\"])[1-9][0-9]{6,7}\1" /path/to/data.txt
'7654321'
"87654321"
# sed -n -r "/(['\"])[1-9][0-9]{6,7}\1/p" /path/to/data.txt
'7654321'
"87654321"
总结,Grep和Sed同时支持BRE和ERE两种正则,缺省情况下,Grep和Sed使用的都是BRE正则,通过增加命令参数(grep -E / sed -r),Grep和Sed可以支持ERE正则。
BTW:Regular expression From Wikipedia, the free encyclopedia
建议继续学习:
- 利用find和sed批量替换文件内容 (阅读:10263)
- Linux grep命令用法 (阅读:6149)
- 统计最近用过的linux命令 (阅读:5431)
- grep 正则表达式选项要记得转义 (阅读:5300)
- 正则表达式基础 (阅读:5180)
- 正则表达式的与或非 (阅读:4735)
- SED命令行脚本快速参考,AWK命令行脚本快速参考,perl命令行脚本快速参考 (阅读:3905)
- grep: writing output: Broken pipe in iTerm2 (阅读:3621)
- URL正则表达式 (阅读:3587)
- bash shell - sed及awk文本捕获及替换 (阅读:3602)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
扫一扫订阅我的微信号:IT技术博客大学习
<< 前一篇:colortail,让 tail 命令绚丽起来
后一篇:Linux screen窗口中文乱码问题 >>
文章信息
- 作者:老王 来源: 火丁笔记
- 标签: Grep Sed 正则
- 发布时间:2010-10-31 20:27:05
建议继续学习
近3天十大热文
-
[84] memory prefetch浅析
-
[54] 基本排序算法的PHP实现
-
[50] 深入浅出cassandra 4 数据一致性问
-
[42] 转载:cassandra读写性能原理分析
-
[38] javascript插入样式
-
[37] JS中如何判断字符串类型的数字
-
[37] MySQL半同步存在的问题
-
[36] Inline Form Labels
-
[35] 字符引用和空白字符
-
[33] 获取Dom元素的X/Y坐标