Linux基础入门 --15 DAY(文件查找工具使用)

文件查找

locate

        locate查询系统上的预建的文件索引数据库/var/lib/mlocate/mlocate.db

        索引的构建实在系统较为空闲时自动进行(周期任务),执行updatedb可以更新数据库

        索引构建需要遍历整个根文件系统,很耗费资源

        工作特点:

        1.查找速度快

        2.模糊查找

        3.非实时查找

        4.搜索的是文件的全路径,不仅仅是文件全名

        格式:

  locate [OPTION]... PATTERN...

        常用选项:

        -i 不区分大小写搜索

        -n N 只列举前N个匹配项目

        -r 使用基本正则表达式

        范例:

locate conf 

locate -r '\.conf$'

find 

         find是实时查找工具,通过遍历指定路径完成文件查找

        工作特点:

        1.查找速度略慢        

        2.精确查找

        3.实时查找

        4.查找条件丰富

        5.可能只搜索用户具备读取和执行权限的目录

        格式:

find [ OPTION... ]... [ 查找路径 ] [ 查找条件 ] [ 处理动作 ]

        查找路径:指定具体路径,默认为当前目录

        查找条件:指定的查找标准,可以文件名,大小,类型,权限等标准进行;默认找出指定路径下的所有文件

        处理动作:对符合条件的文件做操作,默认输出至屏幕

        指定搜索目录层级

         -maxdepth level 最大搜索目录深度,指定目录下的文件第一级

         -mindepth level最小搜索目录深度        

        范例:

find -maxdepth 2 -mindepth 2

        对每个目录先处理目录内容的文件,在处理目录本身

        -depth -d

        范例:

[root@localhost ~]# tree
.
├── anaconda-ks.cfg
├── love
│   └── lover
└── original-ks.cfg

1 directory, 3 files
[root@localhost ~]# find 
.
./.bash_logout
./.bash_profile
./.bashrc
./.cshrc
./.tcshrc
./original-ks.cfg
./anaconda-ks.cfg
./.cache
./.cache/abrt
./.cache/abrt/lastnotification
./.config
./.config/abrt
./.bash_history
./.Xauthority
./love
./love/lover
[root@localhost ~]# find -d
find: warning: the -d option is deprecated; please use -depth instead, because the latter is a POSIX-compliant feature.
./.bash_logout
./.bash_profile
./.bashrc
./.cshrc
./.tcshrc
./original-ks.cfg
./anaconda-ks.cfg
./.cache/abrt/lastnotification
./.cache/abrt
./.cache
./.config/abrt
./.config
./.bash_history
./.Xauthority
./love/lover
./love
.

        根据文件名和inode查找 

-name "文件名称":支持使用glob,如:*,?,[ ],[^ ]

-iname "文件名称":不区分大小写

-inum n 按inode查找

-samefile name 相同的inode号的文件

-links n 链接数为n的文件

-regex "PATTERN":以PATTERN匹配整个文件路径,而非文件名称

         范例:

[root@localhost ~]# find / -iname passwd
/sys/fs/selinux/class/passwd
/sys/fs/selinux/class/passwd/perms/passwd
/etc/pam.d/passwd
/etc/passwd
/usr/bin/passwd
/usr/share/bash-completion/completions/passwd

[root@localhost ~]# ls . -d
.
[root@localhost ~]# ls . -di
33574977 .
[root@localhost ~]# find / -inum 33574977
/root

[root@localhost ~]# 
[root@localhost ~]# find / -samefile /
/
find: ‘/proc/52313/task/52313/fd/6’: No such file or directory
find: ‘/proc/52313/task/52313/fdinfo/6’: No such file or directory
find: ‘/proc/52313/fd/7’: No such file or directory
find: ‘/proc/52313/fdinfo/7’: No such file or directory

        根据数主,属组查找

-user USERNAME:查找属主为指定用户(UID)的文件

-group GROUPNAME:查找属组为指定组(GID)的文件

-uid UserID:查找属主为指定的UID的文件

-gid GroupID:查找属组为指定GID号的文件

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

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

        根据文件类型查找 

-type TYPE

TYPE可以是以下形式:

f 普通文件

d 目录文件

l 符号链接文件

s 套接字文件

b 块设备文件

c 字符设备文件

p 管道文件 

        示例:

[root@localhost ~]# find /home -type d -ls 

        空文件或目录 

-empty

        示例:

[root@localhost ~]# find /home -empty  

        组合条件 

与:-a

或:-o

非:-not

        示例:

[root@localhost ~]# find /etc/ -type d -o -type l | wc
   1069    1069   39696
[root@localhost ~]# find /etc/ -type d -o -type l -ls | wc
    314    4082   48784

[root@localhost ~]# find /etc/ \( -type d -o -type l \) -ls | wc
   1069   12387  127583

        排除目录 

[root@localhost ~]# find / -path '/usr' -a -prune -o -name "*conf"
//过滤/usr目录价的文件搜索

        根据文件大小来查找 

-size [+|-]#UNIT

        常用单位:k,M,G,c(byte),注意大小写敏感

#UNIT:(#-1,#]

        如:6k 表示(5k,6k]

-UNIT:[0,#-1]

        如:6k 表示[0,5k]

+UNIT:(#,+∞)

        如:6k 表示(6k,+∞)

        示例:

find / -size +10G 

        根据时间戳 

以天为单位

-atime[+|-]#

        #:[#,#+1)

        +#:[#+1,∞]

        -#:[0,#)

-mtime

-ctime

以分钟为单位

-amin

-mmin

-cmin

        根据权限查找 

-perm [/|-]MODE

MODE:精确权限匹配

/MODE:任何一类(u,g,o)对象的权限中只要能一位匹配即可,或关系,+从Centos7开始淘汰

-MODE:每一类对象都必须同时拥有指定权限,与关系

0:表示不关注

        说明:

        find -perm 755 会匹配恰好是755的文件

        只要当任意人有写权限时,find -perm /222就会匹配

        只有当每一个人都有写权限时,find -perm -222才匹配

        只有当其他人(other)有写权限时,find -perm -002才会匹配

        处理动作 

-print :默认处理动作,显示至屏幕

-ls :类似于对查找的文件执行'ls -l'命令

-delete :删除查找的文件

-fls file :查找到的所有文件的长格式信息保存至指定文件中

-ok COMMAND{} \; 对查找到的每一个文件执行由COMMAND指定的命令,对于每一个文件执行命令之前都会交互式确认

-exec COMMAND{} \; 对查找到的每一个文件执行由COMMAND指定的命令

{}:用于引用查找到的文件名自身

参数替换xargs 

        由于很多命令不支持管道|来传递参数,xargs用于产生某个命令的参数,xargs可以读入stdin的数据,并且以空格或回车符将stdin的数据分隔成参数

另外,许多命令不能接受过多参数,命令执行可能会失败,xargs可以解决

注意:文件名或者其他意义的名词内含有空格符的情况

find和xargs的组合:

find | xargs COMMAND

        示例 :

[root@localhost ~]# seq 10 | xargs
1 2 3 4 5 6 7 8 9 10

Linux系统中的xargs命令是一个功能强大的工具,它允许用户将输入数据转换成命令行参数传递给其他命令。以下是对xargs命令的详细解析:

一、基本语法

xargs命令的基本语法为:command | xargs [options] [command]。其中,command为要执行的命令,options为选项,可以通过这些选项来定制xargs的行为。

二、常用选项

  1. -i:指定替换字符串,可以通过{}或者{}+来指定替换位置。这允许用户将xargs接收到的每个参数替换到指定的位置。
  2. -l:设置每次传递参数的数量上限。这个选项允许用户控制每次传递给命令的参数数量。
  3. -n:指定每次传递参数的数量。这个选项与-l类似,但更加直接地设置了每次传递的参数个数。
  4. -0:使用NULL字符作为输入项之间的分隔符,而不是默认的空格或换行符。这对于处理包含空格的文件名或路径特别有用。
  5. -d:自定义一个定界符,而不是用空白字符(空格、制表符、换行符)来分隔输入项。
  6. -t:在执行命令之前,先打印出命令的模板,显示将会执行的命令。
  7. -s:指定命令行参数的最大字符数。

三、工作原理

xargs命令将来自标准输入(stdin)的数据转换为命令行参数,并传递给指定的命令。默认情况下,xargs以空格、制表符和换行符作为分隔符来分割输入数据。如果输入数据中包含这些字符以外的分隔符,可以使用-d选项来指定自定义的分隔符。

 

       

         

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

安红豆.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值