linux下find、grep命令详解

简介: linux下find、grep命令详解

grep命令
格式:grep 参数 要查内容 路径
常用参数: -r:递归 -n:显示行号 -i:忽略大小写 -c:匹配到的行数 -w:全词匹配 -v:显示不包含匹配文本的所有行

递归搜索文件:grep -r "from" ./

aaa@hadoopslave16:~/data/hive/aaa$ grep -r "from" ./
./2.sql: from tmp.tmp* where dt between '20190101' and '20190228';
./6.sql: from
./6.sql: from tmp.tmp
*
递归、显示行号、忽略大小写、全词匹配:grep -r -n -i -w 'risk' ./

aaa@hadoopslave16:~/data/hive/aaa$ grep -r -n -i -w 'risk' ./
./2.sql:3:insert overwrite table risk. partition(dt)
./6.sql:4:insert overwrite table risk.
partition(dt)
./4.sql:4:insert overwrite table risk. partition(dt)
./8.sql:6:insert overwrite table risk.
partition(dt)
排除文件或文件夹: --exclude=file --exclude={file1,file2...} --exclude-dir= dir --exclude-dir={dir1,dir2...}

aaa@hadoopslave16:~/data/hive/aaa$ grep -r -n -i -w 'risk' ./ --exclude=2.sql
./6.sql:4:insert overwrite table risk. partition(dt)
./4.sql:4:insert overwrite table risk.
partition(dt)
./8.sql:6:insert overwrite table risk. partition(dt)
aaa@hadoopslave16:~/data/hive/aaa$ grep -r -n -i -w 'risk' ./ --exclude={2.sql,4.sql}
./6.sql:4:insert overwrite table risk.
partition(dt)
./8.sql:6:insert overwrite table risk.* partition(dt)

aaa@hadoopslave16:~/data/hive$ grep -r -n -i -w 'risk' ./ --exclude-dir=bbb
./aaa/2.sql:3:insert overwrite table risk. partition(dt)
./aaa/6.sql:4:insert overwrite table risk.
partition(dt)
./aaa/4.sql:4:insert overwrite table risk. partition(dt)
./aaa/8.sql:6:insert overwrite table risk.
partition(dt)
aaa@hadoopslave16:~/data/hive$ grep -r -n -i -w 'risk' ./ --exclude-dir={bbb,ccc}
./aaa/2.sql:3:insert overwrite table risk. partition(dt)
./aaa/6.sql:4:insert overwrite table risk.
partition(dt)
./aaa/4.sql:4:insert overwrite table risk. partition(dt)
./aaa/8.sql:6:insert overwrite table risk.
partition(dt)
find命令
格式:find 路径 参数 文件名

按文件名查找:
find ./ -name 2.sql
find / -name 2.sql 2>/dev/null
注意:root用户将某些文件目录设置成禁止访问模式,普通用户就没权限用find命令来查这些目录或文件。往往出现“Permission denied”,为避免这种情况,可转移错误提示,把查找错误提示转移到特定的目录中去。系统执行这个命令后,遇到错误的信息就直接输送到stderrstream 2 中,2.log 2就是表明系统将把错误信息输送到stderrstream 2中,/dev/null是一个特殊的文件,表明空的或者错误的信息,这样查询到的错误信息将被转移了,不会再显示了。
参考:https://blog.csdn.net/ydfok/article/details/1486451

按名称查找

aaa@hadoopslave16:~/data/hive$ find ./ -name 2.sql
./aaa/2.sql
./bbbbb/2.sql

有访问限制

aaa@hadoopslave16:~/data/hive$ find / -name 2.sql
find: ‘/boot/grub2’: Permission denied
find: ‘/proc/tty/driver’: Permission denied
find: ‘/proc/1/task/1/fd’: Permission denied

转移访问限制

aaa@hadoopslave16:~/data/hive$ find / -name 2.sql 2>/dev/null
/home/aaa/data/hive/aaa/2.sql
/home/aaa/data/hive/bbbbb/2.sql
按文件特性查找:
find / -size +10000c #查找出大于10000字节的文件(c:字节,w:双字,k:KB,M:MB,G:GB)
find / -size -1000k #查找出小于1000KB的文件
find / -amin -10 # 查找在系统中最后10分钟访问的文件(access time)
find / -atime -2 # 查找在系统中最后48小时访问的文件
find / -empty # 查找在系统中为空的文件或者文件夹
find / -group cat # 查找在系统中属于 group为cat的文件
find / -mmin -5 # 查找在系统中最后5分钟里修改过的文件(modify time)
find / -mtime -1 #查找在系统中最后24小时里修改过的文件
find / -user fred #查找在系统中属于fred这个用户的文件

aaa@hadoopslave16:~/data/hive/aaa$ ll
total 180
-rw-rw-r-- 1 aaa aaa 6918 Jul 9 16:15 1.sql
-rw-rw-r-- 1 aaa aaa 15331 Jul 9 16:18 2.sql
-rw-rw-r-- 1 aaa aaa 6284 Jul 9 16:57 3.sql
-rw-rw-r-- 1 aaa aaa 84134 Jul 9 21:17 4.sql
-rw-rw-r-- 1 aaa aaa 6520 Jul 9 20:31 5.sql
-rw-rw-r-- 1 aaa aaa 14861 Jul 9 21:04 6.sql
-rw-rw-r-- 1 aaa aaa 6520 Jul 9 20:54 7.sql
-rw-rw-r-- 1 aaa aaa 24070 Jul 9 22:11 8.sql
-rw-rw-r-- 1 aaa aaa 13 Jul 13 11:58 ads
drwxrwxr-x 2 aaa aaa 6 Jul 13 12:01 jjj
-rw-rw-r-- 1 aaa aaa 853 Jul 11 18:14 loan.csv

aaa@hadoopslave16:~/data/hive/aaa$ find ./ -size -1000c
./
./loan.csv
./ads
./jjj
aaa@hadoopslave16:~/data/hive/aaa$ find ./ -size +10000c
./2.sql
./6.sql
./4.sql
./8.sql
aaa@hadoopslave16:~/data/hive/aaa$ find ./ -size +10k
./2.sql
./6.sql
./4.sql
./8.sql

find排除单个目录、多个目录
使用-prune

在当前目录除test外的子目录查询txt文件
find . -path ./test -prune -false -o -name .txt

find . -path ./test -prune -o -name
.txt -print

多个目录搜索
find /test /test11 -name *.txt

排除多个目录,注意()与表达式之间有空格,-o是或意思,dir后面没有/,排除目录包含/dir/
find . ( -path dir1 -o -path dir2 -o -path dir3 ) -prune -false -o -name *.txt

显示find文件权限、最后修改时间(d)、最后访问时间(u)等
find . ( -path dir1 -o -path dir2 -o -path dir3 ) -prune -false -o -name *.txt -exec ls -ld --time-style '+%Y/%m/%d %H:%M:%S' {} \;

显示find文件权限、最后访问时间等,通过awk展示需要的几个
find . ( -path dir1 -o -path dir2 -o -path dir3 ) -prune -false -o -name *.txt -exec ls -lu --time-style '+%Y/%m/%d %H:%M:%S' {} \; | awk '{print $1,$3,$6,$7,$8}' >/tmp/testdate +%Y%m%d.txt

参考:https://www.cnblogs.com/zouhong/p/16139765.html

find、grep、xargs组合查找
find ./ -name '*'|xargs grep -i test

aaa@hadoopslave16:~/data/hive$ find ./ -name ''|xargs grep -r -n -i risk.**
./aaa/6.sql:4:insert overwrite table risk. partition(dt)
./aaa/6.sql:4:insert overwrite table risk.
partition(dt)
./aaa/6.sql:4:insert overwrite table risk.* partition(dt)
xargs命令是给其他命令传递参数的一个过滤器,常作为组合多个命令的一个工具。它主要用于将标准输入数据转换成命令行参数,xargs能够处理管道或者标准输入并将其转换成特定命令的命令参数。也就是说find的结果经过xargs后,其实将find找出来的文件名逐个作为了grep的参数。grep再在这些文件内容中查找关键字test。

————————————————

                        版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

原文链接:https://blog.csdn.net/jsbylibo/article/details/84837865

目录
相关文章
|
4天前
|
Linux Python Perl
Linux命令删除文件里的字符串
Linux命令删除文件里的字符串
16 7
|
5天前
|
Shell Linux
Linux shell编程学习笔记82:w命令——一览无余
Linux shell编程学习笔记82:w命令——一览无余
|
6天前
|
监控 Linux
linux之grep详解
linux之grep详解
|
6天前
|
Linux Perl
Linux之sed命令
Linux之sed命令
|
6天前
|
Linux
深入理解Linux中的cp命令:文件与目录的复制利器
深入理解Linux中的cp命令:文件与目录的复制利器
|
7天前
|
Linux Docker 容器
9. 同步执行Linux多条命令
9. 同步执行Linux多条命令
|
7天前
|
Linux Shell
10-10|linux命令查询 关键字在文本中出现的行数
10-10|linux命令查询 关键字在文本中出现的行数
|
7天前
|
存储 Linux Shell
常用vim命令和vim基本使用及Linux用户的管理,用户和组相关文件
这篇文章介绍了Vim编辑器的基本使用、常用命令和模式,以及Linux系统中用户和组的管理方法,包括用户和组相关文件如/etc/passwd、/etc/shadow和/etc/group的说明。
常用vim命令和vim基本使用及Linux用户的管理,用户和组相关文件
|
7天前
|
Ubuntu Linux Shell
10-21|在linux我如果修改了时间,什么命令可以恢复正确啊
10-21|在linux我如果修改了时间,什么命令可以恢复正确啊
|
7天前
|
Linux Perl
6-20|linux sed命令
6-20|linux sed命令
下一篇
无影云桌面