正则表达式之旅_sed_awk
谈谈正则表达式这个东西:
我想作为一个程序员,正则表达式大家绝对不陌生。
正则表达式好像一个有限则动机。主要作用是匹配,但是同时因为这个功能,我们可以扩展很多其他用法
像很多语言都引人了正则表达式:java,C#等面向对象语言,更多的是脚本语言。
另外我们常用的一些工具都引入了这个正则表达式:sed,awk,gawk,grep
包括我们的C语言,它这种引入了一部分基础的正则表达式,我们一会会见到:
正则表达式是用正则表达式引擎实现的。正则表达式引擎是解释正则表达式模式并使用这些模式进行文字或者命令匹配的底层软件
学过编译原理的都知道DFA,和NFA的概念,这是我们编译过程中语法匹配的两大模式。他们的原理和正则表达式一样。
正则表达式就是根据这样分类:我们之关注Linux
在Linux,有两种流行的正则表达式引擎:
POSIX基本正则表达式引擎(BRE)
POSIX扩展正则表达式引擎(ERE)
大多数Linux工具都至少符合BRE
下面先看一下BRE基本成分,然后看看它在不同方面的不同应用
BRE主要有一些特殊字符组成:这些特殊字符有: .*[]^${}\+?|(),下面我们一一学习:但是有一点特殊:不能直接使用单斜线(/)要用反义字符表示包括除法符号(/)
1,锚字符
行首锁定:^ 定义从数据流中文本行的行首开始的模式。只能是行首
行尾锁定:$定义了行尾锚点
两种可以匹配 使用 达到特殊的用处
2,点字符
. 用来匹配除了换行符以外的任意单字符
3,字符数组
[] 可以在此数组中定义你想匹配的任意字符也可以前后配合使用用于交叉匹配
4,排除字符组
[^] 就是字符数组的反义词,匹配的时候不匹配数组中的字符
5,区间:
[]可以用次符号表示区间 [0-9] [a-z]等等进行匹配
6,特殊字符数组:这些定义好的可以使用
[[:alpha:]] 匹配任意字母字符,不区分大小写(都包括)
[[:alnum:]] 匹配任意字母数字字符0-9,A-Z , a-z
[[:blank:]] 匹配空格或者制表符
[[:digit:]] 匹配0-9数字
[[:lower:]] 匹配小写字母
[[:print:]] 匹配可打印字符
[[:punct:]] 匹配标点符号
[[:space:]] 匹配任意空白:空格,制表符,NL,NF,VT,和CR
[[:upper:]] 匹配任意大写字母
7,星号:
在匹配文本后面表示出现0次或多次:
ERE包括一些特殊的扩展用法,awk工具能识别但是sed工具不能
1,问号
文本后面加上?,表示匹配0次或者1次
2,加号
匹配文本后加上+,表示至少匹配一次
3,化括号
(m,n)至少出现m此,最多出现n次
4,管道符号
类似or符号,任意匹配就可以
5,聚合表达式
(),用该符号表示,相当于一个准字符
下面我们来做实验,介绍正则表达式常用的地方及场景
1,sed工具
sed的全程为stream editor,俗称流编辑器。和传说中的交互式文本编辑器正好相反
语法:
sed options script file
-e script 在处理输入时,将script中指定的命令添加到运行的命令中
-f file 在处理输入时,将file中指定的命令添加到运行的命令中
-n 不要为每个命令生成输出,等待print命令来输出,起到过滤的意思
下面一一道来:
e1:
我们从这三个例子中可以看出,sed -n选项的过滤作用,可以看到sed的流处理是怎么实现的。其中s是sed流处理过程中替换的标识,后面还有很多eg:d删除,p打印等等见到再说
///一共是三个,前面两个中间是被替换的文本,后面两个中间是要替换的文本
要在sed命令行上执行多条指令,则加上-e选项就可以了,相当于前面的插入命令,中间加上“;”号,其他不正确的写法看下图
e2:
上面介绍了几种常见的正确和错误写法,其中最后一种主要是根据’号的作用,很类似python语言中的长句子(... ...)
而且还有一种现象,我们的匹配是完全的,只要有匹配的就替换,下面的从文本中读取编辑命令可以看出:
e3:
结果出来了,仔细看的就会发现。所谓完全匹配还是有一定的差别。有一个限制条件是:每行之替换一个!!!
如果我们想让它们都替换怎么办,简单,加上全集控制符就可以了/g,看它是怎么只手回天的
e4:
怎么样,控制性很高吧
sed的匹配模式语法:
s/pattern/replacement/flags
有四种可以替换标记:
>数字,标识将替换第几处匹配的地方
>g , 标识全局替换,只要出现就替换
>p ,标识原来行的内容打印出来
>w file ,将替换的结果写的文件file中
数字:
e5:
g和p:
e6:
我们从例子中可以清晰的看出区别
下面看看我们的另类一点的 写文件:
e7:
自己看,不解释,标志在感情可以接受的范围内可以用多个
另外我们发现,如果我们替换的是字符串并且字符串里面是一个路径(里面含有/)怎么办?
Look me:
e8:
我们看出了什么? 很明显,有路径必须用\符合转义。当然也可以换作其他分割符"!"
而且目前只有"!"可以胜任,其他的(如例子#,@)虽然没有语法错误,但是不识别
sed使用地址:
sed中有两种行寻址:
1,行的数字范围
2,用文本模式来过滤出某行
都可以用相似方式实现:
[address] command
address {
command1
command2
command3
}
数字行寻址:
e9:
结果很明显,不做太多解释。$前面也介绍过
文本过滤模式过滤:
/pattern/command
e10:
当然组合命令也是可以的,比较繁
一个新的sed标识:d(elete)
看例子:
e11:
删除可以根据上面提到过的两种匹配模式
还有你甚至可以这样删除:
e12:
但是这么做有可能造成意外.第一次指定模式会"打开"行删除功能,第二个模式会"关闭"行删除功能.意思是会删除它们之间的元素
另外,只要匹配了打开功能,就开始删除.结果可能让你发疯:
e13:
sed的插入和追加:
插入命令i会在指定行之前增加一行
追加命令a会在指定行之后加入一个新行
令人纳闷的它们格式:
sed '[address]command\
new line'
例子:
e14:
$指最后一行:
e15:
同理可以在文本第一行插入.
sed 的修改:
同理修改要指定行地址
e16:
sed 转换命令
[address]y/inchars/outchars/ 等长转换
转换是一个全局命令,可以转化匹配的一切:
e17:
sed的打印
>p 打印文本行
>= 打印行号
>l 列出行
打印行:
e18:
打印行号:
e19:
列出行: 列出数据流中所有字符,包括可打印和不可打印的字符
e20:
sed的文本保存
[address]w filename
sed '1,2w test' file 把file文件的1,2行读到test中.
可以用-n选项禁止显示在屏幕上
sed的读文件
[address]r filename
sed '3r test' file 读出test内容插入到file文件的第3行后面
sed '/number/r test' file 读出test内容,插入到file中含number行后面
sed '$r test' file 把test内容插到file文件最后
正则表达式之旅_sed_awk的更多相关文章
- JAVA之旅(三十四)——自定义服务端,URLConnection,正则表达式特点,匹配,切割,替换,获取,网页爬虫
JAVA之旅(三十四)--自定义服务端,URLConnection,正则表达式特点,匹配,切割,替换,获取,网页爬虫 我们接着来说网络编程,TCP 一.自定义服务端 我们直接写一个服务端,让本机去连接 ...
- 我的Java开发学习之旅------>工具类:Java使用正则表达式分离出字符串中的中文和英文
今天看到一个工具类使用正则表达式将一大段字符串中的中文和英文都分离出来了,在此记录一下,读者可以收藏! import java.util.ArrayList; import java.util.Col ...
- F#之旅9 - 正则表达式
今天,cozy群有个群友发了条正则,问正则匹配相关的问题.虽然他的问题用html selector去处理可能更好,但是我也再一次发现:我忘了正则怎么写的了! 忘掉正则是有原因的,这篇文章会简单记录下F ...
- 我的Android进阶之旅------>Android使用正则表达式匹配扫描指定目录下的所有媒体文件(音乐、图像、视频文件)
今天使用正则表达式匹配指定目录下的所有媒体文件,下面将这份代码简化了,可以收藏下来,当作工具类. package match; import java.io.File; import java.uti ...
- webpack入坑之旅(二)loader入门
这是一系列文章,此系列所有的练习都存在了我的github仓库中vue-webpack 在本人有了新的理解与认识之后,会对文章有不定时的更正与更新.下面是目前完成的列表: webpack入坑之旅(一)不 ...
- JavaScript之旅(二)
JavaScript之旅(二) 二.进阶知识 js的正则表达式 异常处理 调试 变量提升 表单验证 JSON javascript:void(0) JavaScript 代码规范 二.进阶知识 1. ...
- 我的django之旅(一)
我的django之旅(一) 标签(空格分隔):django web 1.检验我们的python和django版本 liao@spring ~ $ python --version Python 2.7 ...
- 【C++探索之旅】第一部分第三课:第一个C++程序
内容简介 1.第一部分第三课:第一个C++程序 2.第一部分第四课预告:内存的使用 第一个C++程序 经过上两课之后,我们已经知道了什么是编程,编程的语言,编程的必要软件,C++是什么,我们也安装了适 ...
- java正则表达式去除html标签
当我们用ckeditor或其他一些在线文本编辑器的时候 内容里会有很多的标签 如下片段: <p><img alt="" src="/img/upload ...
随机推荐
- C++最接近整数的浮点运算
Function return ceil 不小于给定值的最接近整数值 floor 不大于给定值的最接近整数 trunc (C++11) 绝对值不大于给定值的最接近整数 round(C++11) 最接近 ...
- 基于ftp服务的三种登录方式及其相关的访问控制和优化
ftp(简单文件传输协议),是一种应用广泛的网络文件传输协议和服务,占用20和21号端口,主要用于资源的上传和下载. 在linux对于ftp同widows一样具有很多的种类,这里主要介绍vsfptd( ...
- web开发学习路线
第一阶段: HTML+CSS: HTML进阶.CSS进阶.div+css布局.HTML+css整站开发. JavaScript基础: Js基础教程.js内置对象常用方法.常见DOM树操作大全.ECMA ...
- Python学习 :格式化输出
方式一:使用占位符 % 常用占位符:% s (s = string 字符串) % d (d = digit 整数(十进制)) % f ( f = float 浮点数) na ...
- 3D Food Printing【3D食物打印】
3D Food Printing There's new frontier in 3D printing that's begining to come into focus: food. 3D打印的 ...
- 46-Identity MVC:登录逻辑实现
1- Login.cshtml <h3>Login</h3> @model MvcCookieAuthSample.ViewModel.LoginViewModel <d ...
- Git的使用规范(二)
今天,我们来介绍一下git的一些命令行,来帮我们后面可以面对一些情况的时候,我们可以有一些解决的方法 1.git查看历史记录最全的命令行 git log --pretty=raw 2.对于一下的几个情 ...
- 大数据培训班 cloudera公司讲师面对面授课 CCDH CCAH CCP
大数据助力成就非凡.大数据正在改变着商业游戏规则,为企业解决传统业务问题带来变革的机遇.毫无疑问,当未来企业尝试分析现有海量信息以推动业务价值增值时,必定会采用大数据技术. 目前对大数据的分析工具,首 ...
- 添加用户-查看用户列表-禁止默认root登陆
程序小屌丝狒狒: (Q971751392) linux添加用户 adduser feifei passwd [用户名] 设置密码 可以查看所有用户的列表 cat /etc/passwd w 可以查看 ...
- 【jQuery】 资料
[jQuery] 资料 1. 选择器 http://www.w3school.com.cn/jquery/jquery_ref_selectors.asp 2. 事件 http://www.w3sch ...