1. 程式人生 > >Linux面試指令---sort指令

Linux面試指令---sort指令

sort 命令

       同文本檔案打交道時,總避不開排序,那是因為對於文字處理任務而言,排序(sort)可以起到不小的作用。sort 命令能夠幫助我們對文字檔案和 stdin 進行排序操作。通常,它會結合其他命令來生成所需要的輸出。

(1)命令格式

         sort [選項] [檔名]

(2)常用引數

引數 描述
-n 基於字串的長度來排序,使用此選項允許根據數字值排序,而不是字母值
-k 指定排序關鍵字
-b 預設情況下,對整行進行排序,從每行的第一個字元開始。這個選項導致 sort 程式忽略每行開頭的空格,從第一個非空白字元開始排序
-m 只合並多個輸入檔案
-r 按相反順序排序,結果按照降序排列,而不是升序
-t 自定義分隔符,預設為製表符

(3)常用範例

         例一:列出/usr/share/目錄下使用空間最多的前 10 個目錄檔案,可以使用如下命令:

du -s /usr/share/* | sort -nr | head -10

         du -s /usr/share/* 命令顯示/usr/share/目錄下所有檔案和目錄的磁碟使用空間,目錄包含目錄下的子目錄和檔案

       例二:ls 命令能顯示目錄下檔案的詳細資訊,包含空間使用大小,但與 du 命令不同的是,ls 命令不計算目錄下的子目錄和檔案的大小。ls 顯示格式如下:

-rwxrwxrwx   1  root   root  542  11 月   29  test.php

現在想要對 ls 命令輸出資訊中的空間使用大小欄位進行排序,可以使用如下命令:

ls -l /usr/bin/ | sort -nr -k 5 | head -10

        例三:首先來看下下面的例子:

由於 11 由 1 開始,比 5 小,所以排在 5 的前面。這時排序可以通過自定義排序欄位來排序。使用下面的命令就可以解決。

sort  -k 1,1  -k 2n data.txt

       第一個-k 選項指明只對第一個欄位排序,1,1 意味著“始於並且結束於第一個欄位”。 第二個-k 選項 2n 表示對第二個欄位按數值排序。 還有一種格式,如-k 3.4n,表示始於第三個欄位的第四個字元,按數值排序。

-k 選項的語法格式如下:

[ FStart [ .CStart ] ] [ Modifier ] [ , [ FEnd [ .CEnd ] ][ Modifier ] ]

這個語法格式可以被其中的逗號(“,”)分為兩大部分,Start 部分和 End 部分。

先給你灌輸一個思想,那就是“如果不設定 End 部分,那麼就認為 End 被設定為行尾”。這個概念很重要的,但往往你不會重視它。

Start 部分也由三部分組成,其中的 Modifier 部分就是類似 n 和 r 的選項部分。我們重點說說 Start 部分的 FStart 和 CStart。 FStart.CStart,其中 FStart 就是表示使用的域,而 CStart 則表示在 FStart 域中從第幾個字元開始算“排序首字元”。CStart 是可以省略的,省略的話就表示從本域的開頭部分開始。之前例子中的-k 5 就是省略了 CStart 的例子。

同理,在 End 部分中,你可以設定 FEnd.CEnd,如果你省略.CEnd,則表示結尾到“域尾”,即本域的最後一個字元。或者,如果你將 CEnd 設定為 0(零),也是表示結尾到“域尾”。