linux grep和find命令
grep
功能說明:查找文件裏符合條件的字符串。
語 法:grep [-abcEFGhHilLnqrsvVwxy][-A<顯示列數>][-B<顯示列數>][-C<顯示列數>][-d<進行動作>][-e<範本樣式>][-f<範本文件>][--help][範本樣式][文件或目錄...]
補充說明:grep 指令用於查找內容包含指定的範本樣式的文件,如果發現某文件的內容符合所指定的範本樣式,預設grep指令會把含有範本樣式的那一列顯示出來。若不指定任何文件名稱,或是所給予的文件名為“-”,則grep指令會從標準輸入設備讀取數據。
參 數:
-a或--text 不要忽略二進製的數據。
-A<顯示列數>或--after-context=<顯示列數> 除了顯示符合範本樣式的那一列之外,並顯示該列之後的內容。
-b或--byte-offset 在顯示符合範本樣式的那一列之前,標示出該列第一個字符的位編號。
-B<顯示列數>或--before-context=<顯示列數> 除了顯示符合範本樣式的那一列之外,並顯示該列之前的內容。
-c或--count 計算符合範本樣式的列數。
-C<顯示列數>或--context=<顯示列數>或-<顯示列數> 除了顯示符合範本樣式的那一列之外,並顯示該列之前後的內容。
-d<進行動作>或--directories=<進行動作> 當指定要查找的是目錄而非文件時,必須使用這項參數,否則grep指令將回報信息並停止動作。
-e<範本樣式>或--regexp=<範本樣式> 指定字符串做為查找文件內容的範本樣式。
-E或--extended-regexp 將範本樣式為延伸的普通表示法來使用。
-f<範本文件>或--file=<範本文件> 指定範本文件,其內容含有一個或多個範本樣式,讓grep查找符合範本條件的文件內容,格式為每列一個範本樣式。
-F或--fixed-regexp 將範本樣式視為固定字符串的列表。
-G或--basic-regexp 將範本樣式視為普通的表示法來使用。
-h或--no-filename 在顯示符合範本樣式的那一列之前,不標示該列所屬的文件名稱。
-H或--with-filename 在顯示符合範本樣式的那一列之前,表示該列所屬的文件名稱。
-i或--ignore-case 忽略字符大小寫的差別。
-l或--file-with-matches 列出文件內容符合指定的範本樣式的文件名稱。
-L或--files-without-match 列出文件內容不符合指定的範本樣式的文件名稱。
-n或--line-number 在顯示符合範本樣式的那一列之前,標示出該列的列數編號。
-q或--quiet或--silent 不顯示任何信息。
-r或--recursive 此參數的效果和指定“-d recurse”參數相同。
-s或--no-messages 不顯示錯誤信息。
-v或--revert-match 反轉查找。
-V或--version 顯示版本信息。
-w或--word-regexp 隻顯示全字符合的列。
-x或--line-regexp 隻顯示全列符合的列。
-y 此參數的效果和指定“-i”參數相同。
--help 在線幫助。
linux grep命令的使用
用grep命令 搜索文本文件 來自www.linuxso.com
如果您要在幾個文本文件中查找一字符串,可以使用‘grep’命令。‘grep’在文本中搜索指定的字符串。
假設您正在‘/usr/src/linux/Documentation’目錄下搜索帶字符串‘magic’的文件:
$ grep magic /usr/src/linux/Documentation/*
sysrq.txt:* How do I enable the magic SysRQ key?
sysrq.txt:* How do I use the magic SysRQ key?
其中文件‘sysrp.txt’包含該字符串,討論的是 SysRQ 的功能。
默認情況下,‘grep’隻搜索當前目錄。如果此目錄下有許多子目錄,‘grep’會以如下形式列出:
grep: sound: Is a directory
這可能會使‘grep’的輸出難於閱讀。這裏有兩種解決的辦法:
明確要求搜索子目錄:grep -r
或忽略子目錄:grep -d skip
當然,如果預料到有許多輸出,您可以通過 管道 將其轉到‘less’上閱讀
$ grep magic /usr/src/linux/Documentation/* | less
這樣,您就可以更方便地閱讀。
有一點要注意,您必需提供一個文件過濾方式(搜索全部文件的話用 *)。如果您忘了,‘grep’會一直等著,直到該程序被中斷。如果您遇到了這樣的情況,按 <CTRL c> ,然後再試。
下麵是一些有意思的命令行參數:
grep -i pattern files :不區分大小寫地搜索。默認情況區分大小寫,
grep -l pattern files :隻列出匹配的文件名,
grep -L pattern files :列出不匹配的文件名,
grep -w pattern files :隻匹配整個單詞,而不是字符串的一部分(如匹配‘magic’,而不是‘magical’),
grep -C number pattern files :匹配的上下文分別顯示[number]行,
grep pattern1 | pattern2 files :顯示匹配 pattern1 或 pattern2 的行,
grep pattern1 files | grep pattern2 :顯示既匹配 pattern1 又匹配 pattern2 的行。
這裏還有些用於搜索的特殊符號:
< 和 > 分別標注單詞的開始與結尾。
例如:
grep man * 會匹配 ‘Batman’、‘manic’、‘man’等,
grep \'<man\' * 匹配‘manic’和‘man’,但不是‘Batman’,
grep \'<man>\' 隻匹配‘man’,而不是‘Batman’或‘manic’等其他的字符串。
\'^\':指匹配的字符串在行首,
\'$\':指匹配的字符串在行尾,
如果您不習慣命令行參數,可以試試圖形界麵的‘grep’,如 reXgrep 。這個軟件提供 AND、OR、NOT 等語法,還有漂亮的按鈕 :-) 。如果您隻是需要更清楚的輸出,不妨試試 fungrep 。
.grep 搜索字符串
命令格式:
grep string filename
尋找字串的方法很多,比如說我想找所有以M開頭的行.此時必須引進pattern的觀
念.以下是一些簡單的□例,以及說明:
^M 以M開頭的行,^表示開始的意思
M$ 以M結尾的行,$表示結束的意思
^[0-9] 以數字開始的行,[]內可列舉字母
^[124ab] 以1,2,4,a,或b開頭的行
^b.503 句點表示任一字母
* 星號表示0個以上的字母(可以沒有)
+ 加號表示1個以上的字母
. 斜線可以去掉特殊意義
<eg> cat passwd | grep ^b 列出大學部有申請帳號者名單
cat passwd | grep ^s 列出交換學生申請帳號者名單
cat passwd | grep \'^b.503\' 列出電機係各年級...
grep \'^.\' myfile.txt 列出所有以句點開頭的行
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1. grep簡介
grep (global search regular expression(RE) and print out the line,全麵搜索正則表達式並把行打印出來)是一種強大的文本搜索工具,它能使用正則表達式搜索文本,並把匹配的行打印出來。Unix的grep家族包 括grep、egrep和fgrep。egrep和fgrep的命令隻跟grep有很小不同。egrep是grep的擴展,支持更多的re元字符, fgrep就是fixed grep或fast grep,它們把所有的字母都看作單詞,也就是說,正則表達式中的元字符表示回其自身的字麵意義,不再特殊。linux使用GNU版本的grep。它功能 更強,可以通過-G、-E、-F命令行選項來使用egrep和fgrep的功能。
grep的工作方式是這樣的,它在一個或多個文件中搜索字符串模板。如果模板包括空格,則必須被引用,模板後的所有字符串被看作文件名。搜索的結果被送到屏幕,不影響原文件內容。
grep可用於shell腳本,因為grep通過返回一個狀態值來說明搜索的狀態,如果模板搜索成功,則返回0,如果搜索不成功,則返回1,如果搜索的文件不存在,則返回2。我們利用這些返回值就可進行一些自動化的文本處理工作。
2. grep正則表達式元字符集(基本集)
^
錨定行的開始 如:\'^grep\'匹配所有以grep開頭的行。
$
錨定行的結束 如:\'grep$\'匹配所有以grep結尾的行。
匹配一個非換行符的字符 如:\'gr.p\'匹配gr後接一個任意字符,然後是p。
*
匹配零個或多個先前字符 如:\'*grep\'匹配所有一個或多個空格後緊跟grep的行。 .*一起用代表任意字符。
[]
匹配一個指定範圍內的字符,如\'[Gg]rep\'匹配Grep和grep。
[^]
匹配一個不在指定範圍內的字符,如:\'[^A-FH-Z]rep\'匹配不包含A-R和T-Z的一個字母開頭,緊跟rep的行。
(..)
標記匹配字符,如\'(love)\',love被標記為1。
<
錨定單詞的開始,如:\'
>
錨定單詞的結束,如\'grep>\'匹配包含以grep結尾的單詞的行。
x{m}
重複字符x,m次,如:\'0{5}\'匹配包含5個o的行。
x{m,}
重複字符x,至少m次,如:\'o{5,}\'匹配至少有5個o的行。
x{m,n}
重複字符x,至少m次,不多於n次,如:\'o{5,10}\'匹配5--10個o的行。
w
匹配文字和數字字符,也就是[A-Za-z0-9],如:\'Gw*p\'匹配以G後跟零個或多個文字或數字字符,然後是p。
W
w的反置形式,匹配一個或多個非單詞字符,如點號句號等。
b
單詞鎖定符,如: \'bgrepb\'隻匹配grep。
3. 用於egrep和 grep -E的元字符擴展集
+
匹配一個或多個先前的字符。如:\'[a-z]+able\',匹配一個或多個小寫字母後跟able的串,如loveable,enable,disable等。
?
匹配零個或多個先前的字符。如:\'gr?p\'匹配gr後跟一個或沒有字符,然後是p的行。
a|b|c
匹配a或b或c。如:grep|sed匹配grep或sed
()
分組符號,如:love(able|rs)ov+匹配loveable或lovers,匹配一個或多個ov。
x{m},x{m,},x{m,n}
作用同x{m},x{m,},x{m,n}
4. POSIX字符類
為了在不同國家的字符編碼中保持一至,POSIX(The Portable Operating System Interface)增加了特殊的字符類,如[:alnum:]是A-Za-z0-9的另一個寫法。要把它們放到[]號內才能成為正則表達式,如[A- Za-z0-9]或[[:alnum:]]。在linux下的grep除fgrep外,都支持POSIX的字符類。
[:alnum:]
文字數字字符
[:alpha:]
文字字符
[:digit:]
數字字符
[:graph:]
非空字符(非空格、控製字符)
[:lower:]
小寫字符
[:cntrl:]
控製字符
[:print:]
非空字符(包括空格)
[:punct:]
標點符號
[:space:]
所有空白字符(新行,空格,製表符)
[:upper:]
大寫字符
[:xdigit:]
十六進製數字(0-9,a-f,A-F)
5. Grep命令選項
-?
同時顯示匹配行上下的?行,如:grep -2 pattern filename同時顯示匹配行的上下2行。
-b,--byte-offset
打印匹配行前麵打印該行所在的塊號碼。
-c,--count
隻打印匹配的行數,不顯示匹配的內容。
-f File,--file=File
從文件中提取模板。空文件中包含0個模板,所以什麼都不匹配。
-h,--no-filename
當搜索多個文件時,不顯示匹配文件名前綴。
-i,--ignore-case
忽略大小寫差別。
-q,--quiet
取消顯示,隻返回退出狀態。0則表示找到了匹配的行。
-l,--files-with-matches
打印匹配模板的文件清單。
-L,--files-without-match
打印不匹配模板的文件清單。
-n,--line-number
在匹配的行前麵打印行號。
-s,--silent
不顯示關於不存在或者無法讀取文件的錯誤信息。
-v,--revert-match
反檢索,隻顯示不匹配的行。
-w,--word-regexp
如果被<和>引用,就把表達式做為一個單詞搜索。
-V,--version
顯示軟件版本信息。
6. 實例
要用好grep這個工具,其實就是要寫好正則表達式,所以這裏不對grep的所有功能進行實例講解,隻列幾個例子,講解一個正則表達式的寫法。
$ ls -l | grep \'^a\'
通過管道過濾ls -l輸出的內容,隻顯示以a開頭的行。
$ grep \'test\' d*
顯示所有以d開頭的文件中包含test的行。
$ grep \'test\' aa bb cc
顯示在aa,bb,cc文件中匹配test的行。
$ grep \'[a-z]{5}\' aa
顯示所有包含每個字符串至少有5個連續小寫字符的字符串的行。
$ grep \'w(es)t.*1\' aa
如果west被匹配,則es就被存儲到內存中,並標記為1,然後搜索任意個字符(.*),這些字符後麵緊跟著另外一個es(1),找到就顯示該行。如果用egrep或grep -E,就不用""號進行轉義,直接寫成\'w(es)t.*1\'就可以了。
find
·find path -option [ -print ] [ -exec -ok command ] {} \;
find命令的參數;
pathname: find命令所查找的目錄路徑。例如用.來表示當前目錄,用/來表示係統根目錄。
-print: find命令將匹配的文件輸出到標準輸出。
-exec: find命令對匹配的文件執行該參數所給出的shell命令。相應命令的形式為'command' { } \;,注意{ }和\;之間的空格。
-ok: 和-exec的作用相同,隻不過以一種更為安全的模式來執行該參數所給出的shell命令,在執行每一個命令之前,都會給出提示,讓用戶來確定是否執行。
#-exec command {} \; —–將查到的文件執行command操作,{} 和 \;之間有空格
#-ok 和-exec相同,隻不過在操作前要詢用戶
====================================================
-name filename #查找名為filename的文件
-perm #按執行權限來查找
-user username #按文件屬主來查找
-group groupname #按組來查找
-mtime -n +n #按文件更改時間來查找文件,-n指n天以內,+n指n天以前
-atime -n +n #按文件訪問時間來查GIN: 0px">
-ctime -n +n #按文件創建時間來查找文件,-n指n天以內,+n指n天以前
-nouser #查無有效屬主的文件,即文件的屬主在/etc/passwd中不存
-newer f1 !f2 找文件,-n指n天以內,+n指n天以前
-ctime -n +n #按文件創建時間來查找文件,-n指n天以內,+n指n天以前
-nogroup #查無有效屬組的文件,即文件的屬組在/etc/groups中不存在
-nouser #查無有效屬主的文件,即文件的屬主在/etc/passwd中不存
-newer f1 !f2 #查更改時間比f1新但比f2舊的文件
-type b/d/c/p/l/f #查是塊設備、目錄、字符設備、管道、符號鏈接、普通文件
-size n[c] #查長度為n塊[或n字節]的文件
-depth #使查找在進入子目錄前先行查找完本目錄
-fstype #查更改時間比f1新但比f2舊的文件
-type b/d/c/p/l/f #查是塊設備、目錄、字符設備、管道、符號鏈接、普通文件
-size n[c] #查長度為n塊[或n字節]的文件
-depth #使查找在進入子目錄前先行查找完本目錄
-fstype #查位於某一類型文件係統中的文件,這些文件係統類型通常可 在/etc/fstab中找到
-mount #查文件時不跨越文件係統mount點
-follow #如果遇到符號鏈接文件,就跟蹤鏈接所指的文件
-cpio %; #查位於某一類型文件係統中的文件,這些文件係統類型通常可 在/etc/fstab中找到
-mount #查文件時不跨越文件係統mount點
-follow #如果遇到符號鏈接文件,就跟蹤鏈接所指的文件
-cpio #對匹配的文件使用cpio命令,將他們備份到磁帶設備中
-prune #忽略某個目錄
=====================================================
$find ~ -name "*.txt" -print #在$HOME中查.txt文件並顯示
$find . -name "*.txt" -print
$find . -name "[A-Z]*" -print #查以大寫字母開頭的文件
$find /etc -name "host*" -print #查以host開頭的文件
$find . -name "[a-z][a-z][0–9][0–9].txt" -print #查以兩個小寫字母和兩個數字開頭的txt文件
$find . -perm 755 -print
$find . -perm -007 -exec ls -l {} \; #查所有用戶都可讀寫執行的文件同-perm 777
$find . -type d -print
$find . ! -type d -print
$find . -type l -print
$find . -size +1000000c -print #查長度大於1Mb的文件
$find . -size 100c -print # 查長度為100c的文件
$find . -size +10 -print #查長度超過期作廢10塊的文件(1塊=512字節)
$cd /
$find etc home apps -depth -print | cpio -ivcdC65536 -o /dev/rmt0
$find /etc -name "passwd*" -exec grep "cnscn" {} \; #看是否存在cnscn用戶
$find . -name "yao*" | xargs file
$find . -name "yao*" | xargs echo "" > /tmp/core.log
$find . -name "yao*" | xargs chmod o-w
======================================================
find -name april* 在當前目錄下查找以april開始的文件
find -name april* fprint file 在當前目錄下查找以april開始的文件,並把結果輸出到file中
find -name ap* -o -name may* 查找以ap或may開頭的文件
find /mnt -name tom.txt -ftype vfat 在/mnt下查找名稱為tom.txt且文件係統類型為vfat的文件
find /mnt -name t.txt ! -ftype vfat 在/mnt下查找名稱為tom.txt且文件係統類型不為vfat的文件
find /tmp -name wa* -type l 在/tmp下查找名為wa開頭且類型為符號鏈接的文件
find /home -mtime -2 在/home下查最近兩天內改動過的文件
find /home -atime -1 查1天之內被存取過的文件
find /home -mmin +60 在/home下查60分鍾前改動過的文件
find /home -amin +30 查最近30分鍾前被存取過的文件
find /home -newer tmp.txt 在/home下查更新時間比tmp.txt近的文件或目錄
find /home -anewer tmp.txt 在/home下查存取時間比tmp.txt近的文件或目錄
find /home -used -2 列出文件或目錄被改動過之後,在2日內被存取過的文件或目錄
find /home -user cnscn 列出/home目錄內屬於用戶cnscn的文件或目錄
find /home -uid +501 列出/home目錄內用戶的識別碼大於501的文件或目錄
find /home -group cnscn 列出/home內組為cnscn的文件或目錄
find /home -gid 501 列出/home內組id為501的文件或目錄
find /home -nouser 列出/home內不屬於本地用戶的文件或目錄
find /home -nogroup 列出/home內不屬於本地組的文件或目錄
find /home -name tmp.txt -maxdepth 4 列出/home內的tmp.txt 查時深度最多為3層
find /home -name tmp.txt -mindepth 3 從第2層開始查
find /home -empty 查找大小為0的文件或空目錄
find /home -size +512k 查大於512k的文件
find /home -size -512k 查小於512k的文件
find /home -links +2 查硬連接數大於2的文件或目錄
find /home -perm 0700 查權限為700的文件或目錄
find /tmp -name tmp.txt -exec cat {} \;
find /tmp -name tmp.txt -ok rm {} \;
find / -amin -10 # 查找在係統中最後10分鍾訪問的文件
find / -atime -2 # 查找在係統中最後48小時訪問的文件
find / -empty # 查找在係統中為空的文件或者文件夾
find / -group cat # 查找在係統中屬於 groupcat的文件
find / -mmin -5 # 查找在係統中最後5分鍾裏修改過的文件
find / -mtime -1 #查找在係統中最後24小時裏修改過的文件
find / -nouser #查找在係統中屬於作廢用戶的文件
find / -user fred #查找在係統中屬於FRED這個用戶的文件
-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命令將它們列出
=================================================
在/ l o g s目錄中查找更改時間在5日以前的文件並刪除它們:
$ find logs -type f -mtime +5 -exec -ok rm {} \;
=================================================
查詢當天修改過的文件
[root@book class]# find ./ -mtime -1 -type f -exec ls -l {} \;
=================================================
查詢文件並詢問是否要顯示
[root@book class]# find ./ -mtime -1 -type f -ok ls -l {} \;
< ls … ./classDB.inc.php > ? y
-rw-r–r– 1 cnscn cnscn 13709 1月 12 12:22 ./classDB.inc.php
[root@book class]# find ./ -mtime -1 -type f -ok ls -l {} \;
< ls … ./classDB.inc.php > ? n
[root@book class]#
=================================================
查詢並交給awk去處理
[root@book class]# who | awk ’{print $1"\t"$2}’
cnscn pts/0
=================================================
awk—grep—sed
[root@book class]# df -k | awk ‘{print $1}’ | grep -v ’none’ | sed s"/\/dev\///g"
文件係統
sda2
sda1
[root@book class]# df -k | awk ‘{print $1}’ | grep -v ’none’
文件係統
/dev/sda2
/dev/sda1
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 {} ;
4)將find出來的東西拷到另一個地方
find *.c -exec cp ‘{}’ /tmp ‘;’
如果有特殊文件,可以用cpio,也可以用這樣的語法:
find dir -name filename -print | cpio -pdv newdir
6)查找2004-11-30 16:36:37時更改過的文件
# A=`find ./ -name "*php"` | ls -l –full-time $A 2>/dev/null | grep "2004-11-30 16:36:37"
Linux-all, Linux | No Comments »
find 實例
四月 18th, 2006
要在/usr/linux中查找所有的*.h,並在這些文件中查找“SYSCALL_VECTOR",最後打印出所有包含"SYSCALL_VECTOR"的文件名,有以下幾種方法實現
find /usr/linux -name "*.h" | xargs -n50 grep SYSCALL_VECTOR
grep SYSCALL_VECTOR /usr/linux/*.h | cut -d’:’ -f1 | uniq > filename
find /usr/linux -name "*.h" -exec grep "SYSCALL_VECTOR" {} \; -print
我用find / -name filename| rm -rf,不成功,請問為什麼不成功?
find / -name filename -exec rm -rf {} \;
find . -name filename |rm -rf試一下{} 表示你找出來的結果。
\; 則相當於“憲法”,沒什麼說頭,就是這麼規定的,在 -exec 後麵需要一個表示該命令終結的的符號。可以在 man find 中找到答案。
要讓rm識別find的結果,如下:
find / -name filename |xargs rm -rf
之所以find . -name filename |rm -rf不通過,是因為rm命令不接受從標準輸入傳過來的指令
查找含特定字符串的文件
例如查找當前目錄下含有"the string you want find…"字符串的文件:
$find . -type f -exec grep “the string you want find…” {} ; -print
從根目錄開始查tmpfile,一旦查到馬上刪除
find / -name "tmpfile" -exec rm {} \;
find 的perm問題
請問一下以下命令什麼意思?關鍵是那個數字前的-,其他都還知道
find -name ".*" -perm -007
我知道
find -name ".*" -perm 755
這個是用來查找權限位為755的隱藏文件
噢,對了還有,我上邊的命令都省略了find的pathname參數 find默認是查找當前工作目錄的嗎?
如果我用 -ok 替代 -exec, 那麼還需要加上 {} \; 嗎?
這個已經清楚,仍然需要,因為 -ok 隻是 -exec 的提示模式,它隻是多了一個確認操作的步驟,剛才沒有讀懂那幾句E文的意思 嗬嗬 不好意思
-007是指查找所有用戶都可讀、寫、執行的文件,要小心呀~~~
解釋解釋?
find -name ".*" -perm -007 和 find -name ".*" -perm 777 有區別嗎?
-007是怎麼來得呢?
不過有一個問題
我用 find . -perm -100 會列出當前目錄 . , 這是為什麼呢?
下麵引用由explover在 2002/10/01 06:15am 發表的內容:
-007是指查找所有用戶都可讀、寫、執行的文件,要小心呀~~~
-007是查找含其它用戶(不同組,非屬主)可讀,寫,執行的文件.並不一定要同組可讀寫,-是指最少權限為007.
下麵引用由一顆小白菜在 2002/10/01 10:16am 發表的內容:
OK了, 嗬嗬
不過有一個問題
我用 find . -perm -100 會列出當前目錄 . , 這是為什麼呢?
這種方法不會準確的找出目錄的. -100是指權限至少是屬主可運行.
在unix係統下,你可以擁有對目錄文件的執行權你才可以進入一個目錄.這便是目錄文件被列出的原因.
find . -perm -001 -print找到往往是目錄文件.
我的意思當然不是使用這種方法來找目錄,隻不過不明白其中的 -100 意義了
那以此類推,是不是 -010是指權限至少是owner同組可執行的嗎?也就是說其實這裏的010和-是分開的,-表示一個至少的意思,而且010才是真正用來描述權限位的?
這樣子就明白了 謝謝你噢
將find出來的東西拷到另一個地方?
find *.c -exec cp ‘{}’ /tmp ‘;’
如果有特殊文件,可以用cpio,也可以用這樣的語法:
find dir -name filename -print | cpio -pdv newdir
找出磁盤中某個大小範圍內的文件
比如要查找磁盤中大於3M的文件:
find . -size +3000k -exec ls -ld {} ;
如何用find查找某一天更改的文件?
可以使用這一行命令來實現:
A=`find ~ -print` | ls -l –full-time $A 2>/dev/null | grep "Jun 27" | grep 1998
使用find 命令查找某個時間段的shell怎麼寫。比如11點到12點的。thanks
創建一個腳本judgetime,內容如下:
ls -l $*|awk ‘{split($8,hour,":");if((hour[1]>23 || hour[1] < 1)&&hour[1]<24)print}’
到要查找的目錄下,運行
find ./ -name "*" -exec judgetime {} \;
注意時間格式為24小時製。
thank you ,如果我要精確到分鍾呢
touch -t 04241112 starttemp #精確到12分鍾
touch -t 04241220 endtemp #截止到12點20
find [dir] -newer starttemp -a ! -newer endtemp -exec ls -l {} \;
newer?
那昨天12:10文件如何呢?
每天執行的時候,用當天的日期和時間戳替換一下不就行了嗎?
我不知道他是不是把所有的11:00~12:00的都找出來,是不是隻執行一次還是每天都執行?
這種情況俺猜想是自己的東西放在哪忘了,隻記得當時是深夜了。
有道理!
不愧是斑竹!
不光知道怎麼解決問題,還知道在什麼情況下出現這類問題,佩服佩服!
問題又出現了。創建這個文件的時候。本來應該是時間的一欄現在寫上了2002,而不是12:00.
等到12:00過了吧!
刪除指定日期的文件
find ./ -name 文件名 -exec rm -f {} \;
例:刪除當前30天內沒用過的文件,用如下命令:
find / -atime +30 -exec rm -f {} \;
我自己試著寫了一小段SHELL,也用ll ,grep, rm 幾個命令,用起來還差強人意。
對過濾出來的文件名列表中用了一個FOR語句,再執行rm 。現在我想把這段SHELL 擴展一下讓它每天定時運行將 n 天前的文件刪掉,有沒有人能給我一些提示,謝謝!
還有個問題,對於前麵那位朋友提到的"find / -atime +30 -exec rm -f {} \;
"方法,我很早就試過幾次,不過好像都不太對,參數 -atime n 是查找n天前被訪問過的文件,我不明白的是這裏的時間參照點是什麼,以及這個n天是怎麼計算的。
問 題二、對於"ll |cut -f 1" 這個命令我是不是用錯了,我隻想取出 ll 中列出的文件名,但用cut -f 命令做不到 ,我隻好換用 ll |cut -c 59- 這種方式得到我要的文件名,but it’s a pool idear !我也試過用awk ,好像也不對,看看大家可不可以給我一些小小的提醒,TKS SO MUCH
問題三、如何改變 I結點 的日期格式 我現在的係統顯示的格式是:
-rw-r—– 1 msahz01 users 2253 2002年2月 2日 poheader.i
我想把這換成
-rw-rw-rw- 1 house users 2193 Apr 19 2001 hkdisp.p
如何才能做到這點?
awk 應該可以
ll | awk ‘{print $9}’
刪除多少天之前的文件
find /yourpath -mtime +31 -exec rm {} \;
find /yourpath -mtime +366 -exec rm {} \;
find中, -ctime, -mtime及其-atime有何區別
請問 -ctime 和 -mtime 有什麼關係 ?
如果父目錄的 ctime 改變, 那它下麵的文件的 ctime 就會自動都改了嗎 ?
-ctime 和 -mtime ,-atime 這些信息是存在哪兒呢 ?
我用 -mtime -1 找到了新建或改的文件.
但怎樣才能找到一天內 mv 來的文件呢( 它們的時間是原有的時間,早於一天 ) ?
用-newer選項啊。
你可以先touch一個你想要的時間的文件如下:
$ touch -t 08190800 test
$ ls -l test
-rw-r–r– 1 dba other 0 Aug 19 08:00 test
然後
$ find . -newer test -print
.
./.sh_history
$ ls -l .sh_history
-rw——- 1 dba other 154 Aug 20 17:39 .sh_history
用touch可以寫出你想要的任何時間的文件,然後用-newer ,! -newer選項即可成功。
1.ctime含inode信息修改的時間.mtime隻指文件內容建立或修改的時間.
2 不會.
3.這些信息應該是存在文件係統的超級塊裏.
我查了書 -ctime 是指 inode 的改變(或稱文件的狀態改變).
請問 inode 存了哪些信息 ?
做了些小測試,-mtime 改, -ctime 一定也改.
改文件名, -ctime 也會改.
誰能回答 i-node 存了哪些東西 ?
vi /usr/include/sys/inode.h
班主,我不能 access /usr/include/sys/inode.h .
摘書如下:
Directories contain directory entries. Each entry contains a file or subdirectory name and an index node reference number (i-node number). To increase speed and enhance use of disk space, the data in a file is stored at various locations in the computer’s memory.
The i-node contains the addresses used to locate all the scattered blocks of data associated with a file. The i-node also records other information about the file including time of modification and access, access modes, number of links, file owner, and file
type.
可我發現 -atime 改了, -ctime 還沒改. why ?
( 我先 cat 一個 ASCII 文件,再用 -atime -1 有它用 -ctime -1 居然沒有它.)
著豈不跟 inode 信息改變, ctime 就改矛盾嗎?
我不同意你貼出來的那段文章,正如我提到的那樣,atime,ctime,mtime是放到超級塊裏,在sco unix下是一種叫stat的結構.(stat_32),不同的係統文件係統可能不同.
sco 下inode的結構如下:
typedef struct inode
{
struct inode *i_forw; /* inode hash chain */
struct inode *i_back; /* ‘’ */
struct inode *av_forw; /* freelist chain */
struct inode *av_back; /* ‘’ */
int *i_fsptr; /* "typeless" pointer to fs dependent */
ino32_t i_number; /* i number, 1-to-1 with dev address */
ushort i_ftype; /* file type = IFDIR, IFREG, etc. */
short i_fstyp; /* File system type */
off_t i_size; /* size of file */
ushort i_uid; /* owner */
ushort i_gid; /* group of owner */
ushort i_flag;
ushort i_want; /* i_flag extension to avoid MP races */
ushort i_count; /* reference count */
short i_nlink; /* directory entries */
dev_t i_rdev; /* Raw device number */
#define i_namtype i_rdev /* i_ftype==IFNAM subtype */
dev_t i_dev; /* device where inode resides */
struct mount *i_mton;/* ptr to mount table entry that */
/* this directory is mounted on */
struct region *i_rp; /* ptr to shared region if any */
struct stdata *i_sp; /* ptr to associated stream */
struct iisem *isem; /* ptr to XENIX semaphores */
struct iisd *isd; /* ptr to XENIX shared data */
} i_un;
#define i_mnton i_un.i_mton /* i_ftype==IFDIR IMOUNT */
#define i_rptr i_un.i_rp /* i_ftype==IFREG || i_ftype==IFBLK */
#define i_sptr i_un.i_sp /* i_ftype==IFCHR || i_ftype==IFIFO */
#define i_sem i_un.isem /* i_ftype==IFNAM && i_namtype==IFSEM */
#define i_sd i_un.isd /* i_ftype==IFNAM && i_namtype==IFSHD */
struct fstypsw *i_fstypp; /* ptr to file system switch FSPTR */
long *i_filocks; /* pointer to filock (structure) list */
unsigned long i_mappages; /* number of pages currently cached */
unsigned long i_vcode; /* read-ahead block save (NFS) */
short i_wcnt; /* write open count or ITEXT count */
struct lockb i_cilock; /* tas to synchronize i_flag changes */
ushort i_rdlocks; /* count of non-exclusive lockers */
} inode_t;
所以,訪問一個文件不能改變inode信息.
使用chown, chgrp, chmod命令可以很好的比較mtime和ctime
chown改變一個文件的屬主,用ctime可以找到,用mtime便找不到.
試試看.
多謝斑竹! 我是在 Solaris 上麵試的.我是對 -ctime 不明白.
試的結果如下:
修改文件,-mtime 改了, -ctime 也會改.
訪問文件,-atime 改了, -ctime 沒變.
chown, chgrp, chmod,mv, 都會使 -ctime 改變,但不影響 -atime 和 -mtime.
touch 可以改 -mtime and/or -atime,但 touch -a 隻改訪問時間時,-ctime也改了.
touch -m 改修改時間時,-ctime當然也改了.
好象還有別的很多東西可以令 -ctime 改變, 搞不清楚.
有什麼方法可以顯示 -mtime,atime,ctime 嗎?
可以用 -ctime 來實現對目錄的增量文件進行備份或 transfer 嗎 ?
多謝!
沒有什麼工具顯示,(可能是俺不知道)
把下麵程序裏的st_mtime換成st_ctime,或st_atime便可以得到你要的了.
#include
int
main (int argc, char **argv)
{
struct stat buf;
char date[80];
char fname[80];
printf("Enter filename (with full path) to check mtime : ");
scanf("%s",fname);
stat(fname, &buf);
printf ("mtime (in sec) of %s = %ld\n", fname, buf.st_mtime);
strcpy(date, ctime((time_t *)&(buf.st_mtime)));
printf ("mtime (in date) of %s = %s\n", fname, date);
}
至於文件備份,有什麼不可以的麼?
mtime ls -l 最近修改文件內容的時間
atime ls -lu 最近訪問文件的時間
ctime ls -li 最近文件有所改變的狀態 ,如文件修改,屬性\屬主 改變 ,節點 ,鏈接變化等 ,應該是不拘泥隻是時間前後的改變
俺看了ls的幫助,以為隻是按ctime或atime排序,顯示的時間還是mtime.
仔細比較了一下,ayhan說的是對的.謝謝ayhan.
多謝 ahyan 提示 ! 我在 Solaris 上試過如下:
mtime 用 ls -l 看到
atime 用 ls -lu 看到
ctime 用 ls -lc 看到. (ls -li 隻有 inode number)
摘書如下:
-c Uses time of last modification of the i-node (file
created, mode changed, and so forth) for sorting (-t)
or printing (-l or -n).
-u Uses time of last access instead of last modification
for sorting (with the -t option) or printing (with the
-l option).
-i For each file, prints the i-node number in the first
column of the report.
最後更新:2017-04-03 18:51:56