linux下的文件查找命令

文件查找:按照文件名或文件屬性來搜索文件;

一)locate

    模糊查找:
        基於專用的數據庫進行查找,數據庫應該事先建立,而且按期更新;
        可使用updatedb命令手動更新locate數據庫;
        查找速度很是快,查找精確到很是有限;node


=============================================================
二)find

    精確查找:
        查找精度高,速度略慢;
        在指定的位置進行文件名或文件屬性的遍歷掃描;強烈不建議對根目錄進行find操做;
        實時查找;
        使用find命令只能搜索當前用戶具備讀取和執行權限的目錄;

    find命令:
        find - search for files in a directory hierarchy
        find [OPTIONS...] [查找路徑] [查找條件] [處理動做]
            查找路徑:默認爲當前工做目錄,能夠指定具體的目錄路徑;
            查找條件:進行本次搜索的標準,能夠是文件名、文件大小、文件類型、文件權限等等;默認是指定目錄中的全部文件;
            處理動做:對於符合條件的文件進行某個處理操做;默認將查找結果輸出到顯示器;

        根據文件名查找:
            -name 文件名稱,支持使用Globbing,(*, ?, [], [^])
            -iname 文件名稱,忽略字母大小寫,支持使用Globbing,(*, ?, [], [^])

        根據文件的inode編號查找:
            -inum inode編號:經過給定的inode編號查找對應的文件名及路徑;
            -samefile name:經過給定的文件名查找對應的inode編號,進而肯定全部具備該inode編號的文件名及路徑;
            -links n:查找連接數爲n的全部文件;

        根據正則表達式查找:
            -regex pattern:以pattern匹配整個文件路徑字符串,而不單單是給定文件的名稱;

        根據文件的屬主和屬組進行查找:
            -user uname:根據屬主爲指定用戶的用戶名進行查找
            -uid UID:根據屬主爲某個UID進行查找
            -group gname:
            -gid GID:

            -nogroup:在文件的屬組上沒有組對應的組名;
            -nouser:在文件的屬主上沒有用戶對應的用戶名;

        根據文件的類型查找:
            -type 文件類型:
                b:塊設備
                c:字符設備
                d:目錄文件
                f:普通文件
                l:符號連接文件
                p:管道文件
                s:套接字文件
            -xtype 文件類型:符號連接文件的匹配須要配合其餘的選項;

        根據時間戳進行查找:
            以天爲單位:
                -atime [+|-]n:根據訪問時間查找
                -ctime [+|-]n:根據改變時間查找
                -mtime [+|-]n:根據修改時間查找
                    n:[n,n+1)
                    +n:[n+1,+∞)
                    -n:[now,n)
            以分鐘爲單位:
                -amin [+|-]n
                -cmin [+|-]n
                -mmin [+|-]n

            例子:
                5-28-11-18
                    -mtime -3
                5-25-11-18
                    -mtime 3
                5-24-11-18
                    -mtime +3

        根據文件的大小進行查找:
            -size [+|-]n[cwbkMG]
                n:(n-1,n]
                -n:[0,n-1]
                +n:(n,+∞)

            例子:
                find -size +2k
                    當前目錄下全部大於2KB的文件;
                find -size 2k
                    當前目錄下全部1KB-2KB之間的文件;
                find -size -2k
                    當前目錄下全部小於1KB的文件;

        組合條件:
            -a:邏輯與,默承認以省略;
            -o:邏輯或
            -not, !:邏輯非

            邏輯組合條件遵循德摩根定律:
                非(A 與 B) == 非A 或 非B
                非(A 或 B) == 非A 與 非B

        根據權限查找:
            -perm [/|-]mode
                mode:精確匹配指定的權限
                /mode:隱含了邏輯或的關係,任何一個權限位的權限中只要能有一個權限匹配,便可知足條件;
                -mode:隱含了邏輯與的關係,每個權限位的權限中都必須同時包含指定權限位,才能知足條件;

            全部都有 取反 任意一個沒有
                ! ( a與b與c ) = !a 或 !b 或 !c
            全部都沒有 取反 任意一個有
                !    ( !a與!b與!c ) = a 或 b 或 c

    處理動做:
        -print:輸出到顯示屏幕,默認的動做;
        -ls:對與查找到的結果執行ls -li命令顯示;    
        -exec COMMAND {} \;:
        -ok COMMAND {} \;:
            對於查找到的結果執行COMMAND命令;
            區別:
                -exec是非交互式的;
                -ok是交互式的;
            {}:佔位符,用來引用被find命令查找到的全部的文件的路徑信息;

        -exec和-ok的取代執行操做:
            chmod a-r $(find -perm -444 -type f)
            find -perm -444 -type f | xargs chmod a-r

        注意:管道輸送的是純字符串信息,因此若是管道以後的命令不是處理字符串的命令,須要使用xargs命令將其轉換成可以被後面命令處理的參數;
正則表達式

=============================================================
舉幾個栗子:數據庫


查當前目錄下的全部普通文件
# find . -type f -exec ls -l {} \;
-rw-r–r–    1 root      root         34928 2003-02-25   ./conf/httpd.conf
-rw-r–r–    1 root      root         12959 2003-02-25   ./conf/magic
-rw-r–r–    1 root      root          180 2003-02-25   ./conf.d/README
查當前目錄下的全部普通文件,並在- e x e c選項中使用ls -l命令將它們列出

=================================================
在/ logs目錄中查找更改時間在5日之前的文件並刪除它們:
$ find logs -type f -mtime +5 -exec   -ok   rm {} \;

=================================================
查詢當天修改過的文件
]# find   ./   -mtime   -1   -type f   -exec   ls -l   {} \;


=================================================
查詢並交給awk去處理
]# who   |   awk   ’{print $1"\t"$2}’
cnscn    pts/0

=================================================
awk—grep—sed

]# df   -k |   awk ‘{print $1}’ |   grep   -v   ’none’ |   sed   s"/\/dev\///g"
文件系統
sda2
sda1
]# df   -k |   awk ‘{print $1}’ |   grep   -v   ’none’
文件系統
/dev/sda2
/dev/sda1
1)在/tmp中查找全部的*.h,並在這些文件中查找「SYSCALL_VECTOR",最後打印出全部包含"SYSCALL_VECTOR"的文件名

A) find   /tmp   -name   "*.h"   | xargs   -n50   grep SYSCALL_VECTOR
B) grep   SYSCALL_VECTOR   /tmp/*.h | cut    -d’:'   -f1| uniq > filename
C) find   /tmp   -name "*.h"   -exec grep "SYSCALL_VECTOR"   {}   \; -print

2)find / -name filename -exec rm -rf {} \;
    find / -name filename -ok rm -rf {} \;

3)好比要查找磁盤中大於3M的文件:
find . -size +3000k -exec ls -ld {} ;






ide

相關文章
相關標籤/搜索