用grep -c来统计匹配的行数
grep -c 的作用类似grep | wc -l,不同的是,如果是查找多个文件,grep -c会统计每个文件匹配的行数,每行一个文件的列出来,而wc -l 则列出总的统计数字。
另外grep -c 要比 grep | wc -l快一点。
grep同时满足多个关键字和满足任意关键字
grep 同时满足多个关键字和满足任意关键字
① grep -E "word1|word2|word3" file.txt
满足任意条件(word1、word2和word3之一)将匹配。
② grep word1 file.txt | grep word2 |grep word3
必须同时满足三个条件(word1、word2和word3)才匹配。
-w 显示全部符合的行
-v 是反向查找的意思,比如 grep -v grep 就是查找不含有 grep 字段的行
-E 正则表达式查找
--lolor=auto 标记匹配颜色
-o 只输出文件中匹配到的部分
-c 统计文件或文本中包含匹配字符串的行数
-n 输出包含匹配字符串的行
-r 在多级目录中对文本进行递归搜索
-i 忽略大小写
-e 多个匹配样式
-q 静默输出 成功返回0 失败返回非0
-A # 显示匹配结果之后的#行
-B # 显示匹配结果之前的#行
-C # 显示匹配结果前#行和后#行
如果在只是想匹配模式的上下几行,grep可以实现。
$grep -5 'parttern' inputfile //打印匹配行的前后5行
$grep -C 5 'parttern' inputfile //打印匹配行的前后5行
$grep -A 5 'parttern' inputfile //打印匹配行的后5行
$grep -B 5 'parttern' inputfile //打印匹配行的前5行
查看mysql慢日志中ip地址为192.168.0.10发送过来的SQL语句的后面三行
- tail -50 /usr/local/mysql/data/sql-slow.log |grep -3 '192.168.0.10' 匹配php错误日志中某一个字段
- tail -100 /data/logs/php/php_error_5.3.log | grep "Memcache::get()";
查看某一个文件第5行和第10行
sed -n '5,10p' filename 这样你就可以只查看文件的第5行到第10行。
grep 'invalid bank' repay.log.2018-12.log | grep '请求代扣'
查询出符合查询条件的总数
grep 'invalid banko' repay.log.2018-12.log | grep '请求代扣' | wc -l