Linux-find和xargs

第2章

find是一个非常有效的工具,它可以遍历当前目录甚至于整个文件系统来查找某些文件或目录。

即使系统中含有网络文件系统(NFS),find命令在该文件系统中同样有效,只要你具有相应的权限。

#Find命令的一般形式为
find pathname -options [ -print -exec -ok ]
参数:
pathname
find命令所查找的目录路径。例如用.来表示当前目录,用/来表示系统根目录。
-print
find命令将匹配的文件输出到标准输出。
-exec
find命令对匹配的文件执行该参数所给出的shell命令。相应命令的形式为‘command’{} \;注意{}和、;之间的空格。
-ok
-ok和-exec的作用相同。但是ok会在执行每一个命令之前,都会给出提示,让用户来确定是否执行。

2.1 find命令选项

find命令有很多选项或表达式,每一个选项前面跟随一个横杠-。

-name
按照文件名查找文件
-perm
按照文件权限来查找文件
-prune
使用这一选喜爱嗯可以使find命令不再当前指定的目录中查找,如果同时使用了-depth选项,那么-prune选项将被find命令忽略
-user
按照文件属主来查找文件
-group
按照文件所属的组来查找文件
-mtime -n +n
按照文件的更改时间来查找文件,-n表示文件更改时间距现在n天以内,+n表示文件更改时间距现在n天以前
-nogroup
查找无有效所属组的文件,即该文件所属的组在/etc/groups中不存在
-nouser
查找无有效属主的文件,即该文件的属主在/etc/passwd中不存在
-newer file1 ! file2
查找更改时间比文件file1新但比文件file2旧的文件
-type 查找某一类型的文件
    b - 块设备文件
    d - 目录
    c - 字符设备文件
    p - 管道文件
    l - 符号链接文件
    f - 普通文件
-size n[c]
查找文件长度为n块的文件,带有c时表示文件长度以字节计
-depth
在查找文件时,首先查找当前目录中的文件,然后再在其子目录中查找
-fstype
查找位于某一类型文件系统中的文件,这些文件系统类型通常可以在配置文件/etc/fstab中找到,该配置文件中包含了本系统中有关文件系统的信息
-mount
在查找文件时不跨越文件系统mount点
-follow
如果find命令遇到符号链接文件,就跟踪至链接所指向的文件
-cpio
对匹配的文件使用cpio命令,将这些文件备份到磁带设备中

2.1.1 使用name选项

可以使用某种文件名模式来匹配文件,记住要用引号将文件名模式引起来

1、在自己的根目录$HOME中查找文件名符合*.txt的文件,使用~作为‘pathname’参数,波浪号代表了你的$HOME目录
$ find ~ -name "*.txt" -print
2、在当前目录及子目录中查找所有的*.txt文件
$ find . -name "*.txt" -print
3、在当前及子目录中查找文件名以一个大写字母开头的文件
$ find . -name "[A-Z]*" -print
4、在/etc目录中查找文件名以host开头的文件
$ find /etc -name "host*" -print
5、查找$HOME目录中的文件
$ find ~ -name "*" -print
或
$ find . -print
6、从根目录开始查找所有的文件(尽量不要使用)
$ find / -name "*" -print
7、在当前目录查找文件名以两个小写字母开头,跟着是两个数字,最后是*.txt的文件
$ find . -name "[a-z][a-z][0--9][0--9].txt" -print

2.1.2 使用perm选项

按照文件权限模式来查找文件,采用-perm选项,最好使用八进制的权限表示法

1、在当前目录下查找文件权限位为755的文件
$ find . -perm 755 -print
2、在当前目录下查找所有用户都可读、写、执行的文件,需要在八进制数字千米加一个横杠-
$ find . -perm -007 -print

2.1.3 忽略某个目录

查找文件时希望忽略某个目录,使用-prune选项来指出需要忽略的目录

如果你同时使用了-depth选项,那么-prune选项就会被find命令忽略

#如果希望在/apps目录下查找文件,但不希望在/apps/bin目录下查找,可以用
$ find /apps -name "/apps/bin" -prune -o -print

2.1.4 使用user和nouser选项

按照文件属主查找文件,可以给出相应的用户名

1、在$HOME目录中查找文件属主为dave的文件
$ find ~ -user dave -print
2、在/etc目录下查找文件属主为uucp的文件
$ find /etc -user uucp -print
3、使用-nouser查找属主账户已经被删除的文件,可以找到那些属主在/etc/passwd文件中没有有效账户的文件。在使用-nouser选项时,不必给出用户名
4、在/home目录下查找所有的这类文件
$ find /home -nouser -print

2.1.5 使用group和nogroup

针对文件所属于的用户组

1、在/apps目录下查找属于accts用户组的文件
$ find /apps -group accts -print
2、

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值