linux之sort用法html
sort命令是幫咱們依據不一樣的數據類型進行排序,其語法及經常使用參數格式: linux
sort [-bcfMnrtk][源文件][-o 輸出文件] 補充說明:sort可針對文本文件的內容,以行爲單位來排序。web
參 數: 正則表達式
-b 忽略每行前面開始出的空格字符。 express
-c 檢查文件是否已經按照順序排序。 緩存
-f 排序時,忽略大小寫字母。 app
-M 將前面3個字母依照月份的縮寫進行排序。 post
-n 依照數值的大小排序。 this
-o<輸出文件> 將排序後的結果存入指定的文件。url
-r 以相反的順序來排序。
-t<分隔字符> 指定排序時所用的欄位分隔字符。
-k 選擇以哪一個區間進行排序。 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
下面經過幾個例子來說述Sort的使用。
(1)sort將文件的每一行做爲一個單位,相互比較,比較原則是從首字符向後,依次按ASCII碼值進行比較,最後將他們按升序輸出。
[rocrocket@rocrocket programming]$ cat seq.txt
banana
apple
pear
orange
[rocrocket@rocrocket programming]$ sort seq.txt
apple
banana
orange
pear
用戶能夠保存排序後的文件內容,或把排序後的文件內容輸出至打印機。下例中用戶把排序後的文件內容保存到名爲result的文件中。 $ Sort seq.txt > result
(2)sort的-u選項
它的做用很簡單,就是在輸出行中去除重複行。
[rocrocket@rocrocket programming]$ cat seq.txt
banana
apple
pear
orange
pear
[rocrocket@rocrocket programming]$ sort seq.txt
apple
banana
orange
pear
pear
[rocrocket@rocrocket programming]$ sort -u seq.txt
apple
banana
orange
pear
pear因爲重複被-u選項無情的刪除了。
(3)sort的-r選項
sort默認的排序方式是升序,若是想改爲降序,就加個-r就搞定了。
[rocrocket@rocrocket programming]$ cat number.txt
1 3 5 2 4
[rocrocket@rocrocket programming]$ sort number.txt
1 2 3 4 5
[rocrocket@rocrocket programming]$ sort -r number.txt
5 4 3 2 1
(5)sort的-o選項
因爲sort默認是把結果輸出到標準輸出,因此須要用重定向才能將結果寫入文件,形如sort filename > newfile。
可是,若是你想把排序結果輸出到原文件中,用重定向可就不行了。
[rocrocket@rocrocket programming]$ sort -r number.txt > number.txt
[rocrocket@rocrocket programming]$ cat number.txt
[rocrocket@rocrocket programming]$
看,居然將number清空了。
就在這個時候,-o選項出現了,它成功的解決了這個問題,讓你放心的將結果寫入原文件。這或許也是-o比重定向的惟一優點所在。
[rocrocket@rocrocket programming]$ cat number.txt
1 3 5 2 4
[rocrocket@rocrocket programming]$ sort -r number.txt -o number.txt
[rocrocket@rocrocket programming]$ cat number.txt
5 4 3 2 1
(6) sort的-n選項
你有沒有遇到過10比2小的狀況。我反正遇到過。出現這種狀況是因爲排序程序將這些數字按字符來排序了,排序程序會先比較1和2,顯然1小,因此就將10放在2前面嘍。這也是sort的一向做風。
咱們若是想改變這種現狀,就要使用-n選項,來告訴sort,「要以數值來排序」!
[rocrocket@rocrocket programming]$ cat number.txt
1 10 19 11 2 5
[rocrocket@rocrocket programming]$ sort number.txt
1 10 11 19 2 5
[rocrocket@rocrocket programming]$ sort -n number.txt
1 2 5 10 11 19
(7) sort的-t選項和-k選項
若是有一個文件的內容是這樣:
[rocrocket@rocrocket programming]$ cat facebook.txt
banana:30:5.5
apple:10:2.5
pear:90:2.3
orange:20:3.4
這個文件有三列,列與列之間用冒號隔開了,第一列表示水果類型,第二列表示水果數量,第三列表示水果價格。那麼我想以水果數量來排序,也就是以第二列來排序,如何利用sort實現?幸虧,sort提供了-t選項,後面能夠設定間隔符。指定了間隔符以後,就能夠用-k來指定列數了。
[rocrocket@rocrocket programming]$ sort -n -k 2 -t ‘:’ facebook.txt
apple:10:2.5
orange:20:3.4
banana:30:5.5
pear:90:2.3
(8) 其餘的sort經常使用選項
-f會將小寫字母都轉換爲大寫字母來進行比較,亦即忽略大小寫
-c會檢查文件是否已排好序,若是亂序,則輸出第一個亂序的行的相關信息,最後返回1
-C會檢查文件是否已排好序,若是亂序,不輸出內容,僅返回1
-M會以月份來排序,好比JAN小於FEB等等
-b會忽略每一行前面的全部空白部分,從第一個可見字符開始比較。
uniq
概述:head命令用於顯示文件文字區塊
一、格式
head 【參數】【文件】
二、參數
-q 隱藏文件名
-v 顯示文件名
-c<字節> 顯示字節數
-n<行數> 顯示的行數
sed命令
截取某段時間的日誌
sed -n '/Apr 19 21:58:15/,/Apr 19 22:22:32/p' /var/log/messages