【linux】經常使用命令總結

【Nslookup】 是一個監測網絡中DNS服務器是否能正確實現域名解析的命令行工具 正則表達式



【last】 shell

【cut】cut命令能夠從一個文本文件或者文本流中提取文本列。 express

cut -b list [-n] [file ...]
cut -c list [file ...]
cut -f list [-d delim][-s][file ...]

-d:後面接的是用來分隔的字符,預設是TAG 緩存

-s:表示不包括那些不含分隔符的行(這樣有利於去掉註釋和標題)
bash

上面三種方式中,表示從指定的範圍中提取字節(-b)、或字符(-c)、或字段(-f)。
範圍的表示方法:
N  :N'th byte, character or field, counted from 1
N- :從第N項一直到行尾
N-M:從第N項到第M項(包括M)
-M:從一行的開始到第M項(包括M)
-With no FILE, or when FILE is -, read standard input

【sed】
sed 是一種在線編輯器,它一次處理一行內容。處理時,把當前處理的行存儲在臨時緩衝區中,稱爲「模式空間」(pattern space),接着用sed命令處理緩衝區中的內容,處理完成後,把緩衝區的內容送往屏幕。接着處理下一行,這樣不斷重複,直到文件末尾。文件內容並無 改變,除非你使用重定向存儲輸出。Sed主要用來自動編輯一個或多個文件;簡化對文件的反覆操做;編寫轉換程序等。如下介紹的是Gnu版本的Sed 3.02。
定址
能夠經過定址來定位你所但願編輯的行,該地址用數字構成,用逗號分隔的兩個行數表示以這兩行爲起止的行的範圍(包括行數表示的那兩行)。如1,3表示1,2,3行,美圓符號($)表示最後一行。範圍能夠經過數據,正則表達式或者兩者結合的方式肯定 。
Sed命令經常使用實例 服務器

###刪除:d命令
$ sed '2d' example    ##刪除example文件的第二行。
$ sed '2,$d' example  ##刪除example文件的第二行到末尾全部行。
$ sed '$d' example    ##刪除example文件的最後一行。
$ sed '/test/'d example ##刪除example文件全部包含test的行。


###替換:s命令
$ sed 's/test/mytest/g' example
##在整行範圍內把test替換爲mytest。若是沒有g標記,則只有每行第一個匹配的test被替換成mytest。
$ sed -n 's/^test/mytest/p' example
##(-n)選項和p標誌一塊兒使用表示只打印那些發生替換的行。也就是說,若是某一行開頭的test被替換成mytest,就打印它。
$ sed 's/^192.168.0.1/&localhost/' example
##&符號表示替換換字符串中被找到的部份。全部以192.168.0.1開頭的行都會被替換成它自已加localhost,變成192.168.0.1localhost。
$ sed -n 's/\(love\)able/\1rs/p' example
##love被標記爲1,全部loveable會被替換成lovers,並且替換的行會被打印出來。
$ sed 's#10#100#g' example
##不論什麼字符,緊跟着s命令的都被認爲是新的分隔符,因此,「#」在這裏是分隔符,代替了默認的「/」分隔符。表示把全部10替換成100。


###選定行的範圍:逗號
$ sed -n '/test/,/check/p' example  ##全部在模板test和check所肯定的範圍內的行都被打印。
$ sed -n '5,/^test/p' example  ##打印從第五行開始到第一個包含以test開始的行之間的全部行。
$ sed '/test/,/check/s/$/sed test/' example  ##對於模板test和west之間的行,每行的末尾用字符串sed test替換。


###多點編輯:e命令
$ sed -e '1,5d' -e 's/test/check/' example
##(-e)選項容許在同一行裏執行多條命令。如例子所示,第一條命令刪除1至5行,第二條命令用check替換test。命令的執行順序對結果有影響。若是兩個命令都是替換命令,那麼第一個替換命令將影響第二個替換命令的結果。
$ sed --expression='s/test/check/' --expression='/love/d' example
##一個比-e更好的命令是--expression。它能給sed表達式賦值。


###從文件讀入:r命令
$ sed '/test/r file' example  ##file裏的內容被讀進來,顯示在與test匹配的行後面,若是匹配多行,則file的內容將顯示在全部匹配行的下面。
###寫入文件:w命令
$ sed -n '/test/w file' example  ##在example中全部包含test的行都被寫入file裏。


###追加命令:a命令
$ sed '/^test/a\\--->this is a example' example 
##'this is a example'被追加到以test開頭的行後面,sed要求命令a後面有一個反斜槓。


###插入:i命令
$ sed '/test/i\\
new line
-------------------------' example
###若是test被匹配,則把反斜槓後面的文本插入到匹配行的前面。


###下一個:n命令
$ sed '/test/{ n; s/aa/bb/; }' example  ##若是test被匹配,則移動到匹配行的下一行,替換這一行的aa,變爲bb,並打印該行,而後繼續。
###變形:y命令
$ sed '1,10y/abcde/ABCDE/' example ##把1--10行內全部abcde轉變爲大寫,注意,正則表達式元字符不能使用這個命令。
###退出:q命令
$ sed '10q' example-----打印完第10行後,退出sed。
###保持和獲取:h命令和G命令
$ sed -e '/test/h' -e '$G example-----在sed處理文件的時候,每一行都被保存在一個叫模式空間的臨時緩衝區中,除非行被刪除或者輸出被取消,不然全部被處理的行都將 打印在屏幕上。接着模式空間被清空,並存入新的一行等待處理。在這個例子裏,匹配test的行被找到後,將存入模式空間,h命令將其複製並存入一個稱爲保 持緩存區的特殊緩衝區內。第二條語句的意思是,當到達最後一行後,G命令取出保持緩衝區的行,而後把它放回模式空間中,且追加到如今已經存在於模式空間中 的行的末尾。在這個例子中就是追加到最後一行。簡單來講,任何包含test的行都被複制並追加到該文件的末尾。
###保持和互換:h命令和x命令
$ sed -e '/test/h' -e '/check/x' example -----互換模式空間和保持緩衝區的內容。也就是把包含test與check的行互換。

【生成隨機密碼】 網絡

cat /dev/urandom |tr -dc _A-Z-a-z-0-9 | head -c${1:-6};echo;

head:將每一個文件的前十行打印到標準輸出 dom

head [Option] ... [File]... 編輯器

-c N: 打印前N個bytes 工具

-n N:打印前N行

• sort 語法:[root @test /root ]# sort [-t 分隔符] [(+起始)(-結束)] [-nru] 參數說明: -t 分隔符:使用分隔符來隔開不一樣區間,預設是 tab +start -end:由第 start 區間排序到 end 區間 -n :使用『純數字』排序(不然就會以文字型態來排序) -r :反向排序 -u :相同出現的一行,只列出一次! 範例:[root @test /root]# cat /etc/passwd | sort將列出來的我的帳號排序! [root @test /root]# cat /etc/passwd | sort -t: +2n將我的帳號中,以使用者 ID 來排序(以 : 來分隔,第三個爲 ID ,但第一個代號爲 0 之故) [root @test /root]# cat /etc/passwd | sort -t: +2nr反相排序囉! • wc 語法:[root @test /root ]# wc [-lmw] 參數說明: -l :多少行 -m :多少字符 -w :多少字 範例:[root @test /root]# cat /etc/passwd | wc -l這個文件裏頭有多少行? [root @test /root]# cat /etc/passwd | wc -w這個文件裏頭有多少字!? • uniq這個指令用來將『重複的行刪除掉只顯示一個』 語法:[root @test /root ]# uniq 範例:[root @test /root]# last | cut -d" " -f1 | sort | uniq • tee命令重定向到文件的同時將數據顯示在屏幕上 語法:[root @test /root ]# last | tee last.list | cut -d " " -f1 範例:[root @test /root]# last | tee last.list | cut -d " " -f1 • tr 語法:[root @test /root ]# tr [-ds] SET1 參數說明: -d :刪除 SET1 這個字符串   -s :取代掉重複的字符! 範例:[root @test /root]# last | tr '[a-z]' '[A-Z]' <==將小寫改爲大寫 [root @test /root]# cat /etc/passwd | tr -d : <== : 這個符號在 /etc/passwd 中不見了! [root @test /root]# cat /home/test/dostxt | tr -d '\r' > dostxt-noM • split 語法:[root @test /root ]# split [-bl] 輸入文件 輸出文件前導字符 參數說明: -b :以文件 size 來分 -l :以行數來分 範例:[root @test /root]# split -l 5 /etc/passwd test <==會產生 testaa, testab, testac... 等等的文件 說明:在 Linux 底下就簡單的多了!你要將文件分割的話,那麼就使用 -b size 來將一個分割的文件限制其大小,若是是行數的話,那麼就使用 -l line 來分割! 管線命令在 bash 的連續的處理程序中是至關重要的!另外,在 log file 的分析當中也是至關重要的一環。 管道輸送到一個命令的標準輸入可使用標準輸入參數」-「 進行更仔細的控制.如cat命令的示例 eg:  sort mylist | more sort mylist | cat –n | lpr pwd | cat – mylist | lpr
相關文章
相關標籤/搜索