在linux中经常需要对文本或输出内容进行过滤,最常用的过滤命令是grep

grep [OPTIONS] PATTERN [FILE...]
grep按行检索输入的每一行,如果输入行包含模式PATTERN,则输出这一行。这里的PATTERN是正则表达式(参考前一篇,本文将结合grep一同举例)。
输出文件/etc/passwd中包含root的行:
[root@centos7 temp]# grep root /etc/passwd root:x:0:0:root:/root:/bin/bash operator:x:11:0:operator:/root:/sbin/nologin
或者从标准输入获得:
[root@centos7 temp]# cat /etc/passwd | grep root root:x:0:0:root:/root:/bin/bash operator:x:11:0:operator:/root:/sbin/nologin
需要注意的地方是:当grep的输入既来自文件也来自标准输入时,grep将忽略标准输入的内容不做处理,除非使用符号-来代表标准输入:
[root@centos7 temp]# cat /etc/passwd | grep root /etc/passwd - /etc/passwd:root:x:0:0:root:/root:/bin/bash /etc/passwd:operator:x:11:0:operator:/root:/sbin/nologin (标准输入):root:x:0:0:root:/root:/bin/bash (标准输入):operator:x:11:0:operator:/root:/sbin/nologin
此时,grep会标明哪些结果来自于文件哪些来自于标准输入。
输出文件/etc/passwd和文件/etc/group中以root开头的行:
[root@centos7 temp]# grep "^root" /etc/passwd /etc/group /etc/passwd:root:x:0:0:root:/root:/bin/bash /etc/group:root:x:0:
输出文件/etc/passwd中以/bin/bash结尾的行:
[root@centos7 temp]# grep "/bin/bash$" /etc/passwd root:x:0:0:root:/root:/bin/bash learner:x:1000:1000::/home/learner:/bin/bash
注意以上两个例子中PATTERN被双引号引用起来以防止被shell解析。
输出文件/etc/passwd中不以a-s中任何一个字母开头的行:
[root@centos7 temp]# grep "^[^a-s]" /etc/passwd tss:x:59:59:Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin tcpdump:x:72:72::/:/sbin/nologin
这里需要理解两个^间不同的含义,第一个^表示行首,第二个在[]内部的首个字符^表示取反。
输出文件/etc/passwd中字符0连续出现3次及以上的行(注意转义字符'\'):
[root@centos7 temp]# grep "0\{3,\}" /etc/passwd
learner:x:1000:1000::/home/learner:/bin/bash
如输出文件/etc/passwd中以字符r或l开头的行:
[root@centos7 temp]# grep "^[r,l]" /etc/passwd root:x:0:0:root:/root:/bin/bash lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin learner:x:1000:1000::/home/learner:/bin/bash
选项-i使grep在匹配模式时忽略大小写:
[root@centos7 temp]# grep -i abcd file
ABCD
function abcd() {
[root@centos7 temp]#
选项-o表示只输出匹配的字符,而不是整行:
[root@centos7 temp]# grep -oi abcd file ABCD abcd [root@centos7 temp]#
选项-c统计匹配的行数:
[root@centos7 temp]# grep -oic abcd file 2 [root@centos7 temp]#
选项-v表示取反匹配,如输出/etc/passwd中不以/sbin/nologin结尾的行:
[root@centos7 temp]# grep -v "/sbin/nologin$" /etc/passwd root:x:0:0:root:/root:/bin/bash sync:x:5:0:sync:/sbin:/bin/sync shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown halt:x:7:0:halt:/sbin:/sbin/halt learner:x:1000:1000::/home/learner:/bin/bash
选项-f FILE表示以文件FILE中的每一行作为模式匹配:
[root@centos7 temp]# cat test
abcd
ABCD
[root@centos7 temp]# grep -f test file
ABCD
function abcd() {
[root@centos7 temp]#
选项-x表示整行匹配:
[root@centos7 temp]# grep -xf test file ABCD [root@centos7 temp]#
选项-w表示匹配整个单词:
[root@centos7 temp]# grep here file here there [root@centos7 temp]# grep -w here file here [root@centos7 temp]#
选项-h表示当多个文件时不输出文件名:
[root@centos7 temp]# cat /etc/passwd|grep ^root - /etc/passwd -h root:x:0:0:root:/root:/bin/bash root:x:0:0:root:/root:/bin/bash
选项-n表示显示行号:
[root@centos7 temp]# grep -n "^[r,l]" /etc/passwd 1:root:x:0:0:root:/root:/bin/bash 5:lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin 24:learner:x:1000:1000::/home/learner:/bin/bash
选项-A N、-B N、-C N表示输出匹配行和其'周围行'
-A N 表示输出匹配行和其之后(after)的N行 -B N 表示输出匹配行和其之前(before)的N行 -C N 表示输出匹配行和其之前之后各N行 [root@centos7 temp]# grep -A 2 ^operator /etc/passwd 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 [root@centos7 temp]# grep -B2 ^operator /etc/passwd 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 [root@centos7 temp]# grep -C1 ^operator /etc/passwd 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
选项-F视PATTERN为它的字面意思匹配(忽略字符的特殊含义),等同于执行命令fgrep:
[root@centos7 temp]# grep -F ^root /etc/passwd [root@centos7 temp]#
命令无输出
选项-E可以使用扩展的正则表达式,如同执行egrep命令:
[root@centos7 temp]# egrep "^root|^learner" /etc/passwd root:x:0:0:root:/root:/bin/bash learner:x:1000:1000::/home/learner:/bin/bash
使用扩展正则表达式意味着不需要转义就能表示字符的特殊含义,包括?,+,{,|,(和)。
选项-P表示使用perl的正则表达式进行匹配
如:
[root@centos7 ~]# echo "helloworld123456"| grep -oP "\d+" 123456 [root@centos7 ~]#
perl正则中"\d"表示数字,+表示匹配一到多次(同vim)。
选项-a将二进制文件当成文本文件处理:
[root@centos7 ~]# grep -a online /usr/bin/ls %s online help: <%s> [root@centos7 ~]#
选项--exclude=GLOB和--include=GLOB分别表示排除和包含匹配GLOB的文件,GLOB表示通配符(find及xargs用法见基础命令介绍三):
[root@centos7 temp]# find . -type f | xargs grep --exclude=*.txt --include=test* bash ./test.sh:#!/bin/bash [root@centos7 temp]#
grep强大的过滤能力来自于各种选项以及正则表达式的配合,在今后的文章中还有更多的例子。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# linux
# 文本过滤
# grep
# Linux中grep和egrep命令详解
# linux中使用grep命令详解
# linux 中grep 匹配制表符 和 换行符的命令
# Linux 使用grep筛选多个条件及grep常用过滤命令
# Linux中利用grep命令如何检索文件内容详解
# Linux下find和grep常用命令及区别介绍
# 详解linux grep命令
# 深入理解Linux中的grep命令
# Linux下的Grep命令使用方法详细介绍
# Linux常用命令之grep命令用法详解
# 来自于
# 正则表达式
# 中以
# 行号
# 不以
# 第一个
# 就能
# 多个
# 不需要
# 第二个
# 不做
# 可以使用
# 任何一个
# 一到
# 首个
# 需要注意
# 最常用
# 大家多多
# 文本文件
# 这一行
相关文章:
清除minerd进程的简单方法
齐河建站公司:营销型网站建设与SEO优化双核驱动策略
如何确认建站备案号应放置的具体位置?
在线ppt制作网站有哪些,请推荐几个好的课件下载的网站?
网站制作专业公司有哪些,如何制作一个企业网站,建设网站的基本步骤有哪些?
mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?
如何快速搭建高效简练网站?
动图在线制作网站有哪些,滑动动图图集怎么做?
如何在景安服务器上快速搭建个人网站?
如何快速选择适合个人网站的云服务器配置?
公司网站建设制作费用,想建设一个属于自己的企业网站,该如何去做?
利用JavaScript实现拖拽改变元素大小
建站之星安装需要哪些步骤及注意事项?
装修招标网站设计制作流程,装修招标流程?
陕西网站制作公司有哪些,陕西凌云电器有限公司官网?
如何自定义建站之星网站的导航菜单样式?
网站建设制作需要多少钱费用,自己做一个网站要多少钱,模板一般多少钱?
个人网站制作流程图片大全,个人网站如何注销?
佛山企业网站制作公司有哪些,沟通100网上服务官网?
c++怎么编写动态链接库dll_c++ __declspec(dllexport)导出与调用【方法】
如何高效利用200m空间完成建站?
如何在宝塔面板中创建新站点?
建站之星备案流程有哪些注意事项?
七夕网站制作视频,七夕大促活动怎么报名?
linux top下的 minerd 木马清除方法
家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?
电商网站制作价格怎么算,网上拍卖流程以及规则?
网站制作大概多少钱一个,做一个平台网站大概多少钱?
如何在云指建站中生成FTP站点?
Swift中swift中的switch 语句
宝盒自助建站智能生成技巧:SEO优化与关键词设置指南
网站制作需要会哪些技术,建立一个网站要花费多少?
如何挑选高效建站主机与优质域名?
专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些?
如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?
高性价比服务器租赁——企业级配置与24小时运维服务
Thinkphp 中 distinct 的用法解析
如何用5美元大硬盘VPS安全高效搭建个人网站?
简历在线制作网站免费,免费下载个人简历的网站是哪些?
视频网站app制作软件,有什么好的视频聊天网站或者软件?
平台云上自主建站:模板化设计与智能工具打造高效网站
电脑免费海报制作网站推荐,招聘海报哪个网站多?
如何用腾讯建站主机快速创建免费网站?
,网页ppt怎么弄成自己的ppt?
广州营销型建站服务商推荐:技术优势与SEO优化解析
建站VPS推荐:2025年高性能服务器配置指南
制作旅游网站html,怎样注册旅游网站?
西安制作网站公司有哪些,西安货运司机用的最多的app或者网站是什么?
如何快速重置建站主机并恢复默认配置?
*请认真填写需求信息,我们会在24小时内与您取得联系。