您好,登錄后才能下訂單哦!
which命令的作用是,在PATH變量指定的路徑中,搜索某個系統命令的位置,并且返回第一個搜索結果。也就是說,使用which命令,就可以看到某個系統命令是否存在,以及執行的到底是哪一個位置的命令。
語法: which [-a] command
-a: 將所有由path目錄中可以找出的命令均列出
which ifconfig
which which #找出which的文件名
whereis命令只能用于程序名的搜索,如果省略參數,則返回所有信息。
語法:whereis [-bmsu] 文件或目錄名
-l : 可以列出whereis 會去查詢的幾個主要目錄
-b: 只找二進制格式文件
-m: 只找在說明文件manual路徑下文件
-s: 只找source源文件
-u: 找不在上面三個項目中的其他特殊文件
whereis ifconfig #找ifconfig文件名
whereis -m passwd #只有在man里面文件顯示出來
find,用于在文件樹中查找文件并作相應的處理
-name:按照文件名查找文件
-perm:按照文件權限查找文件
-user:按照文件屬主來查找文件
-size:按照指定的文件大小查找文件【+n:大于,-n:小于,n:等于】
-group:按照文件所屬的組來查找文件
-mtime<-n><+n>:按照文件更改時間來查找文件,-n表示n天之內,+n表示n天以前
-newer file1 file2:查找更改時間在file1和file2之間的文件
find / -name xitai #查找全系統名為xitai的文件
find -mtime -2 #查找48小時修改過的文件
find /usr/local -size +100M #查找大于100M的文件
find -type d | sort #查找當前所有目標目錄并排序
find /usr/local/apache-tomcat-admin/ -perm 755 #查找指定目錄下權限為755的文件
find /etc/ -newer /etc/passwd #查找/etc/比/etc/passwd要新的文件
locate命令其實是"find -name"的另一種寫法,但是要比后者快得多,原因在于它不搜索具體目錄,而是搜索一個數據庫(/var/lib/locatedb),這個數據庫中含有本地所有文件信息。Linux系統自動創建這個數據庫,并且每天自動更新一次,所以使用locate命令查不到最新變動過的文件。為了避免這種情況,可以在使用locate之前,先使用updatedb命令,手動更新數據庫。
updatedb:第一次運行前,創建locate數據庫
參數:
-i: 忽略大小寫
-c:不輸出文件名,僅計算文件數量
-l :僅輸出幾行
-r: 后面可接正則表達式
-S: 輸出數據庫文件相關信息
locate -l 5 passwd
如果報錯:
先安裝
yum -y install mlocate
又報錯:
初始化
updatedb
locate -l 5 passwd
locate -S
type命令其實不能算查找命令,它是用來區分某個命令到底是由shell自帶的,還是由shell外部的獨立二進制文件提供的。如果一個命令是外部命令,那么使用-p參數,會顯示該命令的路徑,相當于which命令。
type -p ifconfig
用于過濾/搜索指定字符串。可以使用正則表達式,能配合多種命令使用。
用法:grep 【選項】 查找內容 源文件
-A:顯示符合的行及之后的內容
-B:顯示符合的行及之前的內容
-C:顯示符合的行及前后的內容
-c:計算符合的行數目
-n:顯示匹配行和行號
-i:忽略大小寫
^:'^grep'表示匹配所有以grep開頭的行
'表示匹配所有以grep結尾的行
.:'gr.p'表示匹配'gr'后面接任意字符然后是'p'
:'grep'表示匹配一個或多個空格后緊跟grep的行
[]:[Gg]rep表示匹配Grep與grep
[^]:[^A-FH-Z]rep表示匹配不以A-F、H-Z開頭并緊跟rep的行
grep -n 'cc' aa.txt
grep -in 'DD' aa.txt
grep -vn 'cc' aa.txt
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。