Linux命令之sort的使用
linux下sort命令使用詳解---linux將文本文件內(nèi)容加以排序命令
功能說明:將文本文件內(nèi)容加以排序。 語 法: sort [-bcdfimMnr][-o輸出文件][-t分隔字符][+起始欄位-結(jié)束欄位][--help][--verison][文件] 補(bǔ)充說明:sort可針對(duì)文本文件的內(nèi)容,以行為單位來排序。 參 數(shù): -b忽略每行前面開始出的空格字符。 -c檢查文件是
功能說明:將文本文件內(nèi)容加以排序。
語 法:sort [-bcdfimMnr][-o<輸出文件>][-t<分隔字符>][+<起始欄位>-<結(jié)束欄位>][--help][--verison][文件]
補(bǔ)充說明:sort可針對(duì)文本文件的內(nèi)容,以行為單位來排序。
參 數(shù):
-b 忽略每行前面開始出的空格字符。
-c 檢查文件是否已經(jīng)按照順序排序。
-d 排序時(shí),處理英文字母、數(shù)字及空格字符外,忽略其他的字符。
-f 排序時(shí),將小寫字母視為大寫字母。
-i 排序時(shí),除了040至176之間的ASCII字符外,忽略其他的字符。
-m 將幾個(gè)排序好的文件進(jìn)行合并。
-M 將前面3個(gè)字母依照月份的縮寫進(jìn)行排序。
-n 依照數(shù)值的大小排序。
-o<輸出文件> 將排序后的結(jié)果存入指定的文件。
-r 以相反的順序來排序。
-t<分隔字符> 指定排序時(shí)所用的欄位分隔字符。
+<起始欄位>-<結(jié)束欄位> 以指定的欄位來排序,范圍由起始欄位到結(jié)束欄位的前一欄位。
--help 顯示幫助。
--version 顯示版本信息
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
下面通過幾個(gè)例子來講述Sort的使用。
用Sort命令對(duì)text文件中各行排序后輸出其結(jié)果。請(qǐng)注意,在原文件的第二、三行上的第一個(gè)單詞完全相同,該命令將從它們的第二個(gè)單詞vegetables與fruit的首字符處繼續(xù)進(jìn)行比較。
$ cat text
vegetable soup
fresh vegetables
fresh fruit
lowfat milk
$ Sort text
fresh fruit
fresh vegetables
lowfat milk
vegetable soup
用戶可以保存排序后的文件內(nèi)容,或把排序后的文件內(nèi)容輸出至打印機(jī)。下例中用戶把排序后的文件內(nèi)容保存到名為result的文件中。
$ Sort text>result
以第2個(gè)字段作為排序關(guān)鍵字對(duì)文件example的內(nèi)容進(jìn)行排序。
$ Sort +1-2 example
對(duì)于file1和file2文件內(nèi)容反向排序,結(jié)果放在outfile中,利用第2個(gè)字段的第一個(gè)字符作為排序關(guān)鍵字。
$ Sort -r -o outfile +1.0 -1.1 example
Sort排序常用于在管道中與其他命令連用,組合完成比較復(fù)雜的功能,如利用管道將當(dāng)前工作目錄中的文件送給Sort進(jìn)行排序,排序關(guān)鍵字是第6個(gè)至第8個(gè)字段。
$ ls - l | Sort +5 - 7
$ ps -e -o " comm pid time"|Sort -d //按照command的首字母的字母順序排序
Sort 命令也可以對(duì)標(biāo)準(zhǔn)輸入進(jìn)行操作。例如,如果您想把幾個(gè)文件文本行合并,并對(duì)合并后的文本行進(jìn)行排序,您可以首先用命令cat把多個(gè)文件合并,然后用管道操作把合并后的文本行輸入給命令Sort,Sort命令將輸出這些合并及排序后的文本行。在下面的例子中,文件veglist與文件 fruitlist的文本行經(jīng)過合并與排序后被保存到文件clist中。
$ cat veglist fruitlist | Sort > clist
|
sort +3 -4 All-Unigene_PlantTFFamily_Abstract.out >All-Unigene_PlantTFFamily_Abstract.sort
sort -k 4 All-Unigene_PlantTFFamily_Abstract.out >All-Unigene_PlantTFFamily_Abstract.sort1
對(duì)一個(gè)文件兩列排序,一列正序一列逆序
sort -k1,1n -k2,2nr file
對(duì)一個(gè)文件兩列排序
sort -k1,1n -k2,2n file
1 sort的工作原理
sort將文件的每一行作為一個(gè)單位,相互比較,比較原則是從首字符向后,依次按ASCII碼值進(jìn)行比較,最后將他們按升序輸出。
[rocrocket@rocrocket programming]$ cat seq.txt
banana
apple
pear
orange
[rocrocket@rocrocket programming]$ sort seq.txt
apple
banana
orange
pear
2 sort的-u選項(xiàng)
它的作用很簡(jiǎn)單,就是在輸出行中去除重復(fù)行。
[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由于重復(fù)被-u選項(xiàng)無情的刪除了。
3 sort的-r選項(xiàng)
sort默認(rèn)的排序方式是升序,如果想改成降序,就加個(gè)-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
4 sort的-o選項(xiàng)
由于sort默認(rèn)是把結(jié)果輸出到標(biāo)準(zhǔn)輸出,所以需要用重定向才能將結(jié)果寫入文件,形如sort filename > newfile。
但是,如果你想把排序結(jié)果輸出到原文件中,用重定向可就不行了。
[rocrocket@rocrocket programming]$ sort -r number.txt > number.txt
[rocrocket@rocrocket programming]$ cat number.txt
[rocrocket@rocrocket programming]$
看,竟然將number清空了。
就在這個(gè)時(shí)候,-o選項(xiàng)出現(xiàn)了,它成功的解決了這個(gè)問題,讓你放心的將結(jié)果寫入原文件。這或許也是-o比重定向的唯一優(yōu)勢(shì)所在。
[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
5 sort的-n選項(xiàng)
你有沒有遇到過10比2小的情況。我反正遇到過。出現(xiàn)這種情況是由于排序程序?qū)⑦@些數(shù)字按字符來排序了,排序程序會(huì)先比較1和2,顯然1小,所以就將10放在2前面嘍。這也是sort的一貫作風(fēng)。
我們?nèi)绻敫淖冞@種現(xiàn)狀,就要使用-n選項(xiàng),來告訴sort,“要以數(shù)值來排序”!
[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
6 sort的-t選項(xiàng)和-k選項(xiàng)
如果有一個(gè)文件的內(nèi)容是這樣:
[rocrocket@rocrocket programming]$ cat facebook.txt
banana:30:5.5
apple:10:2.5
pear:90:2.3
orange:20:3.4
這個(gè)文件有三列,列與列之間用冒號(hào)隔開了,第一列表示水果類型,第二列表示水果數(shù)量,第三列表示水果價(jià)格。
那么我想以水果數(shù)量來排序,也就是以第二列來排序,如何利用sort實(shí)現(xiàn)?
幸好,sort提供了-t選項(xiàng),后面可以設(shè)定間隔符。(是不是想起了cut和paste的-d選項(xiàng),共鳴~~)
指定了間隔符之后,就可以用-k來指定列數(shù)了。
[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
我們使用冒號(hào)作為間隔符,并針對(duì)第二列來進(jìn)行數(shù)值升序排序,結(jié)果很令人滿意。
7 其他的sort常用選項(xiàng)
-f會(huì)將小寫字母都轉(zhuǎn)換為大寫字母來進(jìn)行比較,亦即忽略大小寫
-c會(huì)檢查文件是否已排好序,如果亂序,則輸出第一個(gè)亂序的行的相關(guān)信息,最后返回1
-C會(huì)檢查文件是否已排好序,如果亂序,不輸出內(nèi)容,僅返回1
-M會(huì)以月份來排序,比如JAN小于FEB等等
-b會(huì)忽略每一行前面的所有空白部分,從第一個(gè)可見字符開始比較。 本文出自:億恩科技【www.allwellnessguide.com】
服務(wù)器租用/服務(wù)器托管中國(guó)五強(qiáng)!虛擬主機(jī)域名注冊(cè)頂級(jí)提供商!15年品質(zhì)保障!--億恩科技[ENKJ.COM]
|