青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Prayer

在一般中尋求卓越
posts - 1256, comments - 190, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

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

1 準備素材

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

$ sort -t ‘ ‘ -k 3nr -k 2n facebook.txt
baidu 100 5000
google 110 5000
sohu 100 4500
guge 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.txt
baidu 100 5000
sohu 100 4500
google 110 5000
guge 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.txt
baidu 100 5000
google 110 5000
sohu 100 4500
guge 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.txt
google 110 5000
baidu 100 5000
guge 50 3000
sohu 100 4500

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

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

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

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

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

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

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

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

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

11 最詭異的排序:

$ sort -n -k 2.2,3.1 facebook.txt
guge 50 3000
baidu 100 5000
sohu 100 4500
google 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.txt
guge 50 3000
sohu 100 4500
baidu 100 5000
google 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個字符。明白?)

結束語:

本文是互聯網上僅有的比較全的關于sort的k選項的論述文章,如需轉載請務必注明“轉自Linux大棚-Linux主題博客”,謝謝各位:)

sort的-k選項基本就是這堆內容了,如果大家有什么補充,就留言吧:) 歡迎交流!

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲精品欧美精品| 亚洲国产一区二区三区a毛片| 尤妮丝一区二区裸体视频| 亚洲一区二区三区在线播放| 亚洲第一天堂av| 久久国产精品99国产| 久久精品国产免费| 国内视频一区| 久久久久久有精品国产| 亚洲女ⅴideoshd黑人| 欧美精品成人在线| aa级大片欧美三级| 亚洲区中文字幕| 欧美日本一道本| 一区二区三区免费观看| 亚洲精选视频在线| 欧美日韩免费观看中文| 亚洲视频专区在线| 亚洲精品影视在线观看| 欧美精品在线免费观看| 亚洲免费电影在线| 99精品国产热久久91蜜凸| 欧美日韩一区二区三区| 亚洲视频香蕉人妖| 亚洲欧美不卡| 国产真实久久| 欧美黄色免费| 欧美日本在线| 欧美一级淫片播放口| 亚洲欧美在线x视频| 激情五月婷婷综合| 亚洲国产成人av| 免费观看30秒视频久久| 一区二区黄色| 欧美一区二区网站| 亚洲国产成人91精品| 亚洲国产综合视频在线观看| 欧美日韩福利| 亚洲一区二区三区精品视频| 午夜亚洲视频| 亚洲国内自拍| 亚洲国产高清一区| 国产精品一级| 欧美搞黄网站| 欧美日韩一区二区三区免费看 | 久久精品国产亚洲a| 欧美中文字幕视频| 99热免费精品| 校园春色国产精品| 99v久久综合狠狠综合久久| 亚洲一区二区三区免费在线观看 | 一本大道av伊人久久综合| 欧美视频国产精品| 久久综合狠狠综合久久综合88| 欧美成人69| 香蕉亚洲视频| 欧美福利电影在线观看| 久久精品国产综合精品| 久久一区中文字幕| 欧美亚洲免费电影| 欧美激情无毛| 欧美阿v一级看视频| 国产精品手机视频| 亚洲精品在线免费| 国产综合精品| 亚洲性线免费观看视频成熟| 亚洲日韩第九十九页| 欧美一区二区网站| 性一交一乱一区二区洋洋av| 欧美日韩国产一区精品一区| 免费一级欧美片在线观看| 国产精品成人v| 亚洲区一区二| 亚洲激情女人| 久久精品一本久久99精品| 亚洲综合社区| 国产美女精品免费电影| 午夜精品福利电影| 欧美在线首页| 激情另类综合| 欧美va天堂| 亚洲每日更新| 亚洲欧美美女| 国产女精品视频网站免费| 午夜一区在线| 另类图片国产| 99这里只有精品| 欧美亚州一区二区三区| 亚洲免费影视第一页| 久久婷婷av| 亚洲三级影院| 欧美三区在线| 欧美一区二区在线免费播放| 玖玖视频精品| 在线一区欧美| 国产日韩欧美三级| 免费观看成人www动漫视频| 亚洲精品国产精品国自产观看| 亚洲一区二区欧美日韩| 国模一区二区三区| 欧美激情精品久久久久久蜜臀| 99精品视频免费| 久久精品五月| 99精品热6080yy久久| 国产精品亚洲成人| 久久综合狠狠综合久久激情| 日韩亚洲欧美一区| 久久国产乱子精品免费女| 亚洲欧洲一二三| 国产精品一区一区| 欧美国产日韩在线观看| 亚洲专区一二三| 亚洲国产裸拍裸体视频在线观看乱了 | 欧美韩国日本综合| 亚洲一区国产| 亚洲电影专区| 国产精品久久中文| 你懂的视频欧美| 欧美一区二区在线观看| 亚洲日韩欧美视频一区| 久久久亚洲国产天美传媒修理工 | 国产欧美日韩一区| 欧美日韩精品在线播放| 欧美一区二区三区啪啪| 99v久久综合狠狠综合久久| 免费观看成人www动漫视频| 亚洲欧美色一区| 一本久久青青| 亚洲欧洲视频在线| 在线播放视频一区| 国产美女精品免费电影| 欧美午夜a级限制福利片| 麻豆成人综合网| 久久久久一区二区三区| 羞羞色国产精品| 在线一区二区三区四区| 亚洲黄色小视频| 亚洲承认在线| 欧美激情一二三区| 欧美成人激情在线| 奶水喷射视频一区| 久久久噜噜噜| 久久天天躁狠狠躁夜夜av| 午夜精品三级视频福利| 亚洲午夜一二三区视频| 一区二区三欧美| 一区二区日韩精品| 中文一区在线| 亚洲一区中文字幕在线观看| 一本大道久久a久久精二百| 亚洲精品护士| 一本色道久久综合亚洲精品婷婷| 亚洲欧洲精品一区二区精品久久久| 激情六月综合| 亚洲国产精品久久久久婷婷884 | 黄色国产精品一区二区三区| 国产一区二区三区观看| 国产麻豆日韩欧美久久| 国产精品系列在线播放| 国产午夜精品一区二区三区欧美| 国产精品人人做人人爽| 国产伦精品一区二区三区高清| 国产精品亚洲精品| 国产主播精品| 91久久嫩草影院一区二区| 日韩视频在线你懂得| 在线性视频日韩欧美| 性欧美1819性猛交| 久久久久免费视频| 欧美韩日一区二区| 日韩小视频在线观看专区| 亚洲性感激情| 久久先锋影音av| 欧美日韩国产a| 国产日韩精品一区| 亚洲二区精品| 中文精品视频一区二区在线观看| 欧美亚洲在线观看| 欧美国产亚洲精品久久久8v| 亚洲乱码国产乱码精品精| 亚洲影视在线| 久热re这里精品视频在线6| 欧美精品一区二区视频| 国产精品久久网站| 91久久精品视频| 亚洲欧美精品suv| 欧美成人激情在线| 亚洲永久免费av| 免费成人av资源网| 国产嫩草一区二区三区在线观看| 亚洲国产精品久久久久秋霞蜜臀| 亚洲一区二区三区四区视频| 久久久久免费| 亚洲视频免费观看| 麻豆成人综合网| 国产日韩精品一区二区浪潮av| 亚洲精品一区二区三区樱花| 久久九九精品| 亚洲一区二区三区四区五区午夜| 久久久久国产一区二区|