linux笔记(26)grep

简介:

正则是一串有规律的字符串
grep/egrep egrep是grep的拓展
sed
awk
学好三个命令,对编写shell脚本有很多大帮助

grep 过滤指定关键词
grep +参数 'word' filename 
-c 显示关键词有多少行
[root@localhost grep]# grep -c 'nologin' passwd 
19

-n 显示关键词所在的行号
[root@localhost grep]# grep -n 'nologin' passwd 
2:bin:x:1:1:bin:/bin:/sbin/nologin
3:daemon:x:2:2:daemon:/sbin:/sbin/nologin
4:adm:x:3:4:adm:/var/adm:/sbin/nologin
5:lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
9:mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
10:operator:x:11:0:operator:/root:/sbin/nologin
11:games:x:12:100:games:/usr/games:/sbin/nologin
12:ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
13:nobody:x:99:99:Nobody:/:/sbin/nologin
14:systemd-bus-proxy:x:999:997:systemd Bus Proxy:/:/sbin/nologin
15:systemd-network:x:192:192:systemd Network Management:/:/sbin/nologin
16:dbus:x:81:81:System message bus:/:/sbin/nologin
17:polkitd:x:998:996:User for polkitd:/:/sbin/nologin
18:tss:x:59:59:Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin
19:postfix:x:89:89::/var/spool/postfix:/sbin/nologin
20:sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
21:chrony:x:997:995::/var/lib/chrony:/sbin/nologin
24:user1:x:1111:1000::/home/user222:/sbin/nologin
25:user3:x:1010:1000::/home/user111:/sbin/nologin

-i 不区分大小写的过滤关键词

-v 过滤出来没有关键词的行号

-r 遍历所有子目录

-A 后面跟数字,过滤出符合要求的行向下的n行列出来
[root@localhost grep]# grep -A2 'root' passwd 
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin

operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin

-B 后面跟数字,过滤出符合要求的行向上的n行列出来
[root@localhost grep]# grep -B2 'root' passwd 
root:x:0:0:root:/root:/bin/bash

halt:x:7:0:halt:/sbin:/sbin/halt
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nolog

-A 后面跟数字,过滤出符合要求的行上下的n行列出来
[root@localhost grep]# grep -C2 'root' passwd 
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin

halt:x:7:0:halt:/sbin:/sbin/halt
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin


grep/egrep 示列
grep '[0-9]' passwd 把0-9的数字过滤出来
grep -v '[0-9]' passwd 没有0-9的行过滤出来
grep -v '^#' /etc/inittab 把不是以#开头的行列出来
[root@localhost grep]# grep -vn '^#' inittab 
7:dadasdasd
13:dadasda

^放到[]外面 表示以***开头,放[^]里面,表示非[]里的字符

grep 'r.o' passwd .表示任意的一个字符 
grep 'ro' passwd 左边的字符重复0-n次,0次就是没有,则可以匹配到一个o
.* 可以匹配到任意的字符

grep 'o{2}' passwd 
[root@localhost grep]# grep 'o{2}' passwd 过滤2个o的字符,4个o是由2个o组成的,所以也可以匹到
root:x:0:0:root:/root:/bin/bash
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
lty:x:1000:1000::/hoooome/lty:/bin/bash

如果不想输入脱义符\,也可以用
egrep 'o{2}' passwd

[root@localhost grep]# egrep 'o+o' passwd +号表示左侧的字符重复1次或多次,和*的区别是没有0次,所以一个o匹配不到
root:x:0:0:root:/root:/bin/bash
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
lty:x:1000:1000::/hoooome/lty:/bin/bash

[root@localhost grep]# egrep 'o?1o' passwd ?表示左侧字符重复0次或1次
bin:x:1o:1:bin:/bin:/sbin/nologin
mail:x:8:o1o2:mail:/var/spool/mail:/sbin/nologin

|
[root@localhost grep]# egrep 'root|user' passwd |表示或者的意思
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin
tss:x:59:59:Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin
user1:x:1111:1000::/home/user222:/sbin/nologin
user3:x:1010:1000::/home/user111:/sbin/nologin










本文转自 小新锐 51CTO博客,原文链接:http://blog.51cto.com/13407306/2044083,如需转载请自行联系原作者
目录
相关文章
|
2月前
|
Ubuntu 搜索推荐 Linux
详解Ubuntu的strings与grep命令:Linux开发的实用工具。
这就是Ubuntu中的strings和grep命令,透明且强大。我希望你喜欢这个神奇的世界,并能在你的Linux开发旅程上,通过它们找到你的方向。记住,你的电脑是你的舞台,在上面你可以做任何你想做的事,只要你敢于尝试。
144 32
|
2月前
|
运维 监控 中间件
Linux运维笔记 - 如何使用WGCLOUD监控交换机的流量
WGCLOUD是一款开源免费的通用主机监控工具,安装使用都非常简单,它可以监控主机、服务器的cpu、内存、磁盘、流量等数据,也可以监控数据库、中间件、网络设备
|
9月前
|
Ubuntu Linux Python
Tkinter错误笔记(一):tkinter.Button在linux下出现乱码
在Linux系统中,使用Tkinter库时可能会遇到中文显示乱码的问题,这通常是由于字体支持问题导致的,可以通过更换支持中文的字体来解决。
439 0
Tkinter错误笔记(一):tkinter.Button在linux下出现乱码
|
7月前
|
监控 Linux 数据处理
Linux grep技巧 结合awk查询
结合 `grep` 和 `awk`,可以实现灵活、高效的文本处理和数据分析。`grep` 用于快速过滤符合条件的行,`awk` 用于进一步处理和提取数据。这种组合使用在日志分析、数据处理和系统监控等场景中尤为常见。掌握这两者的基本用法和组合技巧,可以大大提升在 Linux 环境下的工作效率。
159 7
|
9月前
|
Linux API 开发工具
FFmpeg开发笔记(五十九)Linux编译ijkplayer的Android平台so库
ijkplayer是由B站研发的移动端播放器,基于FFmpeg 3.4,支持Android和iOS。其源码托管于GitHub,截至2024年9月15日,获得了3.24万星标和0.81万分支,尽管已停止更新6年。本文档介绍了如何在Linux环境下编译ijkplayer的so库,以便在较新的开发环境中使用。首先需安装编译工具并调整/tmp分区大小,接着下载并安装Android SDK和NDK,最后下载ijkplayer源码并编译。详细步骤包括环境准备、工具安装及库编译等。更多FFmpeg开发知识可参考相关书籍。
288 0
FFmpeg开发笔记(五十九)Linux编译ijkplayer的Android平台so库
|
10月前
|
存储 Linux Shell
linux查找技巧: find grep xargs
linux查找技巧: find grep xargs
120 13
|
10月前
|
监控 Linux
linux之grep详解
linux之grep详解
|
10月前
|
机器学习/深度学习 存储 Linux
linux中强大且常用命令:find、xargs、grep
linux中强大且常用命令:find、xargs、grep
620 9
|
11月前
|
Unix Linux 开发工具
linux笔记 diff及patch的制作与使用
这篇文章是关于Linux系统中使用`diff`命令生成补丁文件以及使用`patch`命令应用这些补丁的详细教程和实战案例。
289 2
linux笔记 diff及patch的制作与使用
|
10月前
|
SQL 移动开发 Linux
linux下find、grep命令详解
linux下find、grep命令详解
310 8