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

Prayer

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

本原創(chuàng)文章屬于《Linux大棚》博客,博客地址為http://roclinux.cn。文章作者為rocrocket。

為了防止某些網(wǎng)站的惡性轉(zhuǎn)載,特在每篇文章前加入此信息,還望讀者體諒。

===

[正文開始]
有時(shí)候?qū)W習(xí)腳本,你會(huì)發(fā)現(xiàn)sort命令后面跟了一堆類似-k1,2,或者-k1.2 -k3.4的東東,有些匪夷所思。今天,我們就來搞定它—-k選項(xiàng)!

1 準(zhǔn)備素材

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

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

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

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

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

3 我想讓facebook.txt按照公司人數(shù)排序

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

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

但是,此處出現(xiàn)了問題,那就是baidu和sohu的公司人數(shù)相同,都是100人,這個(gè)時(shí)候怎么辦呢?按照默認(rèn)規(guī)矩,是從第一個(gè)域開始進(jìn)行升序排序,因此baidu排在了sohu前面。

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

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

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

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

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

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

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

看,我們?nèi)サ袅俗钋懊娴?n選項(xiàng),而是將它加入到了每一個(gè)-k選項(xiàng)中了。

6 -k選項(xiàng)的具體語法格式

要繼續(xù)往下深入的話,就不得不來點(diǎn)理論知識(shí)。你需要了解-k選項(xiàng)的語法格式,如下:

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

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

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

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

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

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

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

7 突發(fā)奇想,從公司英文名稱的第二個(gè)字母開始進(jìn)行排序:

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

看,我們使用了-k 1.2,這就表示對(duì)第一個(gè)域的第二個(gè)字符開始到本域的最后一個(gè)字符為止的字符串進(jìn)行排序。你會(huì)發(fā)現(xiàn)baidu因?yàn)榈诙€(gè)字母是a而名列榜首。sohu和google第二個(gè)字符都是o,但sohu的h在google的o前面,所以兩者分別排在第二和第三。guge只能屈居第四了。

8 又突發(fā)奇想,,只針對(duì)公司英文名稱的第二個(gè)字母進(jìn)行排序,如果相同的按照員工工資進(jìn)行降序排序:

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

由于只對(duì)第二個(gè)字母進(jìn)行排序,所以我們使用了-k 1.2,1.2的表示方式,表示我們“只”對(duì)第二個(gè)字母進(jìn)行排序。(如果你問“我使用-k 1.2怎么不行?”,當(dāng)然不行,因?yàn)槟闶÷粤薊nd部分,這就意味著你將對(duì)從第二個(gè)字母起到本域最后一個(gè)字符為止的字符串進(jìn)行排序)。對(duì)于員工工資進(jìn)行排序,我們也使用了-k 3,3,這是最準(zhǔn)確的表述,表示我們“只”對(duì)本域進(jìn)行排序,因?yàn)槿绻闶÷粤撕竺娴?,就變成了我們“對(duì)第3個(gè)域開始到最后一個(gè)域位置的內(nèi)容進(jìn)行排序”了。

9 在modifier部分還可以用到哪些選項(xiàng)?

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

其中n和r你肯定已經(jīng)很熟悉了。

b表示忽略本域的簽到空白符號(hào)。

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

f表示對(duì)本域忽略大小寫進(jìn)行排序。

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

10 思考思考關(guān)于-k和-u聯(lián)合使用的例子:

$ 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

當(dāng)設(shè)定以公司員工域進(jìn)行數(shù)值排序,然后加-u后,sohu一行就被刪除了!原來-u只識(shí)別用-k設(shè)定的域,發(fā)現(xiàn)相同,就將后續(xù)相同的行都刪除。

$ 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è)例子也同理,開頭字符是g的guge就沒有幸免于難。

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

咦!這里設(shè)置了兩層排序優(yōu)先級(jí)的情況下,使用-u就沒有刪除任何行。原來-u是會(huì)權(quán)衡所有-k選項(xiàng),將都相同的才會(huì)刪除,只要其中有一級(jí)不同都不會(huì)輕易刪除的:)(不信,你可以自己加一行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

以第二個(gè)域的第二個(gè)字符開始到第三個(gè)域的第一個(gè)字符結(jié)束的部分進(jìn)行排序。

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

又因?yàn)閟ort認(rèn)為0小于00小于000小于0000….

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

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

$ 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 有時(shí)候在sort命令后會(huì)看到+1 -2這些符號(hào),這是什么東東?

關(guān)于這種語法,最新的sort是這么進(jìn)行解釋的:

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.

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

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

結(jié)束語:

本文是互聯(lián)網(wǎng)上僅有的比較全的關(guān)于sort的k選項(xiàng)的論述文章,如需轉(zhuǎn)載請(qǐng)務(wù)必注明“轉(zhuǎn)自Linux大棚-Linux主題博客”,謝謝各位:)

sort的-k選項(xiàng)基本就是這堆內(nèi)容了,如果大家有什么補(bǔ)充,就留言吧:) 歡迎交流!

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            91久久久久久| 欧美欧美天天天天操| 亚洲欧美一区二区三区在线| 日韩午夜在线视频| 亚洲精品一区二区三区av| 亚洲黑丝一区二区| 毛片一区二区| 欧美不卡视频| 欧美精品九九| 欧美午夜精品理论片a级大开眼界| 欧美视频一区二区三区四区| 欧美日韩专区在线| 国产精品女主播一区二区三区| 国产精品久久久99| 国产精品专区h在线观看| 国产一区二区三区高清在线观看| 激情亚洲一区二区三区四区| 亚洲国产欧美一区二区三区丁香婷| 亚洲精品欧洲| 性欧美大战久久久久久久久| 久久蜜桃精品| 精品1区2区| 久久久精品视频成人| 久久黄色级2电影| 欧美国产日韩一二三区| 欧美日韩中文精品| 韩国精品久久久999| 亚洲免费av电影| 小嫩嫩精品导航| 欧美不卡视频一区发布| 日韩写真在线| 久久免费99精品久久久久久| 欧美色视频在线| 欧美精品一二三| 国产日韩欧美黄色| 亚洲精品永久免费精品| 欧美中文字幕| 亚洲精品永久免费| 久久精品视频免费播放| 国产精品v欧美精品∨日韩| 国内精品久久久久久久影视麻豆 | 久久精品国产综合| 欧美日韩亚洲视频| 国产伦一区二区三区色一情| 亚洲人线精品午夜| 久久久久久亚洲精品杨幂换脸| 亚洲每日在线| 欧美mv日韩mv亚洲| 国产日韩在线不卡| 亚洲香蕉网站| 亚洲欧洲精品成人久久奇米网| 欧美一级专区免费大片| 欧美午夜不卡视频| 亚洲人成欧美中文字幕| 美女久久一区| 亚洲综合久久久久| 欧美日一区二区三区在线观看国产免 | 中文欧美字幕免费| 亚洲激情网站免费观看| 免费成人黄色片| 黄色精品一二区| 欧美一区日本一区韩国一区| 日韩一区二区电影网| 欧美激情aⅴ一区二区三区| 亚洲观看高清完整版在线观看| 久久久久久久久久久一区| 亚洲新中文字幕| 国产精品久久久久999| 亚洲婷婷综合色高清在线| 亚洲乱码国产乱码精品精| 欧美精品在线免费| 亚洲精品影院在线观看| 欧美尤物巨大精品爽| 欧美高清日韩| 亚洲午夜精品国产| 日韩视频一区二区三区在线播放免费观看| 久久久www| 在线欧美福利| 欧美激情第六页| 欧美激情在线免费观看| 99成人在线| 亚洲最黄网站| 国产精品毛片高清在线完整版| 欧美一区成人| 久久久久久久久久看片| 亚洲缚视频在线观看| 91久久精品美女高潮| 国产精品v日韩精品v欧美精品网站| 欧美一区二区三区免费观看视频| 久久精品国产999大香线蕉| 亚洲人午夜精品| 亚洲欧美大片| 亚洲国产天堂久久综合网| 艳女tv在线观看国产一区| 好看的亚洲午夜视频在线| 亚洲国产裸拍裸体视频在线观看乱了中文 | 在线性视频日韩欧美| 亚洲欧美激情在线视频| 狠狠88综合久久久久综合网| 欧美激情精品久久久久久免费印度 | 99在线精品视频| 欧美婷婷久久| 欧美一区二区成人6969| 欧美在线影院| 亚洲欧洲视频| 一本色道久久综合亚洲精品高清| 欧美一级久久久| 亚洲神马久久| 性欧美18~19sex高清播放| 国产一区二区三区在线观看视频| 久久免费视频在线| 美女精品在线| 亚洲永久免费视频| 亚洲一级黄色av| 亚洲人成人77777线观看| av不卡在线观看| 国产一区美女| 亚洲欧洲日本一区二区三区| 国产精品你懂的| 99精品欧美一区二区蜜桃免费| 亚洲欧美日韩网| 欧美在线欧美在线| 亚洲国产精品高清久久久| 亚洲人成欧美中文字幕| 国产精品视频久久| 亚洲电影在线看| 国产午夜精品在线| 日韩天堂在线视频| ●精品国产综合乱码久久久久| 一个色综合av| 国产亚洲激情视频在线| 亚洲欧美成人综合| 日韩视频中午一区| 欧美制服第一页| 亚洲一区3d动漫同人无遮挡| 久久综合给合| 亚洲欧美成人精品| 美女国产一区| 久久精品人人做人人综合 | 一区二区欧美日韩视频| 一区在线视频观看| 亚洲精品国产精品乱码不99按摩| 亚洲国产裸拍裸体视频在线观看乱了中文 | 亚洲电影在线看| 韩日视频一区| 亚洲小说欧美另类婷婷| 一区二区三区视频在线播放| 久久综合电影| 乱中年女人伦av一区二区| 国产精品久久久久久久久久直播 | 国内视频精品| 亚洲精品一品区二品区三品区| 一区二区三区精品视频| 狂野欧美激情性xxxx| 久久久久久国产精品一区| 国产精品久久久久77777| 一区二区国产精品| 亚洲视频精选在线| 欧美精品一区二区三区在线看午夜| 免费成人美女女| 精品成人在线| 久久精品在线播放| 欧美制服丝袜| 欧美国产成人在线| 一区二区动漫| 欧美成熟视频| 欧美成人精品福利| 亚洲成人自拍视频| 另类图片国产| 欧美激情一区二区三区四区| 国产中文一区| 欧美专区在线观看一区| 欧美一区二区三区四区视频 | 亚洲开发第一视频在线播放| 久久精品中文字幕免费mv| 欧美视频官网| 国产精品99久久久久久久vr| 久久精品在线视频| 在线观看视频欧美| 久久影院亚洲| 亚洲区第一页| 亚洲夜晚福利在线观看| 国产精品乱码一区二区三区| 亚洲日本中文字幕免费在线不卡| 欧美一级视频| 伊人久久大香线蕉av超碰演员| 麻豆精品传媒视频| 亚洲区国产区| 欧美在线关看| 国产精品一区二区久久| 欧美国产综合一区二区| 一区二区三区福利| 久久婷婷激情| 99精品国产在热久久| 国产精品一区二区三区四区 | 国产伦一区二区三区色一情| 欧美精品一卡| 久久精品国产免费| 日韩写真在线| 久久综合色播五月|