zoukankan      html  css  js  c++  java
  • linux文件文本查找

    grep, egrep, fgrep: 文本查找


    文件查找
    locate:
    非实时,模糊匹配,查找是根据全系统文件数据库进行的;
    # updatedb, 手动生成文件数据库
    速度快


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


    find:
    find DIRICTORY Cretiria ACTION
    匹配条件:
    -type
    f, d, c, b, l, s, p
    -atime [+|-]
    -amin

    -size [+|-] 11M
    10M<


    -user
    -uid
    -nouser
    -nogroup

    -name
    -iname
    -regex 

    组合条件:
    -a
    -o
    -not

    ( )

    ACTION
    -print
    -ls
    -ok
    -exec


    find 查找路径 查找标准 查找到以后的处理运作
    查找路径
    :默认为当前目录
    查找标准:默认为指定路径下的所有文件
    处理运作:默认为显示


    匹配标准:
    -name 'FILENAME':对文件名作精确匹配
    文件名通配:
    *:任意长度的任意字符
    ?
    []
    -iname 'FILENAME': 文件名匹配时不区分大小写
    -regex PATTERN:基于正则表达式进行文件名匹配

    -user USERNAME: 根据属主查找
    -group GROUPNAME: 根据属组查找

    -uid UID: 根据UID查找
    -gid GID: 根据GID查找

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

    -type 
    f: 普通文件
    d
    c
    b
    l
    p
    s

    -size [+|-]
    #k
    #M
    #G

    组合条件:
    -a
    -o
    -not 

    /tmp目录,不是目录,并且还不能套接字类型的文件
    /tmp/test目录下,属主不是user1,也不是user2的文件;


    -mtime
    -ctime
    -atime
    [+|-]#
    -mmin
    -cmin
    -amin
    [+|-]#

    -perm MODE:精确匹配
    /MODE: 任意一位匹配即满足条件
    -MODE: 文件权限能完全包含此MODE时才符合条件

    -644
    644: rw-r--r--
    755: rwxr-xr-x
    750: rwxr-x---
    find ./ -perl -001




    运作:
    -print: 显示
    -ls:类似ls -l的形式显示每一个文件的详细
    -ok COMMAND {} ; 每一次操作都需要用户确认
    -exec COMMAND {} ;

    例子:

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


    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 {} ; 


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


    6、查找/etc目录下所有用户都没有写权限的文件,显示出其详细信息;
    find /etc -not -perm /222 -ls
    起风了,努力生存
  • 相关阅读:
    Title
    Title
    Title
    Title
    Title
    Title
    Title
    Title
    Title
    git 的使用
  • 原文地址:https://www.cnblogs.com/StivenYang/p/8441307.html
Copyright © 2011-2022 走看看