linux里面find的用法,Linux中find命令的使用技巧

本文详细介绍了Linux系统中查找文件的两种方法:locate和find命令。locate基于预构建的文件数据库进行快速搜索,而find则实时遍历目录进行精确匹配,支持多种查找条件,如文件类型、大小、权限、属主等。文章还提供了多个实例来演示find命令的用法,包括查找特定文件、按时间或大小筛选、执行操作等,以及如何组合条件进行高级搜索。
摘要由CSDN通过智能技术生成

文件查找有两种方式:

一、locate:非实时查找,模糊匹配,查找时根据全系统文件数据库进行;速度快

# updatedb:是手动生成文件数据库;速度快

二、find:实时查找,精确匹配,支持众多查找标准,遍历指定目录中的所有文件完成查找;速度慢

find命令的用法

find  查找路径  查找标准  查找到以后的处理运作

查找路径:默认为当前目录

查找标准:默认为指定路径下的所有文件

处理运作:默认为显示

其匹配标准:

-name `FILENAME`:对文件名做精确匹配

文件名通配:

*:任意长度

?:任意单个字符

[]:匹配指定范围内的任意单个字符

[:space:]:空白字符

[:punct:]:标点符号

[:lower:]:小写字母

[:upper:]: 大写字母

[:alpha:]: 大小写字母

[:digit:]: 数字

[:alnum:]: 数字和大小写字母

例:#  find  /etc  -name  'passwd*'  -->查找以/etc目录下以passwd开头的文件

-iname ‘FILENAME':文件名匹配时不区分大小写

-regex PATTERN:基于正则表达式进行文件名匹配

-user USERNAME:根据属主查找

例:#  find  /tmp  -user  student  -->查找/tmp目录下属主为student的文件

-group GROUPNAME:根据属组查找

-uid UID:根据UID查找

例: #  find  /tmp  -uid  2003 -->查找/tmp目录下uid为2003的文件

-gid GID:根据GID查找

-nouser:查找没有属主的文件

例: #  find  /tmp  -nouser  -->查找/tmp目录下没有属主的文件

-nogroup:查找没有属组的文件

-type:根据文件类型查找

文件类型:

f:普通文件

d:目录文件

b:块设备文件(block)

c:字符设备文件(character)

l:符号链接诶文件(pipe)

p:命令管道文件(pipe)

s:套接字文件(socket)

例:#  find  /tmp  -type  f  -->查找/tmp目录下的普通文件

-size:根据文件大小查找[+|-]

(11M即大于10M小于等于11M)

# k

# M

# G

例:#  find  /tmp  -size  +11M -->查找/tmp目录下所有大于11M的文件

组合条件:(默认为与关系)

-a:与

-o:或

-not:非

其优先级为:-not > -a > -o

小练习:找出/tmp目录下,不是目录,并且还不能是套接字类型的文件

#  find  /tmp  -not  -type  d  -a  -not  -type  s

或者 #  find  /tmp  -not  \(  -type  d  -a  -type  s  \)

-mtime:根据文件的修改时间查找;(天数)

-ctime:根据文件的改变时间查找;(天数)

-atime:根据文件的访问时间进行查找;(天数)

+n:表示至少n天没访问过

-n:表示n天内没访问过

n:表示第n天访问过

例: find  /tmp  -mtime  -7  -->查找/tmp目录下7天内被修改过的文件

-mmin:根据文件的修改时间查找;(分钟数)

-cmin:根据文件的改变时间查找;(分钟数)

-amin:根据文件的访问时间进行查找;(分钟数)

(用法同上)

-perm  MODE (直接跟权限表示精确匹配)按权限查找

-mode:文件权限能完全包含此MODE时才能显示

/mode:任意一位匹配即可

例:# find  /tmp  -perm  -011 -->查找组用户和其他用户都有读权限的文件

#find  /tmp  -perm  /022  --> 查找组用户或者其他用户有写权限的文件

运作:

-print:显示

-ls: 类似ls -l的形式显示每一个文件的详细信息

-ok COMMAND {} \;  对查找的文件执行命令。每一次操作都需要用户确认

-exec COMMAND {} \;  不需要确认

例:   # find /tmp -prem -006 -exec chmod o-w {} \;

--> 查找其他用户有读写权限的用户,并且把将其写权限去掉。

# find -type d -ok chmod +x {} \;  --> 将当前的目录都改为执行权限

# find -perm -020 -exec mv {} {}.new \;)

--> 将当前目录下有写权限的组用户的名字改为后面加.new

Find命令的高级应用:

1、查找/var目录下属主为root并且属组为mail的所有文件;

# find /var -user root -group mail

(这里默认的关系为与的关系,即两个条件为真,结果为真。中间可加-a)

2、查找/usr目录下不属于root,bin,或student的文件;

# find /usr -not -user root -a -not -user bin -a -not -user student

# find /usr -not \( -user root -o -user bin -o -user student \)

(上边一句分别写不属于各个用户的文件;下边一句是将语句合起来,括号前要用\作转义符,这里使用摩根定律,加括号时,括号里的与关系要转成或关系)

3、查找/etc目录下最近一周内内容修改过且不属于root及student用户的文件;

# find /etc -mtime -7 -not \ ( -user root -o -user student \)

# find /etc -mtime -7 -not -user root -a -not -user student

同上,使用摩根定律。

4、查找当前系统上没有属主或属组且最近1天内曾被访问过的文件,并将其属主属组均修改为root;

# find / \( -nouser -o -nogroup \) -a -atime -1 -exec chown root:root {} \;

(先找出没有属主或属组的文件,要用括号括着,再找一天内被访问过的文件。最后用-exec修改其属主和属组。 最后边的\; 一定不要忘了)

5、查找/etc目录下大于1M的文件,并将其文件名写入/tmp/etc.largefiles文件中;

# find /etc -size +1M >> /tmp/etc.largefiles

# find /etc -size +1M | xarges echo {} >> /tmp/etc.largefiles

扩展:

xarges --> 可用其将查找出的文件名写入另一个文件中。

6、查找/etc目录下所有用户都没有写权限的文件,显示出其详细信息;

# find /etc -not -perm /222 -ls

(-ls,可查看查找到文件的详细信息)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值