文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

文本搜索利器:grep egrep fgrep

2024-04-02 19:55

关注

    grep名称来自于g/re/p(globally search a regular expression and print,以正规表示法进行全域查找以及打印),是一个最初用于Unix操作系统的命令行工具。在给出文件列表或标准输入后,grep会对匹配一个或多个正则表达式的文本进行搜索,并只输出匹配(或者不匹配)的行或文本。

命令名称:grep, egrep, fgrep
命令作用:print lines matching a pattern
命令用法:grep [OPTIONS] PATTERN [FILE...]
          grep [OPTIONS] [-e PATTERN | -f FILE] [FILE...]
参数选项:-v  反向选取
          -o  仅显示匹配的字符串,而非字符串所在的行
          -i  忽略字符串大小写
          -E  支持只用扩展正则表达式
          -A n  显示匹配到字符串之后的n行
          -B n  显示匹配到字符串之前的n行
          -C n  显示匹配到字符串前后的n行
          --color  高亮显示匹配到的字符串


常见字符集:

[:space:]所以空白字符
[:punct:]所以标点符号
[:lower:]所有小写字母
[:upper:]所以大写字母
[:digit:]所有数字
[:alnum:]所有大小写字母和数字
[:alpha:]所有大小写字母


文件名通配:


*任意长度的任意字符
?匹配任意单个字符
[]匹配指定范围内的任意单个字符
[^]匹配指定范围以外的任意单个字符


基本正则表达式:

字符匹配.匹配任意单个字符
[]匹配指定范围内的任意单个字符
[^]匹配指定范围外的任意单个字符
次数匹配*前面的字符可以出现任意次
\?前面的字符出现0次或者1次
\{m\}前面的字符出现m次
\{m,n\}前面的字符出现n次~m次
\{m,\}前面的字符至少出现m次
\{0,n\}前面的字符至多出现n次
.*任意长度的任意字符
位置锚定^行首锚定,写在模式的最左侧
$行尾锚定,写在模式的最右侧
^$匹配空行
\<词首锚定,出现于单词左侧
\>词尾锚定,出现于单词右侧
分组\(\)匹配一个分组
\1引用第1个括号所匹配到的内容,而非模式本身
\2

引用第2个括号所匹配到的内容,而非模式本


扩展正则表达式:

字符匹配.匹配任意单个字符
[]匹配指定范围内的任意单个字符
[^]匹配指定范围外的任意单个字符
次数匹配*前面的字符可以出现任意次
?前面的字符出现0次或者1次
+前面的字符至少出现1次
{m}前面的字符出现m次
{m,n}前面的字符出现n次~m次
{m,}前面的字符至少出现m次
{0,n}前面的字符至多出现n次
锚定^行首锚定,写在模式的最左侧
$行尾锚定,写在模式的最右侧
\<,\b词首锚定,出现于单词左侧
\>,\b词尾锚定,出现于单词右侧
^$匹配空行
分组()匹配一个分组
\1引用第1个括号所匹配到的内容,而非模式本身


grep练习:

1、显示/proc/meminfo文件中以大写或小写S开头的行;

[root@DB2 ~]# grep -i '^s' /proc/meminfo 

[root@DB2 ~]# grep -E '^(S|s)' /proc/meminfo

[root@DB2 ~]# grep '^[S|s]' /proc/meminfo


2、显示/etc/passwd文件中其默认shell为非/sbin/nologin的用户;

[root@DB2 ~]# grep -v "/sbin/nologin$" /etc/passwd | cut -d: -f1


3、显示/etc/passwd文件中其默认shell为/bin/bash并且ID号最大的用户;

[root@DB2 ~]# grep '/bin/bash' /etc/passwd | sort -t: -k3 -n | tail -1 | cut -d: -f1


4、找出/etc/passwd文件中的一位数或两位数;

[root@DB2 ~]# grep '\<[0-9][0-9]\?\>' /etc/passwd

[root@DB2 ~]# grep '\<[0-9][0-9]\{0,1\}\>' /etc/passwd


5、显示/boot/grub/grub.conf中以至少一个空白字符开头的行;

[root@DB2 ~]# grep '^[[:space:]]\{1,\}' /boot/grub/grub.conf


6、显示/etc/rc.d/rc.sysinit文件中,以#开头,后面跟至少一个空白字符,而后又有至少一个非空白字符的行;

[root@DB2 ~]# grep --color '^#[[:space:]]\{1,\}[^[:space:]]\{1,\}' /etc/rc.d/rc.sysinit


7、找出netstat -tan命令执行结果中以'LISTEN'结尾的行;

[root@DB2 ~]# netstat -tan | grep --color 'LISTEN[[:space:]]*$'


8、添加用户bash, testbash, basher, nologin(SHELL为/sbin/nologin),而找出当前系统上其用户名和默认shell相同的用户;

[root@DB2 ~]# grep --color '^\([[:alnum:]]\{1,\}\):.*\1$' /etc/passwd


9、扩展题:新建一个文本文件,假设有如下内容:

He like his lover.

He love his lover.

He like his liker.

He love his liker.

找出其中最后一个单词是由此前某单词加r构成的行。

cat <<EOF> 2.txt

He like his lover.

He love his lover.

He like his liker.

He love his liker.

EOF

[root@DB2 ~]# grep --color '\(l..e\).*\1r' 2.txt


文本搜索利器:grep egrep fgrep


练习:使用扩展的正则表达式

10、显示当前系统上root、bin或halt用户的默认shell;

[root@Oracle ~]# grep -E "^(root|bin|halt):" /etc/passwd | cut -d: -f7文本搜索利器:grep egrep fgrep


11、找出/etc/rc.d/init.d/functions文件中某单词后跟一组小括号“()”行;

[root@Oracle ~]# grep -E -o "\<[[:alnum:]]+\>\(\)" /etc/rc.d/init.d/functions

文本搜索利器:grep egrep fgrep


12、使用echo命令输出一个路径,而后使用grep取出其基名;

echo "/etc/sysconfig/" | grep -o -E "[[:alnum:]]+/?"

[root@Oracle ~]# echo "/etc/sysconfig/" | grep -o -E "[^/]+/?$" | cut -d/ -f1

sysconfig

[root@Oracle ~]# echo "/etc/sysconfig/" | grep -o -E "[[:alnum:]]+/?"

etc/sysconfig/


13、找出ifconfig命令结果中的1-255之间的数字;

[root@Oracle ~]# ifconfig | grep -o -E --color "\<([1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\>"

文本搜索利器:grep egrep fgrep



14、挑战题:写一个模式,能匹配合理的ipv4地址;

cat << EOF > 5.txt 

192.168.1.1

127.0.0.1

10.127.5.1

202.96.128.166

202.96.128.255

255.255.255.255

239.0.1.25

240.1.1.1

0.0.0.1

EOF

[root@Oracle ~]# grep -o -E --color "\<([1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-3][0-9])\>\.\<([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\>\.\<([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\>\.\<([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-4])\>" 5.txt 

文本搜索利器:grep egrep fgrep

 


阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯