正则表达式之扩展正则

扩展正则

扩展正则,指的是表达式中含有:+ ? | { } 等符号,在grep当中不能直接使用,需要加\拓义
如果不想加\拓义的话可以使用egrep 或者grep -E 进行使用
扩展正则:sed -r,和grep选项,含有+ ? | { }符号的时候需要加r选项,如果不加则需要加上\拓义
awk默认支持grep、sed所有功能
awk里面比较大小不能用数字和字母比较,这个比较不出来
扩展正则 ? + | { }
? 扩展正则 表示:?前面的字符有0个或1个
a1? ==> a or a1

  • 扩展正则 表示:+前面的字符有正整数个
    | 扩展正则 表示:或者
    { } 表示范围

特殊符号的一些含义:

. 表示任意1个字符

  • a b 0: 前面的这个字符有0或者多个
    abc
    ab abccc
    .
    表示贪婪匹配
    egrep ‘abc|123‘ 1.txt
    [ ] 表示方括号里面的1个字符
    [a-zA-Z0-9] [abc] [a|@] [^]
    ^ 表示开头
    $ 表示结尾
    a{1,5} b{3}
    ( ) 小括号里面的字符看成一个整体
    (abc){2} ==》 abcabc
    (abc)+
    abc{2} ==> abcc
    awk -F ‘[#:|]‘

原文地址:https://blog.51cto.com/13292790/2439867

时间: 2024-11-11 04:48:54

正则表达式之扩展正则的相关文章

正则表达式,文件名通配,扩展正则之间的一些异同

正则表达式是一个神器,但初学linux时候还有文件名通配这样的东东.今天就总结一下文件名通配,正则表达式,扩展正则表达式之间有什么异同.可能写的不全,求指教. 使用方面: 正则多用来匹配过滤文本内容. 文件名通配符则用来匹配文件名较多. 支持命令: 文件处理,查看cp find ls rm mv touch 等一系列的文件匹配查找命令.(和上面说的是一个意思) 正则表达式则用在文本内容处理的各种工具grep,awk,sed,vim末行模式等. 匹配功能上正则规矩多,自然能力更强大,所以就这的区别

正则表达式和扩展正则表达式

正则表达式和扩展正则表达式   先了解下基础概念:字符是计算机软件处理文字时最基本的单位,可能是字母,数字,标点符号,空格,换行符,汉字等等.字符串是0个或更多个字符的序列.文本也就是文字,字符串.说某个字符串匹配某个正则表达式,通常是指这个字符串里有一部分(或几部分分别)能满足表达式给出的条件.  正则表达式:是指一个用来描述或者匹配一系列符合某个句法规则的字符串的单个字符串.vim.grep.awk .sed 等工具都支持正则表达式,本文介绍如何使用grep及egrep命令.而扩展正则表达式

grep、正则表达式和扩展正则表达式的理解及运用

grep.正则表达式和扩展正则表达式的理解及运用 一 .grep的基本含义 我们可以从命令man grep中看到gerp命令的帮助文档,从中我们可以得出grep.egrep.fgrep都是文本搜索工具,根据用户指定的文本模式(搜索条件)对目标文件进行逐行搜索,显示能匹配到的. grep有三种变形:   grep:标准grep命令,支持基本正则表达式   egrep:扩展grep命令,支持基本及扩展的正则表达式   fgrep:fastgrep,它把所有的字母都看作单词,即正则元字符不再特殊,而仅

基本正则表达式与扩展正则表达式

什么是正则表达式 通过符号.符号与字母数字的组合,来描述文本的特征.这些字符不代表字符原本的意义,而是表示控制和通配.这此符号和符号与字母的组合称为元字符. 为什么要用正则表达式,用在什么地方. 正则表达式可以匹配一段文本的特征,比如年月日,空白行,单词,一行文本,IP地址等.这样可以根据某些文本,然后查找到那些文件中包含了这些内容.还可以根据这些特征找到的文本进行复制,删除,替换,或者赋值给一个变量等.很多编程语言都支持正则表达式,它们可能支持的正则表达式引擎不同,表示方法略有不同.vi,gr

POSIX基本正则表达式和扩展正则表达式的比较

POSIX基本正则表达式和扩展正则表达式的比较 在读者正觉得正则表达式已经复杂得不能再复杂时,又会发现POSIX规范将正则表达式的实现方法分为了两种:基本正则表达式(BRE)和扩展正则表 达式(ERE).到目前为止,我们所讨论的正则表达式的所有特性,都得到了兼容POSIX的应用程序的支持,并且都是以BRE的方式实现.grep命令就 是这样的一个例子. BRE和ERE到底有什么区别?其实仅仅是元字符的不同!在BRE方式中,只承认^ .$. . .[ .] .*这些是元字符,所有其他的字符都被识别为

[8-27]正则表达式、扩展表达式以及相关实战

本文旨在复习正则表达式,扩展正则表达式,对基本概念.基本用法等作记录 知识储备 正则表达式:是文本搜索工具,根据用户指定的"PATTERN模式"去逐行匹配目标文本,打印匹配到的行 模式: 由正则表达式的元字符及文本字符,所编写的过滤条件 元字符:字符不标识其字面意义,用于表示通配或控制功能: 逐行: 请注意:正则处理单位是"行",匹配时去匹配行,输出时输出行 BRE与ERE: BRE基本正则表达式,ERE扩展正则表达式 本质区别是[元字符的定义不一样罢了],常用参数

基础正则和扩展正则的作用

*基础正则表达式:basic regular expression BRE包括:^ $ . [] [^] 和扩展正则不同的是grep和sed不需要加参数也可以使用 ^^d 以d开头的行,例如:ls l|grep "^d" 给三剑客使用只查看以d开头的行,正则表达式的意思为,以.....开头,^d就是以d开头[[email protected] data]# grep '^m' oldboy.txt 以m开头的行my qq is 49000448 $以什么什么结尾的行,例如grep &q

OSIX基本正则表达式和扩展正则表达式的比较

POSIX基本正则表达式和扩展正则表达式的比较 在读者正觉得正则表达式已经复杂得不能再复杂时,又会发现POSIX规范将正则表达式的实现方法分为了两种:基本正则表达式(BRE)和扩展正则表达式(ERE).到目前为止,我们所讨论的正则表达式的所有特性,都得到了兼容POSIX的应用程序的支持,并且都是以BRE的方式实现.grep命令就是这样的一个例子. BRE和ERE到底有什么区别?其实仅仅是元字符的不同!在BRE方式中,只承认^ .$. . .[ .] .*这些是元字符,所有其他的字符都被识别为文字

linux正则表达式和扩展表达式

Centos的grep的正则表达式和扩展表达式 日期2015.08.28 备注:其简述来自于马哥课堂笔记  grep      grep是一个文本过滤工具根据用户指定的"模式(pattern)"逐行去搜索目标文本,打印匹配到的行:     模式:由正则表达式的元字符及文本字符所编写的过滤条件: 其中,元字符:字符不表示其字面意义,而用于表示通配或控制功能 grep分为两类 基本的正则表达式:BRE 扩展的正则表达式:ERE grep 使用格式 grep  [选项]   模式  [文件]