亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

sort的常用方法

2019-11-11 05:07:49
字體:
來源:轉載
供稿:網友

1 sort的工作原理

 

sort將文件的每一行作為一個單位,相互比較,比較原則是從首字符向后,依次按ASCII碼值進行比較,最后將他們按升序輸出。

[rocrocket@rocrocket PRogramming]$ cat seq.txtbananaapplepearorange[rocrocket@rocrocket programming]$ sort seq.txtapplebananaorangepear

2 sort的-u選項

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

[rocrocket@rocrocket programming]$ cat seq.txtbananaapplepearorangepear[rocrocket@rocrocket programming]$ sort seq.txtapplebananaorangepearpear[rocrocket@rocrocket programming]$ sort -u seq.txtapplebananaorangepear

pear由于重復被-u選項無情的刪除了。

3 sort的-r選項

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

[rocrocket@rocrocket programming]$ cat number.txt13524[rocrocket@rocrocket programming]$ sort number.txt12345[rocrocket@rocrocket programming]$ sort -r number.txt54321

4 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.txt13524[rocrocket@rocrocket programming]$ sort -r number.txt -o number.txt[rocrocket@rocrocket programming]$ cat number.txt54321

5 sort的-n選項

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

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

[rocrocket@rocrocket programming]$ cat number.txt110191125[rocrocket@rocrocket programming]$ sort number.txt110111925[rocrocket@rocrocket programming]$ sort -n number.txt125101119

6 sort的-t選項和-k選項

如果有一個文件的內容是這樣:

[rocrocket@rocrocket programming]$ cat facebook.txtbanana:30:5.5apple:10:2.5pear:90:2.3orange:20:3.4

這個文件有三列,列與列之間用冒號隔開了,第一列表示水果類型,第二列表示水果數量,第三列表示水果價格。

那么我想以水果數量來排序,也就是以第二列來排序,如何利用sort實現?

幸好,sort提供了-t選項,后面可以設定間隔符。(是不是想起了cut和paste的-d選項,共鳴~~)

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

[rocrocket@rocrocket programming]$ sort -n -k 2 -t : facebook.txtapple:10:2.5orange:20:3.4banana:30:5.5pear:90:2.3

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

7 其他的sort常用選項

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

-c會檢查文件是否已排好序,如果亂序,則輸出第一個亂序的行的相關信息,最后返回1

-C會檢查文件是否已排好序,如果亂序,不輸出內容,僅返回1

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

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

有時候學習腳本,你會發現sort命令后面跟了一堆類似-k1,2,或者-k1.2 -k3.4的東東,有些匪夷所思。今天,我們就來搞定它—-k選項!

1 準備素材

$ cat facebook.txtgoogle 110 5000baidu 100 5000guge 50 3000sohu 100 4500

 

第一個域是公司名稱,第二個域是公司人數,第三個域是員工平均工資。(除了公司名稱,其他的別信,都瞎寫的^_^)

2 我想讓這個文件按公司的字母順序排序,也就是按第一個域進行排序:(這個facebook.txt文件有三個域)

$ sort -t ‘ ‘ -k 1 facebook.txtbaidu 100 5000google 110 5000guge 50 3000sohu 100 4500

看到了吧,就直接用-k 1設定就可以了。(其實此處并不嚴格,稍后你就會知道)

3 我想讓facebook.txt按照公司人數排序

$ sort -n -t ‘ ‘ -k 2 facebook.txtguge 50 3000baidu 100 5000sohu 100 4500google 110 5000

不用解釋,我相信你能懂。

但是,此處出現了問題,那就是baidu和sohu的公司人數相同,都是100人,這個時候怎么辦呢?按照默認規矩,是從第一個域開始進行升序排序,因此baidu排在了sohu前面。

 我想讓facebook.txt按照公司人數排序 ,人數相同的按照員工平均工資升序排序:

$ sort -n -t ‘ ‘ -k 2 -k 3 facebook.txtguge 50 3000sohu 100 4500baidu 100 5000google 110 5000

看,我們加了一個-k2 -k3就解決了問題。對滴,sort支持這種設定,就是說設定域排序的優先級,先以第2個域進行排序,如果相同,再以第3個域進行排序。(如果你愿意,可以一直這么寫下去,設定很多個排序優先級)

5 我想讓facebook.txt按照員工工資降序排序,如果員工人數相同的,則按照公司人數升序排序:(這個有點難度嘍)

$ sort -n -t ‘ ‘ -k 3r -k 2 facebook.txtbaidu 100 5000google 110 5000sohu 100 4500guge 50 3000

此處有使用了一些小技巧,你仔細看看,在-k 3后面偷偷加上了一個小寫字母r。你想想,再結合我們上一篇文章,能得到答案么?揭曉:r和-r選項的作用是一樣的,就是表示逆序。因為sort默認是按照升序排序的,所以此處需要加上r表示第三個域(員工平均工資)是按照降序排序。此處你還可以加上n,就表示對這個域進行排序時,要按照數值大小進行排序,舉個例子吧:

$ sort -t ‘ ‘ -k 3nr -k 2n facebook.txtbaidu 100 5000google 110 5000sohu 100 4500guge 50 3000

看,我們去掉了最前面的-n選項,而是將它加入到了每一個-k選項中了。

6 -k選項的具體語法格式

要繼續往下深入的話,就不得不來點理論知識。你需要了解-k選項的語法格式,如下:

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

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

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

Start部分也由三部分組成,其中的Modifier部分就是我們之前說過的類似n和r的選項部分。我們重點說說Start部分的FStart和C.Start。

C.Start也是可以省略的,省略的話就表示從本域的開頭部分開始。之前例子中的-k 2和-k 3就是省略了C.Start的例子嘍。

FStart.CStart,其中FStart就是表示使用的域,而CStart則表示在FStart域中從第幾個字符開始算“排序首字符”。

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

7 突發奇想,從公司英文名稱的第二個字母開始進行排序:

$ sort -t ‘ ‘ -k 1.2 facebook.txtbaidu 100 5000sohu 100 4500google 110 5000guge 50 3000

看,我們使用了-k 1.2,這就表示對第一個域的第二個字符開始到本域的最后一個字符為止的字符串進行排序。你會發現baidu因為第二個字母是a而名列榜首。sohu和 google第二個字符都是o,但sohu的h在google的o前面,所以兩者分別排在第二和第三。guge只能屈居第四了。

8 又突發奇想,,只針對公司英文名稱的第二個字母進行排序,如果相同的按照員工工資進行降序排序:

$ sort -t ‘ ‘ -k 1.2,1.2 -k 3,3nr facebook.txtbaidu 100 5000google 110 5000sohu 100 4500guge 50 3000

由于只對第二個字母進行排序,所以我們使用了-k 1.2,1.2的表示方式,表示我們“只”對第二個字母進行排序。(如果你問“我使用-k 1.2怎么不行?”,當然不行,因為你省略了End部分,這就意味著你將對從第二個字母起到本域最后一個字符為止的字符串進行排序)。對于員工工資進行排 序,我們也使用了-k 3,3,這是最準確的表述,表示我們“只”對本域進行排序,因為如果你省略了后面的3,就變成了我們“對第3個域開始到最后一個域位置的內容進行排序” 了。

9 在modifier部分還可以用到哪些選項?

可以用到b、d、f、i、n 或 r。

其中n和r你肯定已經很熟悉了。

b表示忽略本域的簽到空白符號。

d表示對本域按照字典順序排序(即,只考慮空白和字母)。

f表示對本域忽略大小寫進行排序。

i表示忽略“不可打印字符”,只針對可打印字符進行排序。(有些ASCII就是不可打印字符,比如/a是報警,/b是退格,/n是換行,/r是回車等等)

10 思考思考關于-k和-u聯合使用的例子:

$ cat facebook.txtgoogle 110 5000baidu 100 5000guge 50 3000sohu 100 4500

這是最原始的facebook.txt文件。

$ sort -n -k 2 facebook.txtguge 50 3000baidu 100 5000sohu 100 4500google 110 5000

$ sort -n -k 2 -u facebook.txtguge 50 3000baidu 100 5000google 110 5000

當設定以公司員工域進行數值排序,然后加-u后,sohu一行就被刪除了!原來-u只識別用-k設定的域,發現相同,就將后續相同的行都刪除。

$ sort  -k 1 -u facebook.txtbaidu 100 5000google 110 5000guge 50 3000sohu 100 4500

$ sort  -k 1.1,1.1 -u facebook.txtbaidu 100 5000google 110 5000sohu 100 4500

這個例子也同理,開頭字符是g的guge就沒有幸免于難。

$ sort -n -k 2 -k 3 -u facebook.txtguge 50 3000sohu 100 4500baidu 100 5000google 110 5000

咦!這里設置了兩層排序優先級的情況下,使用-u就沒有刪除任何行。原來-u是會權衡所有-k選項,將都相同的才會刪除,只要其中有一級不同都不會輕易刪除的:)(不信,你可以自己加一行sina 100 4500試試看)

11 最詭異的排序:

$ sort -n -k 2.2,3.1 facebook.txtguge 50 3000baidu 100 5000sohu 100 4500google 110 5000

以第二個域的第二個字符開始到第三個域的第一個字符結束的部分進行排序。

第一行,會提取0 3,第二行提取00 5,第三行提取00 4,第四行提取10 5。

又因為sort認為0小于00小于000小于0000….

因此0 3肯定是在第一個。10 5肯定是在最后一個。但為什么00 5卻在00 4前面呢?(你可以自己做實驗思考一下。)

答案揭曉:原來“跨域的設定是個假象”,sort只會比較第二個域的第二個字符到第二個域的最后一個字符的部分,而不會把第三個域的開頭字符納入比較范圍。當發現00和00相同時,sort就會自動比較第一個域去了。當然baidu在sohu前面了。用一個范例即可證實:

$ sort -n -k 2.2,3.1 -k 1,1r facebook.txtguge 50 3000sohu 100 4500baidu 100 5000google 110 5000

12 有時候在sort命令后會看到+1 -2這些符號,這是什么東東?

關于這種語法,最新的sort是這么進行解釋的:

On older systems, `sort’ supports an obsolete origin-zero syntax `+POS1 [-POS2]‘ for specifying sort keys.  POSIX 1003.1-2001 (*note Standards conformance::) does not allow this; use `-k’ instead.

原來,這種古老的表示方式已經被淘汰了,以后可以理直氣壯的鄙視使用這種表示方法的腳本嘍!

(為了防止古老腳本的存在,在這再說一下這種表示方法,加號表示Start部分,減號表示End部分。最最重要的一點是,這種方式方法是從0開始計數的,以前所說的第一個域,在此被表示為第0個域。以前的第2個字符,在此表示為第1個字符。明白?)


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久夜色撩人精品| 久久久久久久一区二区| 66m—66摸成人免费视频| 精品久久久999| 日本高清不卡在线| 日韩在线中文字幕| 国产精品私拍pans大尺度在线| 亚洲电影天堂av| 超碰91人人草人人干| 日本老师69xxx| 欧美成人午夜激情在线| 日韩电影中文字幕| 国产日韩在线视频| 欧美洲成人男女午夜视频| 色偷偷av一区二区三区| 丝袜美腿亚洲一区二区| 91九色单男在线观看| 日韩va亚洲va欧洲va国产| 免费不卡在线观看av| 国产精品欧美风情| 成人精品视频在线| 亚洲最大的免费| 午夜伦理精品一区| 91亚洲精品在线观看| 日韩欧美综合在线视频| 色爱av美腿丝袜综合粉嫩av| 中文字幕在线看视频国产欧美| 欧美日韩一区二区三区在线免费观看| 国产区精品视频| 久久精品夜夜夜夜夜久久| 亚洲嫩模很污视频| 欧美性生交大片免费| 亚洲精品永久免费| 久久亚洲精品网站| 欧美国产视频一区二区| 国产精品久久久久秋霞鲁丝| 国产欧美在线看| 欧美午夜精品久久久久久人妖| 午夜精品久久久久久久久久久久| 国产偷亚洲偷欧美偷精品| 亚洲女成人图区| 亚洲激情视频在线| 性色av一区二区三区在线观看| 欧美猛交ⅹxxx乱大交视频| 大伊人狠狠躁夜夜躁av一区| 久久久国产精品亚洲一区| 国产裸体写真av一区二区| 欧美特黄级在线| 亚洲精品国产电影| 亚洲精品aⅴ中文字幕乱码| 精品国产依人香蕉在线精品| 亚洲人在线观看| 日韩亚洲欧美成人| 91精品国产精品| 久热精品在线视频| 欧美色另类天堂2015| 国产亚洲福利一区| 亚洲国产天堂久久综合| 国内免费久久久久久久久久久| 欧洲成人在线观看| 国产精品99久久久久久人| 精品视频—区二区三区免费| 中文字幕少妇一区二区三区| 久久在线免费观看视频| 国产精品天天狠天天看| 欧美亚洲另类制服自拍| 91青草视频久久| 亚洲成av人片在线观看香蕉| 91av在线播放视频| 国产suv精品一区二区三区88区| 国产精品久久久久一区二区| 亚洲第一色中文字幕| 日韩一区av在线| 狠狠色狠色综合曰曰| 欧美成人免费播放| www.色综合| 欧美体内谢she精2性欧美| 亚洲电影第1页| 欧美成人精品xxx| 91高清免费在线观看| 国产亚洲免费的视频看| 亚洲人成77777在线观看网| 一本色道久久88精品综合| 亚洲综合中文字幕在线观看| 欧美激情手机在线视频| 国产999在线| 亚洲欧美国产va在线影院| 久久99热精品这里久久精品| 亚洲美女av在线| 欧美日韩综合视频网址| 91精品视频免费看| 亚洲精品视频在线播放| 日日摸夜夜添一区| 欧美日韩国产精品一区| 国产成人短视频| 国产大片精品免费永久看nba| 久久久久久久久久久人体| 久久偷看各类女兵18女厕嘘嘘| 91日本视频在线| 精品国内产的精品视频在线观看| 岛国av一区二区在线在线观看| 5566成人精品视频免费| 国产亚洲欧美另类中文| 成人午夜高潮视频| 久久亚洲综合国产精品99麻豆精品福利| 自拍亚洲一区欧美另类| 欧洲成人免费aa| 亚洲国产另类 国产精品国产免费| 亚洲国模精品一区| 国产精品ⅴa在线观看h| 亚洲人成电影网站| 日韩av日韩在线观看| 91在线高清视频| 欧美成人午夜免费视在线看片| 日韩网站免费观看| 亚洲精选在线观看| 欧美亚洲激情在线| 伊人久久免费视频| 在线成人激情黄色| 亚洲第一精品电影| 日韩免费观看在线观看| 久久久91精品国产| 中文字幕亚洲欧美在线| 精品毛片三在线观看| 国产成人短视频| 黑人巨大精品欧美一区二区三区| 国产精品福利在线观看| 亚洲第一黄色网| 欧美一区二粉嫩精品国产一线天| 欧美亚洲成人xxx| 国产精品视频精品视频| 国产一区二区丝袜高跟鞋图片| 日韩美女视频中文字幕| 日韩国产高清污视频在线观看| 国产69精品久久久久9999| 成人免费网站在线看| 成人午夜高潮视频| 欧美激情在线播放| 国产日韩欧美中文| 欧美另类暴力丝袜| 亚洲电影免费观看高清| 久久精品中文字幕一区| 亚洲精品资源美女情侣酒店| 国产精品国产自产拍高清av水多| 亚洲系列中文字幕| 69久久夜色精品国产7777| 欧美亚洲国产精品| 韩国三级电影久久久久久| 91系列在线播放| 成人日韩av在线| 欧美午夜性色大片在线观看| 亚洲va欧美va国产综合剧情| 日韩在线观看免费高清| 福利一区福利二区微拍刺激| 亚洲久久久久久久久久| 69**夜色精品国产69乱| 国产精品第一页在线| 欧美精品激情视频| 亚洲女人天堂成人av在线| 久久综合88中文色鬼| 91精品国产91久久| 中文字幕不卡av| 日韩三级成人av网| 一区二区三区精品99久久|