linux常用命令彙總?1、ls命令就是 list 的縮寫,通過 ls 命令不僅可以查看 linux 文件夾包含的文件,而且可以查看文件權限(包括目錄、文件夾、文件權限)查看目錄信息等等,現在小編就來說說關于linux常用命令彙總?下面内容希望能幫助到你,我們來一起看看吧!
1、ls命令
就是 list 的縮寫,通過 ls 命令不僅可以查看 linux 文件夾包含的文件,而且可以查看文件權限(包括目錄、文件夾、文件權限)查看目錄信息等等。
常用參數搭配:
ls -a 列出目錄所有文件,包含以.開始的隐藏文件
ls -A 列出除.及..的其它文件
ls -r 反序排列
ls -t 以文件修改時間排序
ls -S 以文件大小排序
ls -h 以易讀大小顯示
ls -l 除了文件名之外,還将文件的權限、所有者、文件大小等信息詳細列出來
實例:
(1) 按易讀方式按時間反序排序,并顯示文件詳細信息
ls -lhrt
(2) 按大小反序顯示文件詳細信息
ls -lrS
(3)列出當前目錄中所有以"t"開頭的目錄的詳細内容
ls -l t*
(4) 列出文件絕對路徑(不包含隐藏文件)
ls | sed "s:^:`pwd`/:"
(5) 列出文件絕對路徑(包含隐藏文件)
find $pwd -maxdepth 1 | xargs ls -ld
2、cd 命令
cd(changeDirectory) 命令語法:
cd [目錄名]
說明:切換當前目錄至 dirName。
實例:
(1)進入要目錄
cd /
(2)進入 "home" 目錄
cd ~
(3)進入上一次工作路徑
cd -
(4)把上個命令的參數作為cd參數使用。
cd !$
3、pwd 命令
pwd 命令用于查看當前工作目錄路徑。
實例:
(1)查看當前路徑
pwd
(2)查看軟鍊接的實際路徑
pwd -P
4、mkdir 命令
mkdir 命令用于創建文件夾。
可用選項:
實例:
(1)當前工作目錄下創建名為 t的文件夾
mkdir t
(2)在 tmp 目錄下創建路徑為 test/t1/t 的目錄,若不存在,則創建:
mkdir -p /tmp/test/t1/t
5、rm 命令
删除一個目錄中的一個或多個文件或目錄,如果沒有使用 -r 選項,則 rm 不會删除目錄。如果使用 rm 來删除文件,通常仍可以将該文件恢複原狀。
rm [選項] 文件…
實例:
(1)删除任何 .log 文件,删除前逐一詢問确認:
rm -i *.log
(2)删除 test 子目錄及子目錄中所有檔案删除,并且不用一一确認:
rm -rf test
(3)删除以 -f 開頭的文件
rm -- -f*
6、rmdir 命令
從一個目錄中删除一個或多個子目錄項,删除某目錄時也必須具有對其父目錄的寫權限。
注意:不能删除非空目錄
實例:
(1)當 parent 子目錄被删除後使它也成為空目錄的話,則順便一并删除:
rmdir -p parent/child/child11
7、mv 命令
移動文件或修改文件名,根據第二參數類型(如目錄,則移動文件;如為文件則重命令該文件)。
當第二個參數為目錄時,第一個參數可以是多個以空格分隔的文件或目錄,然後移動第一個參數指定的多個文件到第二個參數指定的目錄中。
實例:
(1)将文件 test.log 重命名為 test1.txt
mv test.log test1.txt
(2)将文件 log1.txt,log2.txt,log3.txt 移動到根的 test3 目錄中
mv llog1.txt log2.txt log3.txt /test3
(3)将文件 file1 改名為 file2,如果 file2 已經存在,則詢問是否覆蓋
mv -i log1.txt log2.txt
(4)移動當前文件夾下的所有文件到上一級目錄
mv * ../
8、cp 命令
将源文件複制至目标文件,或将多個源文件複制至目标目錄。
注意:命令行複制,如果目标文件已經存在會提示是否覆蓋,而在 shell 腳本中,如果不加 -i 參數,則不會提示,而是直接覆蓋!
-i 提示
-r 複制目錄及目錄内所有項目
-a 複制的文件與原文件時間一樣
實例:
(1)複制 a.txt 到 test 目錄下,保持原文件時間,如果原文件存在提示是否覆蓋。
cp -ai a.txt test
(2)為 a.txt 建立一個鍊接(快捷方式)
cp -s a.txt link_a.txt
9、cat 命令
cat 主要有三大功能:
1.一次顯示整個文件:
cat filename
2.從鍵盤創建一個文件:
cat > filename
隻能創建新文件,不能編輯已有文件。
3.将幾個文件合并為一個文件:
cat file1 file2 > file
實例:
(1)把 log2012.log 的文件内容加上行号後輸入 log2013.log 這個文件裡
cat -n log2012.log log2013.log
(2)把 log2012.log 和 log2013.log 的文件内容加上行号(空白行不加)之後将内容附加到 log.log 裡
cat -b log2012.log log2013.log log.log
(3)使用 here doc 生成新文件
cat >log.txt <<EOF
>Hello
>World
>PWD=$(pwd)
>EOF
ls -l log.txt
cat log.txt
Hello
World
PWD=/opt/soft/test
(4)反向列示
tac log.txt
PWD=/opt/soft/test
World
Hello
10、more 命令
功能類似于 cat, more 會以一頁一頁的顯示方便使用者逐頁閱讀,而最基本的指令就是按空白鍵(space)就往下一頁顯示,按 b 鍵就會往回(back)一頁顯示。
命令參數:
n 從笫 n 行開始顯示
-n 定義屏幕大小為n行
/pattern 在每個檔案顯示前搜尋該字串(pattern),然後從該字串前兩行之後開始顯示
-c 從頂部清屏,然後顯示
-d 提示“Press space to continue,’q’ to quit(按空格鍵繼續,按q鍵退出)”,禁用響鈴功能
-l 忽略Ctrl l(換頁)字符
-p 通過清除窗口而不是滾屏來對文件進行換頁,與-c選項相似
-s 把連續的多個空行顯示為一行
-u 把文件内容中的下畫線去掉
常用操作命令:
Enter 向下 n 行,需要定義。默認為 1 行
Ctrl F 向下滾動一屏
空格鍵 向下滾動一屏
Ctrl B 返回上一屏
= 輸出當前行的行号
:f 輸出文件名和當前行的行号
V 調用vi編輯器
!命令 調用Shell,并執行命令
q 退出more
實例:
(1)顯示文件中從第3行起的内容
more 3 text.txt
(2)在所列出文件目錄詳細信息,借助管道使每次顯示 5 行
ls -l | more -5
按空格顯示下 5 行。
11、less 命令
less 與 more 類似,但使用 less 可以随意浏覽文件,而 more 僅能向前移動,卻不能向後移動,而且 less 在查看之前不會加載整個文件。
常用命令參數:
-i 忽略搜索時的大小寫
-N 顯示每行的行号
-o <文件名> 将less 輸出的内容在指定文件中保存起來
-s 顯示連續空行為一行
/字符串:向下搜索“字符串”的功能
?字符串:向上搜索“字符串”的功能
n:重複前一個搜索(與 / 或 ? 有關)
N:反向重複前一個搜索(與 / 或 ? 有關)
-x <數字> 将“tab”鍵顯示為規定的數字空格
b 向後翻一頁
d 向後翻半頁
h 顯示幫助界面
Q 退出less 命令
u 向前滾動半頁
y 向前滾動一行
空格鍵 滾動一行
回車鍵 滾動一頁
[pagedown]: 向下翻動一頁
[pageup]: 向上翻動一頁
實例:
(1)ps 查看進程信息并通過 less 分頁顯示
ps -aux | less -N
(2)查看多個文件
less 1.log 2.log
可以使用 n 查看下一個,使用 p 查看前一個。
12、head 命令
head 用來顯示檔案的開頭至标準輸出中,默認 head 命令打印其相應文件的開頭 10 行。
常用參數:
-n<行數> 顯示的行數(行數為複數表示從最後向前數)
實例:
(1)顯示 1.log 文件中前 20 行
head 1.log -n 20
(2)顯示 1.log 文件前 20 字節
head -c 20 log2014.log
(3)顯示 t.log最後 10 行
head -n -10 t.log
13、tail 命令
用于顯示指定文件末尾内容,不指定文件時,作為輸入信息進行處理。常用查看日志文件。
常用參數:
-f 循環讀取(常用于查看遞增的日志文件)
-n<行數> 顯示行數(從後向前)
(1)循環讀取逐漸增加的文件内容
ping 127.0.0.1 > ping.log &
後台運行:可使用 jobs -l 查看,也可使用 fg 将其移到前台運行。
tail -f ping.log
(查看日志)
14、which 命令
在 linux 要查找某個文件,但不知道放在哪裡了,可以使用下面的一些命令來搜索:
which 查看可執行文件的位置。
whereis 查看文件的位置。
locate 配合數據庫查看文件位置。
find 實際搜尋硬盤查詢文件名稱。
which 是在 PATH 就是指定的路徑中,搜索某個系統命令的位置,并返回第一個搜索結果。使用 which 命令,就可以看到某個系統命令是否存在,以及執行的到底是哪一個位置的命令。
常用參數:
-n 指定文件名長度,指定的長度必須大于或等于所有文件中最長的文件名。
實例:
(1)查看 ls 命令是否存在,執行哪個
which ls
(2)查看 which
which which
(3)查看 cd
which cd(顯示不存在,因為 cd 是内建命令,而 which 查找顯示是 PATH 中的命令)
查看當前 PATH 配置:
echo $PATH
或使用 env 查看所有環境變量及對應值
15、whereis 命令
whereis 命令隻能用于程序名的搜索,而且隻搜索二進制文件(參數-b)、man說明文件(參數-m)和源代碼文件(參數-s)。如果省略參數,則返回所有信息。whereis 及 locate 都是基于系統内建的數據庫進行搜索,因此效率很高,而find則是遍曆硬盤查找文件。
常用參數:
-b 定位可執行文件。
-m 定位幫助文件。
-s 定位源代碼文件。
-u 搜索默認路徑下除可執行文件、源代碼文件、幫助文件以外的其它文件。
實例:
(1)查找 locate 程序相關文件
whereis locate
(2)查找 locate 的源碼文件
whereis -s locate
(3)查找 lcoate 的幫助文件
whereis -m locate
16、locate 命令
locate 通過搜尋系統内建文檔數據庫達到快速找到檔案,數據庫由 updatedb 程序來更新,updatedb 是由 cron daemon 周期性調用的。默認情況下 locate 命令在搜尋數據庫時比由整個由硬盤資料來搜尋資料來得快,但較差勁的是 locate 所找到的檔案若是最近才建立或 剛更名的,可能會找不到,在内定值中,updatedb 每天會跑一次,可以由修改 crontab 來更新設定值 (etc/crontab)。
locate 與 find 命令相似,可以使用如 *、? 等進行正則匹配查找
常用參數:
-l num(要顯示的行數)
-f 将特定的檔案系統排除在外,如将proc排除在外
-r 使用正則運算式做為尋找條件
實例:
(1)查找和 pwd 相關的所有文件(文件名中包含 pwd)
locate pwd
(2)搜索 etc 目錄下所有以 sh 開頭的文件
locate /etc/sh
(3)查找 /var 目錄下,以 reason 結尾的文件
locate -r '^/var.*reason$'(其中.表示一個字符,*表示任務多個;.*表示任意多個字符)
17、find 命令
用于在文件樹中查找文件,并作出相應的處理。
命令格式:
find pathname -options [-print -exec -ok ...]
命令參數:
pathname: find命令所查找的目錄路徑。例如用.來表示當前目錄,用/來表示系統根目錄。
-print: find命令将匹配的文件輸出到标準輸出。
-exec: find命令對匹配的文件執行該參數所給出的shell命令。相應命令的形式為'command' { } \;,注意{ }和\;之間的空格。
-ok: 和-exec的作用相同,隻不過以一種更為安全的模式來執行該參數所給出的shell命令,在執行每一個命令之前,都會給出提示,讓用戶來确定是否執行。
命令選項:
-name 按照文件名查找文件
-perm 按文件權限查找文件
-user 按文件屬主查找文件
-group 按照文件所屬的組來查找文件。
-type 查找某一類型的文件,諸如:
b - 塊設備文件
d - 目錄
c - 字符設備文件
l - 符号鍊接文件
p - 管道文件
f - 普通文件
-size n :[c] 查找文件長度為n塊文件,帶有c時表文件字節大小
-amin n 查找系統中最後N分鐘訪問的文件
-atime n 查找系統中最後n*24小時訪問的文件
-cmin n 查找系統中最後N分鐘被改變文件狀态的文件
-ctime n 查找系統中最後n*24小時被改變文件狀态的文件
-mmin n 查找系統中最後N分鐘被改變文件數據的文件
-mtime n 查找系統中最後n*24小時被改變文件數據的文件
(用減号-來限定更改時間在距今n日以内的文件,而用加号 來限定更改時間在距今n日以前的文件。 )
-maxdepth n 最大查找目錄深度
-prune 選項來指出需要忽略的目錄。在使用-prune選項時要當心,因為如果你同時使用了-depth選項,那麼-prune選項就會被find命令忽略
-newer 如果希望查找更改時間比某個文件新但比另一個文件舊的所有文件,可以使用-newer選項
實例:
(1)查找 48 小時内修改過的文件
find -atime -2
(2)在當前目錄查找 以 .log 結尾的文件。 . 代表當前目錄
find ./ -name '*.log'
(3)查找 /opt 目錄下 權限為 777 的文件
find /opt -perm 777
(4)查找大于 1K 的文件
find -size 1000c
查找等于 1000 字符的文件
find -size 1000c
-exec 參數後面跟的是 command 命令,它的終止是以 ; 為結束标志的,所以這句命令後面的分号是不可缺少的,考慮到各個系統中分号會有不同的意義,所以前面加反斜杠。{} 花括号代表前面find查找出來的文件名。
實例:
(5)在當前目錄中查找更改時間在10日以前的文件并删除它們(無提醒)
find . -type f -mtime 10 -exec rm -f {} \;
(6)當前目錄中查找所有文件名以.log結尾、更改時間在5日以上的文件,并删除它們,隻不過在删除之前先給出提示。 按y鍵删除文件,按n鍵不删除
find . -name '*.log' mtime 5 -ok -exec rm {} \;
(7)當前目錄下查找文件名以 passwd 開頭,内容包含 "pkg" 字符的文件
find . -f -name 'passwd*' -exec grep "pkg" {} \;
(8)用 exec 選項執行 cp 命令
find . -name '*.log' -exec cp {} test3 \;
-xargs find 命令把匹配到的文件傳遞給 xargs 命令,而 xargs 命令每次隻獲取一部分文件而不是全部,不像 -exec 選項那樣。這樣它可以先處理最先獲取的一部分文件,然後是下一批,并如此繼續下去。
實例:
(9)查找當前目錄下每個普通文件,然後使用 xargs 來判斷文件類型
find . -type f -print | xargs file
(10)查找當前目錄下所有以 js 結尾的并且其中包含 'editor' 字符的普通文件
find . -type f -name "*.js" -exec grep -lF 'ueditor' {} \;
find -type f -name '*.js' | xargs grep -lF 'editor'
(11)利用 xargs 執行 mv 命令
find . -name "*.log" | xargs -i mv {} test4
(12)用 grep 命令在當前目錄下的所有普通文件中搜索 hostnames 這個詞,并标出所在行:
find . -name \*(轉義) -type f -print | xargs grep -n 'hostnames'
(13)查找當前目錄中以一個小寫字母開頭,最後是 4 到 9 加上 .log 結束的文件:
find . -name '[a-z]*[4-9].log' -print
(14)在 test 目錄查找不在 test4 子目錄查找
find test -path 'test/test4' -prune -o -print
(15)實例1:查找更改時間比文件 log2012.log新但比文件 log2017.log 舊的文件
find -newer log2012.log ! -newer log2017.log
使用 depth 選項:
depth 選項可以使 find 命令向磁帶上備份文件系統時,希望首先備份所有的文件,其次再備份子目錄中的文件。
實例:find 命令從文件系統的根目錄開始,查找一個名為 CON.FILE 的文件。 它将首先匹配所有的文件然後再進入子目錄中查找
find / -name "CON.FILE" -depth -print
18、chmod 命令
用于改變 linux 系統文件或目錄的訪問權限。用它控制文件或目錄的訪問權限。該命令有兩種用法。一種是包含字母和操作符表達式的文字設定法;另一種是包含數字的數字設定法。
每一文件或目錄的訪問權限都有三組,每組用三位表示,分别為文件屬主的讀、寫和執行權限;與屬主同組的用戶的讀、寫和執行權限;系統中其他用戶的讀、寫和執行權限。可使用 ls -l test.txt 查找。
以文件 log2012.log 為例:
-rw-r--r-- 1 root root 296K 11-13 06:03 log2012.log
第一列共有 10 個位置,第一個字符指定了文件類型。在通常意義上,一個目錄也是一個文件。如果第一個字符是橫線,表示是一個非目錄的文件。如果是 d,表示是一個目錄。從第二個字符開始到第十個 9 個字符,3 個字符一組,分别表示了 3 組用戶對文件或者目錄的權限。權限字符用橫線代表空許可,r 代表隻讀,w 代表寫,x 代表可執行。
常用參數:
-c 當發生改變時,報告處理信息
-R 處理指定目錄以及其子目錄下所有文件
權限範圍:
u :目錄或者文件的當前的用戶
g :目錄或者文件的當前的群組
o :除了目錄或者文件的當前用戶或群組之外的用戶或者群組
a :所有的用戶及群組
權限代号:
r :讀權限,用數字4表示
w :寫權限,用數字2表示
x :執行權限,用數字1表示
- :删除權限,用數字0表示
s :特殊權限
實例:
(1)增加文件 t.log 所有用戶可執行權限
chmod a x t.log
(2)撤銷原來所有的權限,然後使擁有者具有可讀權限,并輸出處理信息
chmod u=r t.log -c
(3)給 file 的屬主分配讀、寫、執行(7)的權限,給file的所在組分配讀、執行(5)的權限,給其他用戶分配執行(1)的權限
chmod 751 t.log -c(或者:chmod u=rwx,g=rx,o=x t.log -c)
(4)将 test 目錄及其子目錄所有文件添加可讀權限
chmod u r,g r,o r -R text/ -c
19、tar 命令
用來壓縮和解壓文件。tar 本身不具有壓縮功能,隻具有打包功能,有關壓縮及解壓是調用其它的功能來完成。
弄清兩個概念:打包和壓縮。打包是指将一大堆文件或目錄變成一個總的文件;壓縮則是将一個大的文件通過一些壓縮算法變成一個小文件
常用參數:
-c 建立新的壓縮文件
-f 指定壓縮文件
-r 添加文件到已經壓縮文件包中
-u 添加改了和現有的文件到壓縮包中
-x 從壓縮包中抽取文件
-t 顯示壓縮文件中的内容
-z 支持gzip壓縮
-j 支持bzip2壓縮
-Z 支持compress解壓文件
-v 顯示操作過程
有關 gzip 及 bzip2 壓縮:
gzip 實例:壓縮 gzip fileName .tar.gz 和.tgz 解壓:gunzip filename.gz 或 gzip -d filename.gz
對應:tar zcvf filename.tar.gz tar zxvf filename.tar.gz
bz2實例:壓縮 bzip2 -z filename .tar.bz2 解壓:bunzip filename.bz2或bzip -d filename.bz2
對應:tar jcvf filename.tar.gz 解壓:tar jxvf filename.tar.bz2
實例:
(1)将文件全部打包成 tar 包
tar -cvf log.tar 1.log,2.log 或tar -cvf log.*
(2)将 /etc 下的所有文件及目錄打包到指定目錄,并使用 gz 壓縮
tar -zcvf /tmp/etc.tar.gz /etc
(3)查看剛打包的文件内容(一定加z,因為是使用 gzip 壓縮的)
tar -ztvf /tmp/etc.tar.gz
(4)要壓縮打包 /home, /etc ,但不要 /home/dmtsai
tar --exclude /home/dmtsai -zcvf myfile.tar.gz /home/* /etc
20、chown 命令
chown 将指定文件的擁有者改為指定的用戶或組,用戶可以是用戶名或者用戶 ID;組可以是組名或者組 ID;文件是以空格分開的要改變權限的文件列表,支持通配符。
-c 顯示更改的部分的信息
-R 處理指定目錄及子目錄
實例:
(1)改變擁有者和群組 并顯示改變信息
chown -c mail:mail log2012.log
(2)改變文件群組
chown -c :mail t.log
(3)改變文件夾及子文件目錄屬主及屬組為 mail
chown -cR mail: test/
21、df 命令
顯示磁盤空間使用情況。獲取硬盤被占用了多少空間,目前還剩下多少空間等信息,如果沒有文件名被指定,則所有當前被挂載的文件系統的可用空間将被顯示。默認情況下,磁盤空間将以 1KB 為單位進行顯示,除非環境變量 POSIXLY_CORRECT 被指定,那樣将以512字節為單位進行顯示:
-a 全部文件系統列表
-h 以方便閱讀的方式顯示信息
-i 顯示inode信息
-k 區塊為1024字節
-l 隻顯示本地磁盤
-T 列出文件系統類型
實例:
(1)顯示磁盤使用情況
df -l
(2)以易讀方式列出所有文件系統及其類型
df -haT
22、du 命令
du 命令也是查看使用空間的,但是與 df 命令不同的是 Linux du 命令是對文件和目錄磁盤使用的空間的查看:
命令格式:
du [選項] [文件]
常用參數:
-a 顯示目錄中所有文件大小
-k 以KB為單位顯示文件大小
-m 以MB為單位顯示文件大小
-g 以GB為單位顯示文件大小
-h 以易讀方式顯示文件大小
-s 僅顯示總計
-c或--total 除了顯示個别目錄或文件的大小外,同時也顯示所有目錄或文件的總和
實例:
(1)以易讀方式顯示文件夾内及子文件夾大小
du -h scf/
(2)以易讀方式顯示文件夾内所有文件大小
du -ah scf/
(3)顯示幾個文件或目錄各自占用磁盤空間的大小,還統計它們的總和
du -hc test/ scf/
(4)輸出當前目錄下各個子目錄所使用的空間
du -hc --max-depth=1 scf/
23、ln 命令
功能是為文件在另外一個位置建立一個同步的鍊接,當在不同目錄需要該問題時,就不需要為每一個目錄創建同樣的文件,通過 ln 創建的鍊接(link)減少磁盤占用量。
鍊接分類:軟件鍊接及硬鍊接
軟鍊接:
硬鍊接:
需要注意:
常用參數:
-b 删除,覆蓋以前建立的鍊接
-s 軟鍊接(符号鍊接)
-v 顯示詳細處理過程
實例:
(1)給文件創建軟鍊接,并顯示操作信息
ln -sv source.log link.log
(2)給文件創建硬鍊接,并顯示操作信息
ln -v source.log link1.log
(3)給目錄創建軟鍊接
ln -sv /opt/soft/test/test3 /opt/soft/test/test5
24、date 命令
顯示或設定系統的日期與時間。
命令參數:
-d<字符串> 顯示字符串所指的日期與時間。字符串前後必須加上雙引号。
-s<字符串> 根據字符串來設置日期與時間。字符串前後必須加上雙引号。
-u 顯示GMT。
%H 小時(00-23)
%I 小時(00-12)
%M 分鐘(以00-59來表示)
%s 總秒數。起算時間為1970-01-01 00:00:00 UTC。
%S 秒(以本地的慣用法來表示)
%a 星期的縮寫。
%A 星期的完整名稱。
%d 日期(以01-31來表示)。
%D 日期(含年月日)。
%m 月份(以01-12來表示)。
%y 年份(以00-99來表示)。
%Y 年份(以四位數來表示)。
實例:
(1)顯示下一天
date %Y%m%d --date=" 1 day" //顯示下一天的日期
(2)-d參數使用
date -d "nov 22" 今年的 11 月 22 日是星期三
date -d '2 weeks' 2周後的日期
date -d 'next monday' (下周一的日期)
date -d next-day %Y%m%d(明天的日期)或者:date -d tomorrow %Y%m%d
date -d last-day %Y%m%d(昨天的日期) 或者:date -d yesterday %Y%m%d
date -d last-month %Y%m(上個月是幾月)
date -d next-month %Y%m(下個月是幾月)
25、cal 命令
可以用戶顯示公曆(陽曆)日曆如隻有一個參數,則表示年份(1-9999),如有兩個參數,則表示月份和年份:
常用參數:
-3 顯示前一月,當前月,後一月三個月的日曆
-m 顯示星期一為第一列
-j 顯示在當前年第幾天
-y [year]顯示當前年[year]份的日曆
實例:
(1)顯示指定年月日期
cal 9 2012
(2)顯示2013年每個月日曆
cal -y 2013
(3)将星期一做為第一列,顯示前中後三月
cal -3m
26、grep 命令
強大的文本搜索命令,grep(Global Regular Expression Print) 全局正則表達式搜索。
grep 的工作方式是這樣的,它在一個或多個文件中搜索字符串模闆。如果模闆包括空格,則必須被引用,模闆後的所有字符串被看作文件名。搜索的結果被送到标準輸出,不影響原文件内容。
命令格式:
grep [option] pattern file|dir
常用參數:
-A n --after-context顯示匹配字符後n行
-B n --before-context顯示匹配字符前n行
-C n --context 顯示匹配字符前後n行
-c --count 計算符合樣式的列數
-i 忽略大小寫
-l 隻列出文件内容符合指定的樣式的文件名稱
-f 從文件中讀取關鍵詞
-n 顯示匹配内容的所在文件中行數
-R 遞歸查找文件夾
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開頭的單詞的行。
\> #錨定單詞的結束,如'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],如:'G\w*p'匹配以G後跟零個或多個文字或數字字符,然後是p。
\W #\w的反置形式,匹配一個或多個非單詞字符,如點号句号等。
\b #單詞鎖定符,如: '\bgrep\b'隻匹配grep。
實例:
(1)查找指定進程
ps -ef | grep svn
(2)查找指定進程個數
ps -ef | grep svn -c
(3)從文件中讀取關鍵詞
cat test1.txt | grep -f key.log
(4)從文件夾中遞歸查找以grep開頭的行,并隻列出文件
grep -lR '^grep' /tmp
(5)查找非x開關的行内容
grep '^[^x]' test.txt
(6)顯示包含 ed 或者 at 字符的内容行
grep -E 'ed|at' test.txt
更多精彩资讯请关注tft每日頭條,我们将持续为您更新最新资讯!