linux入门之grep 正则表达式案例

grep 正则表达式案例

案例一:

1、显示/proc/meminfo文件中以大小s开头的行;(要求:使用两种方式)

#grep -i ‘^s‘ /proc/meminfo
#grep  ‘^[Ss]‘ /proc/meminfo
#grep -E ‘^(s|S)‘ /proc/meinfo

2、显示/etc/passwd文件中不以/bin/bash结尾的行

#grep -v ‘/bin/bash$‘ /etc/passwd

3、显示用户rpc默认的shell程序

#grep ‘^\<rpc\>‘ /etc/passwd | cut -d: -f7

4、找出/etc/passwd中的两位或三位数

#grep ‘\<[0-9][0-9]\?\>‘ /etc/passwd
#grep ‘\<[0-9]\{2,3\}\>‘ /etc/passwd

5、显示/etc/grub2.cfg文件中,至少以一个空白字符开头的且后面存非空白字符的行

#grep ‘^[[:space:]]\+.*[^[:space:]]‘ /etc/grub2.cfg

6、找出"netstat -tan"命令的结果中以‘LISTEN‘后跟任意个空白字符结尾的行

#netstat -tan ‘.*LISTEN[[:space:]]*$‘

7、添加用户bash、testbash、basher以及nologin(其shell为/sbin/nologin),而后找出/etc/passwd文件中用户名同shell名的行

#grep ‘^\<\(.*\)\>.*/\1$‘  /etc/passwd
#grep ‘^\<\(.*\)\>.*\<\1\>$‘ /etc/passwd

案例二:

1、显示当前系统root、mage或wang用户的UID和默认shell

#grep -E ‘^(root|mage|wang)\>‘ /etc/passwd |cut -d: -f7

2、找出/etc/rc.d/init.d/functions文件中行首为某单词(包括下划线)后面跟一个小括号的行

#grep -E -o ‘^\<[[:alnum:]_]+\>\(\)‘ /etc/rc.d/init.d/functins

3、使用egrep取出/etc/rc.d/init.d/functions中其基名

#echo "/etc/rc.d/init.d/functions" | grep -E -o ‘[^/]+/?$‘

4、使用egrep取出上面路径的目录名

#echo "/etc/rc.d/init.d/functions" | grep -E ‘(/.*/)‘

5、统计以root身份登录的每个远程主机IP地址的登录次数

#last | grep  -o ‘root\>.*\([[:digit:]]\{1,3\}\.\)\{3\}[[:digit:]]\>‘ | tr -s ‘ ‘ | cut -d‘ ‘ -f3 | uniq -c

6、利用扩展正则表达式分别表示0-9、10-99、100-199、200-249、250-255

#grep -E ‘\<([0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\>‘

7、显示ifconfig命令结果中所有IPv4地址

#ifconfig | grep -o ‘\(\([0-9]\|1[0-9]\|1[0-9]{2}\|2[0-4][0-9]\|25[0-5]\)\.\)\{3\}\([0-9]\|1[0-9]\|1[0-9]{2}\|2[0-4][0-9]\|25[0-5]\)‘

案例三:

4、取本机ip地址

#ifconfig | grep ‘inet addr‘ | grep -E -o ‘(([1-9]|1[0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-4])\.){3}([1-9]|1[0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-4])‘

5、取各分区利用率的数值

df | grep -o ‘\<[0-9]\+%‘

6、统计/etc/init.d/functions 文件中每个单词出现的次数,并按频率从高到低显示

非正则:

#cat /etc/init.d/functions | tr -cs ‘[:alpha:]‘ ‘ ‘ | tr ‘ ‘ ‘\n‘ |  sort  | uniq -c | tr -s ‘ ‘ | sort -t ‘ ‘ -k 1nr

正则加替换:

#cat /etc/init.d/functions | tr ‘_‘ ‘ ‘ | grep -o ‘\<[a-zA-Z]\+\>‘ | sort | uniq -c | tr -s ‘ ‘ | sort -t‘ ‘ -k2 nr

纯正则:

#cat /etc/init.d/functions |  grep -o  --color ‘\<\([a-zA-Z_]\)\+\>‘ | grep --color ‘\<[#a-zA-Z]\+\>‘ | sort | uniq -c | grep -o "[0-9]\+[[:space:]][a-zA-Z]\+" | sort -t‘ ‘ -k1 -nr

7、/etc/rc.d/init.d/functions或/etc/rc.d/init.d/functions/"  取目录名

#DIR="/etc/rc.d/init.d/functions"
#DIR1="/etc/rc.d/init.d/functions/"
#echo ${DIR} | grep ‘\(/.*/\)‘
#echo ${DIR1} | tr ‘/‘ ‘ ‘ | cut -d‘ ‘ -f1-$[ `echo $DIR | tr ‘/‘ ‘ ‘ | wc -w` ] | tr ‘ ‘ ‘/‘
echo ${DIR} | grep -o ‘/.*[^/]‘ | grep --color -o ‘/.*/‘

扩展使用sed命令:

echo "/sdsdf/sgdsg/sdgg/fgdfhdfh/" | sed ‘s/[^\/]\+\/\?$//g‘
时间: 2024-10-21 06:05:58

linux入门之grep 正则表达式案例的相关文章

Linux入门之sed命令案例

实战: 1.删除/etc/grub.conf文件中行首的空白符: sed -r '[email protected]^[[:spapce:]][email protected]@g' /etc/grub.conf 2.替换/etc/inittab文件中"id:3:initdefault:"一行中的数字为5: sed '[email protected]\(id:\)[0-9]\(:initdefault:\)@\15\[email protected]' /etc/inittab 3.

Linux入门之磁盘管理(9)LVM逻辑卷案例

Linux入门之磁盘管理(9)LVM逻辑卷案例 案例介绍阶段(1): 创建一个由两个物理卷组成的大小未20G的卷组myvg,要求其PE大小为16M:而在此卷组中创建一个大小未5G的逻辑卷lvtest,此逻辑卷要能在开机后自动挂载至/mnt/lvtest目录,且支持ACL功能. 1.准备工作 #这里我们分别从两个磁盘选择10G来准备组合为PV [[email protected] ~]# fdisk -l | grep -o '/.*B' /dev/sda: 21.5 GB /dev/sdb: 2

Linux系统的grep以及正则表达式浅析!

grep命令可以从文本中或者通过管道送过来的字符流中或一个"-"符号代替文件名来搜索精确或者模糊的匹配信息,grep家族有三个命令:grep,egrep,fgrep. grep支持正则表达式匹配查找 egrep支持扩展正则表达式匹配查找 fgrep不支持正则表达式匹配查找 grep命令的格式: grep [OPT] 'PATTERN' FILE PATTERN是所需要匹配的内容 精确匹配中单双引号的含义相同 如果PATTERN是精确匹配(即只有普通字符不包含元字符)且字符串中间不包含空

Linux学习之grep及正则表达式

1.grep:根据模式搜索文本,并将符合模式的文本行打印出来 使用基本正则表达式定义的模式来过滤文本的命令 grep 选项 模式(正则表达式) 参数 模式:由文本字符和正则表达式的元字符组合而成的匹配条件 -E:扩展正则表达式 -i:不区分大小写 -w:匹配整个单词 -x:匹配整行 -v:显示不匹配的行 --colour/--color:高亮显示匹配字符串 -A:打印匹配本身以及后面的几行 -B:打印匹配本身以及前面的几行 -C:打印匹配本机以后前后的几行 -o:只显示匹配到的字符串 -c:显示

linux 命令grep正则表达式

Linux 命令grep正则表达式 在linux里面有处理文本的三剑,现在我要说的就是grep正则表达式的使用,正则表达式只是一种表示法,只要工具支持这种表示法,那么该工具就可以处理正则表达式的字符串.vi grep ,awk ,sed 等都支持正则表达式..正则表达式有基本正则表达式和扩展正则表达式. grep默认就是基本表达式. 基本正则表达式: 默认匹配次数:贪婪模式,尽可能多的去匹配. 扩展正则表达式:基于基本正则表达式多加了一些功能,基本一样. 1. grep命令 grep [参数]

linux grep 正则表达式

grep正则表达式元字符集: ^ 锚定行的开始 如:'^grep'匹配所有以grep开头的行. $ 锚定行的结束 如:'grep$'匹配所有以grep结尾的行. . 匹配一个非换行符的字符 如:'gr.p'匹配gr后接一个任意字符,然后是p. * 匹配零个或多个先前字符 如:'*grep'匹配所有一个或多个空格后紧跟grep的行. .*一起用代表任意字符. [] 匹配一个指定范围内的字符,如'[Gg]rep'匹配Grep和grep. [^] 匹配一个不在指定范围内的字符,如:'[^A-FH-Z]

Linux入门之CentOS7内核编译三部曲(2)

Linux入门之CentOS7内核编译三部曲(2) 在linux系统中,编译完了内核,得到了所需的功能,并不能表示就已经能完美完成我们的所需.因为内核只是做一个核心的硬件及核心代码的支持,而注意的模块支持任然是对应版本的内核模块文件.这些文件决定着平时能否使用哪些功能.这次不会介绍如果添加给上次编译的新内核模块功能,主要介绍模块的功能和作用以及其加载和卸载. 查看当前系统以及加载的内核模块命令:lsmod  modinfo lsmod 命令 lsmod - program to show the

Linux 入门学习之rpm软件包管理

Linux入门之软件包管理 在linux有很多类的软件包管理机制,但是在redhat.centos这类版本的系统中,都会使用一种相同的机制,就是rpm软件包管理机制,当然,还有其它版本的linux使用的不同机制: debian:使.deb文件,dpkg包管理器 redhat:使用.rpm文件,rpm包管理器 软件包在使用中又分类两种(源码包和二进制包): 源码包:一般是提供了一些源码模块和编译脚步组合起来的压缩文件,命令格式如: name-version.tar.{gz|bz2|xz} 等,这里

Linux入门之磁盘管理(2)文件系统

Linux入门之磁盘管理(2)文件系统 linux分区构成完成之后,一般需要进行对其创建指定的文件系统,也就是我们常说的格式化,然后对其进行分区挂载,提供指定分区的访问点.不同的分区格式会在文件系统内部提供不同的对该分区的数据存储的格式分配,以及其内部模块会支持不同的分区的接口及方法调用,例如对一个文件的打开.读取.写入.关闭等功能,每个文件系统都会有各种不同的特点. 常见的系统文件系统: linux: ext2.ext3.ext4:xfs(SGI):btrfs(Oracle):reiserfs