天天看點

《sort幫你排序》-linux指令五分鐘系列之二十六

好久沒寫技術文章了,對不住大家。今天送上sort幫你排序,以資共享。:)

[正文開始]

sort是在Linux裡非常常用的一個指令,管排序的,集中精力,五分鐘搞定sort,現在開始!

1 sort的工作原理

sort将檔案的每一行作為一個機關,互相比較,比較原則是從首字元向後,依次按ASCII碼值進行比較,最後将他們按升序輸出。

[rocrocket@rocrocket programming]$ cat seq.txt

banana

apple

pear

orange

[rocrocket@rocrocket programming]$ sort seq.txt

2 sort的-u選項

它的作用很簡單,就是在輸出行中去除重複行。

[rocrocket@rocrocket programming]$ sort -u seq.txt

pear由于重複被-u選項無情的删除了。

3 sort的-r選項

sort預設的排序方式是升序,如果想改成降序,就加個-r就搞定了。

[rocrocket@rocrocket programming]$ cat number.txt

1

3

5

2

4

[rocrocket@rocrocket programming]$ sort number.txt

[rocrocket@rocrocket programming]$ sort -r number.txt

4 sort的-o選項

由于sort預設是把結果輸出到标準輸出,是以需要用重定向才能将結果寫入檔案,形如sort filename > newfile。

但是,如果你想把排序結果輸出到原檔案中,用重定向可就不行了。

[rocrocket@rocrocket programming]$ sort -r number.txt > number.txt

[rocrocket@rocrocket programming]$

看,竟然将number清空了。

就在這個時候,-o選項出現了,它成功的解決了這個問題,讓你放心的将結果寫入原檔案。這或許也是-o比重定向的唯一優勢所在。

[rocrocket@rocrocket programming]$ sort -r number.txt -o number.txt

5 sort的-n選項

你有沒有遇到過10比2小的情況。我反正遇到過。出現這種情況是由于排序程式将這些數字按字元來排序了,排序程式會先比較1和2,顯然1小,是以就将10放在2前面喽。這也是sort的一貫作風。

我們如果想改變這種現狀,就要使用-n選項,來告訴sort,“要以數值來排序”!

10

19

11

[rocrocket@rocrocket programming]$ sort -n number.txt

6 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選項,後面可以設定間隔符。(是不是想起了cut和paste的-d選項,共鳴~~)

指定了間隔符之後,就可以用-k來指定列數了。

[rocrocket@rocrocket programming]$ sort -n -k 2 -t : facebook.txt

我們使用冒号作為間隔符,并針對第二列來進行數值升序排序,結果很令人滿意。

7 其他的sort常用選項

-f會将小寫字母都轉換為大寫字母來進行比較,亦即忽略大小寫

-c會檢查檔案是否已排好序,如果亂序,則輸出第一個亂序的行的相關資訊,最後傳回1

-C會檢查檔案是否已排好序,如果亂序,不輸出内容,僅傳回1

-M會以月份來排序,比如JAN小于FEB等等

-b會忽略每一行前面的所有空白部分,從第一個可見字元開始比較。

繼續閱讀