linux--文件查找
let I=$[$I+1]
SUM=$[$SUM+$I]
let SUM+=$I
let I+=1 相當於let I++
-=
let I-=1 相當於 let I--
grep, egrep, fgrep: 文本查找
文件查找:
locate :
非實時, 模糊匹配, 查找是根據全系統文件數據庫進行的;
# updatedb, 手動生成文件數據庫
速度快
find :
實時
精確
支持眾多查找標準
遍歷指定目錄中的所有文件完成查找,速度慢;
find 查找路徑 查找標準 查找到以後的處理動作
查找路勁 : 默認是當前目錄
查找標準 : 默認為指定路徑下的所有文件
處理動作 : 默認為顯示到屏幕
匹配標準 :
-name ‘FILENAME‘ : 對文件名作精確匹配
文件名通配:
* : 任意長度的任意字符
?
[]
-iname ‘FILENAME‘ : 文件名匹配不區分大小寫
-regex PATTERN : 基於正則表達式進行文件名匹配
-user USERNAME : 根據屬主查找
-group GROUPNAME : 根據屬組查找
-uid UID : 根據UID查找
-gid GID : 根據GID查找
-nouser : 查找沒有屬主的文件
-gid GID : 查找沒有屬組的文件
-type
f: 普通文件
d ; 目錄
c :字符設備
b : 塊設備
l : 鏈接文件
p : 管道設備
s : 套接字
# find /tmp -type s
-size [+|-]
#k
#M
#G
組合條件 :
-a 與
-o 或
-not 非
/tmp目錄, 不是目錄, 並且還不能套接字類型的文件
find /tmp -not -type d -a -not type s
或者
find /tmp -not \(-type d -o -type s\)
/tmp/test目錄下,屬主不是user1, 也不是user2的文件;
find /tmp/test -not -user user1 -a -not -user user2
或者
find /tmp/test -not \(-user user1 -o -user user2\)
-mtime
-ctime
-atime
[+|-]#
-mmin
-cmin
-amin
[+|-]#
-perm MODE : 精確匹配
/MODE : 任意一位匹配即滿足條件
-MODE : 文件權限能完全包含此MODE時才符合條件
動作 :
-print : 顯示
-ls : 類似 ls -l 的形式顯示每一個文件的詳細
-ok COMMAND {} \; 每一次操作都需要用戶確認
-exec COMMAND {} \;
# find /etc -perm -006 -exec chmod o-w {} \;
練習:
1、查找/var目錄下屬主為root並且屬組為mail的所有文件;
# find /var -user root -a -group mail
2、查找/usr目錄下不屬於root,bin,或student的文件;
# find /usr -not -user root -a -not -user bin -a -not -user student
3、查找/etc目錄下最近一周內內容修改過且不屬於root及student用戶的文件;
# find /etc -mtime -7 -a -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
# find /etc -size +1M -exec echo {} >> /tmp/etc.largefiles \;
# find /etc -size +1M -xargs >> /tmp/etc.largefiles
6、查找/etc目錄下所有用戶都沒有寫權限的文件,顯示出其詳細信息;
# find /etc -not -perm /222 -ls
linux--文件查找