sort 是將文件的每一行作為一個(gè)單位,相互比較,比較原則是從首字符向后,依次按照ASCII碼值進(jìn)行比較,默認(rèn)將他們按照升序輸出
網(wǎng)站建設(shè)哪家好,找成都創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、小程序開發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了新邱免費(fèi)建站歡迎大家使用!
降序
在輸出中去重
將排序結(jié)果輸出到原文件
sort的默認(rèn)輸出是輸出到標(biāo)準(zhǔn)輸出,如果想把結(jié)果輸出到文件,需要 sort file newfile,但是如果想把結(jié)果輸出到原文件這樣就不行了,這時(shí)就需要 使用sort -o
以數(shù)值來排序
sort 默認(rèn)是按照字符串排序的,這樣就會出現(xiàn)10比3小的情況,sort -n 就可以告訴sort 以整數(shù)排序
-t 后面跟 分隔符
-k 后面跟數(shù)字,表示用第幾列排序
如 sort -t : -k 2 表示把每行 以:號分割,按照第二列排序
banana:30:5.5
orange:20:3.4
apple:10:2.5
我們可以看到,當(dāng)baidu 和soho都是100的時(shí)候,baidu排在前面,當(dāng)當(dāng)前域按照默認(rèn)規(guī)矩,是從第一個(gè)域開始進(jìn)行升序排序,因此baidu排在了sohu前面。
sort 支持 -k 2 -k3這種模式,如果你需要,你可以繼續(xù)這么寫下去
你仔細(xì)看看,在-k 3后面偷偷加上了一個(gè)小寫字母r,r和-r的作用是一樣,你也可以把前面的-n去掉 在r后面加上n,如下
其實(shí)-k 選項(xiàng) 功能很強(qiáng)大,語法[ FStart [ .CStart ] ] [ Modifier ] [ , [ FEnd [ .CEnd ] ][ Modifier ] ]
從逗號前后 分為兩大部分,即-k 2,2,是嚴(yán)格使用第一個(gè)域排序,如果只設(shè)置-k 2 其實(shí)是按照從第一個(gè)域到行尾。逗號分開的每部分又有一個(gè)點(diǎn)表示子域,即-k 1.2表示 按照第一個(gè)域的第二個(gè)字符排序,Modifiers就是我們用到的n和r 如 -k 1.2nr 具體我們看下面的例子。
我們使用了-k 1.2,這就表示對第一個(gè)域的第二個(gè)字符開始到本域的最后一個(gè)字符為止的字符串進(jìn)行排序。你會發(fā)現(xiàn)baidu因?yàn)榈诙€(gè)字母是a而名列榜首。sohu和 google第二個(gè)字符都是o,但sohu的h在google的o前面,所以兩者分別排在第二和第三。這和之前說到的按照默認(rèn)的排序規(guī)則 是不同的,當(dāng)?shù)谝粋€(gè)域的第二個(gè)字符相同時(shí),他不會去按照第一個(gè)字符排序,而是按照后面的字符排序,這是因?yàn)?k 1.2是對第一個(gè)域的第二個(gè)字符開始到本域的最后一個(gè)字符為止的字符串進(jìn)行排序。而之前的夸域其實(shí)是一種假象。
-u只識別用-k設(shè)定的域,發(fā)現(xiàn)相同,就將后續(xù)相同的行都刪除
但是這時(shí)候,卻一行也沒有刪除。原來-u是會權(quán)衡所有-k選項(xiàng),將都相同的才會刪除,只要其中有一級不同都不會輕易刪除的
可以用到b、d、f、i、n 或 r。
其中n和r你肯定已經(jīng)很熟悉了。
b表示忽略本域的簽到空白符號。
d表示對本域按照字典順序排序(即,只考慮空白和字母)。
f表示對本域忽略大小寫進(jìn)行排序。
i表示忽略“不可打印字符”,只針對可打印字符進(jìn)行排序。(有些ASCII就是不可打印字符,比如\a是報(bào)警,\b是退格,\n是換行,\r是回車等等)
Linux存在著許多不同的Linux版本,但它們都使用了Linux內(nèi)核。Linux可安裝在各種計(jì)算機(jī)硬件設(shè)備中,比如手機(jī)、平板電腦、路由器、視頻游戲控制臺、臺式計(jì)算機(jī)、大型機(jī)和超級計(jì)算機(jī)。下面讓我們一起去了解Linux TOP命令 按內(nèi)存占用排序和按CPU占用排序。
Linux TOP命令 按內(nèi)存占用排序和按CPU占用排序:
:在命令行提示符執(zhí)行top命令
2:輸入大寫P,則結(jié)果按CPU占用降序排序。輸入大寫M,結(jié)果按內(nèi)存占用降序排序。(注:大寫P可以在capslock狀態(tài)輸入p,或者按Shift+p)
另外:
認(rèn)識top的顯示結(jié)果
top命令的顯示結(jié)果如下所示:
top - 01:06:48 up 1:22, 1 user, load average: 0.06, 0.60, 0.48 Tasks: 29 total, 1 running, 28 sleeping, 0 stopped, 0 zombie Cpu(s): 0.3% us, 1.0% sy, 0.0% ni, 98.7% id, 0.0% wa, 0.0% hi, 0.0% si Mem: 191272k total, 173656k used, 17616k free, 22052k buffers Swap: 192772k total, 0k used, 192772k free, 123988k cached PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 1379 root 16 0 7976 2456 1980 S 0.7 1.3 0:11.03 sshd 14704 root 16 0 2128 980 796 R 0.7 0.5 0:02.72 top 1 root 16 0 1992 632 544 S 0.0 0.3 0:00.90 init 2 root 34 19 0 0 0 S 0.0 0.0 0:00.00 ksoftirqd/0 3 root RT 0 0 0 0 S 0.0 0.0 0:00.00 watchdog/0統(tǒng)計(jì)信息區(qū)
前五行是系統(tǒng)整體的統(tǒng)計(jì)信息。第一行是任務(wù)隊(duì)列信息,同 uptime 命令的執(zhí)行結(jié)果。其內(nèi)容如下:
01:06:48當(dāng)前時(shí)間
up 1:22系統(tǒng)運(yùn)行時(shí)間,格式為時(shí):分
1 user當(dāng)前登錄用戶數(shù)
load average: 0.06, 0.60, 0.48系統(tǒng)負(fù)載,即任務(wù)隊(duì)列的平均長度。
三個(gè)數(shù)值分別為 1分鐘、5分鐘、15分鐘前到現(xiàn)在的平均值。
第二、三行為進(jìn)程和CPU的信息。當(dāng)有多個(gè)CPU時(shí),這些內(nèi)容可能會超過兩行。內(nèi)容如下:
Tasks: 29 total進(jìn)程總數(shù)
1 running正在運(yùn)行的進(jìn)程數(shù)
28 sleeping睡眠的進(jìn)程數(shù)
0 stopped停止的進(jìn)程數(shù)
0 zombie僵尸進(jìn)程數(shù)
Cpu(s): 0.3% us用戶空間占用CPU百分比
1.0% sy內(nèi)核空間占用CPU百分比
0.0% ni用戶進(jìn)程空間內(nèi)改變過優(yōu)先級的進(jìn)程占用CPU百分比
98.7% id空閑CPU百分比
0.0% wa等待輸入輸出的CPU時(shí)間百分比
0.0% hi
0.0% si
最后兩行為內(nèi)存信息。內(nèi)容如下:
Mem: 191272k total物理內(nèi)存總量
173656k used使用的物理內(nèi)存總量
17616k free空閑內(nèi)存總量
22052k buffers用作內(nèi)核緩存的內(nèi)存量
Swap: 192772k total交換區(qū)總量
0k used使用的交換區(qū)總量
192772k free空閑交換區(qū)總量
123988k cached緩沖的交換區(qū)總量。
內(nèi)存中的內(nèi)容被換出到交換區(qū),而后又被換入到內(nèi)存,但使用過的交換區(qū)尚未被覆蓋,
該數(shù)值即為這些內(nèi)容已存在于內(nèi)存中的交換區(qū)的大小。
相應(yīng)的內(nèi)存再次被換出時(shí)可不必再對交換區(qū)寫入。
進(jìn)程信息區(qū)
統(tǒng)計(jì)信息區(qū)域的下方顯示了各個(gè)進(jìn)程的詳細(xì)信息。首先來認(rèn)識一下各列的含義。
序號列名含義
aPID進(jìn)程id
bPPID父進(jìn)程id
cRUSERReal user name
dUID進(jìn)程所有者的用戶id
eUSER進(jìn)程所有者的用戶名
fGROUP進(jìn)程所有者的組名
gTTY啟動進(jìn)程的終端名。不是從終端啟動的進(jìn)程則顯示為 ?
hPR優(yōu)先級
iNInice值。負(fù)值表示高優(yōu)先級,正值表示低優(yōu)先級
jP最后使用的CPU,僅在多CPU環(huán)境下有意義
k%CPU上次更新到現(xiàn)在的CPU時(shí)間占用百分比
lTIME進(jìn)程使用的CPU時(shí)間總計(jì),單位秒
mTIME+進(jìn)程使用的CPU時(shí)間總計(jì),單位1/100秒
n%MEM進(jìn)程使用的物理內(nèi)存百分比
oVIRT進(jìn)程使用的虛擬內(nèi)存總量,單位kb。VIRT=SWAP+RES
pSWAP進(jìn)程使用的虛擬內(nèi)存中,被換出的大小,單位kb。
qRES進(jìn)程使用的、未被換出的物理內(nèi)存大小,單位kb。RES=CODE+DATA
rCODE可執(zhí)行代碼占用的物理內(nèi)存大小,單位kb
sDATA可執(zhí)行代碼以外的部分(數(shù)據(jù)段+棧)占用的物理內(nèi)存大小,單位kb
tSHR共享內(nèi)存大小,單位kb
unFLT頁面錯(cuò)誤次數(shù)
vnDRT最后一次寫入到現(xiàn)在,被修改過的頁面數(shù)。
wS進(jìn)程狀態(tài)。
D=不可中斷的睡眠狀態(tài)
R=運(yùn)行
S=睡眠
T=跟蹤/停止
Z=僵尸進(jìn)程
xCOMMAND命令名/命令行
yWCHAN若該進(jìn)程在睡眠,則顯示睡眠中的系統(tǒng)函數(shù)名
zFlags任務(wù)標(biāo)志,參考 sched.h
默認(rèn)情況下僅顯示比較重要的 PID、USER、PR、NI、VIRT、RES、SHR、S、%CPU、%MEM、TIME+、COMMAND 列。可以通過下面的快捷鍵來更改顯示內(nèi)容。
更改顯示內(nèi)容
通過 f 鍵可以選擇顯示的內(nèi)容。按 f 鍵之后會顯示列的列表,按 a-z 即可顯示或隱藏對應(yīng)的列,最后按回車鍵確定。
按 o 鍵可以改變列的顯示順序。按小寫的 a-z 可以將相應(yīng)的列向右移動,而大寫的 A-Z 可以將相應(yīng)的列向左移動。最后按回車鍵確定。
按大寫的 F 或 O 鍵,然后按 a-z 可以將進(jìn)程按照相應(yīng)的列進(jìn)行排序。而大寫的 R 鍵可以將當(dāng)前的排序倒轉(zhuǎn)。
sort命令是對文件進(jìn)行排序,并將排序的結(jié)果輸出到屏幕,不影響原文件
以行為單位,將每一行作為一個(gè)單位,相互比較,比較原則是從首字符向后,以此按ASCII碼進(jìn)行比較,最后升序輸出
參數(shù)
-b 忽略每行前面開始處的空格
-d 只按照英文字母,數(shù)字,空格字符排序,忽略其他字符
-m 將幾個(gè)排序好的文件進(jìn)行合并
-n 依照數(shù)值的大小進(jìn)行排序,如果是按照數(shù)值大小排序一定要加 -n ,否則就會出現(xiàn) 10 比2 小的情況,因?yàn)槟J(rèn)比較數(shù)值是先比較第1位的,后面的位不考慮
-o 將排序好的結(jié)果輸出到文件, 也可以使用重定向符號 輸出到文件中
-r 以相反的順序來排序, 默認(rèn)是升序
文章名稱:linux下排序的命令 linux系統(tǒng)排序命令
當(dāng)前路徑:http://jinyejixie.com/article48/doscphp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供響應(yīng)式網(wǎng)站、定制開發(fā)、微信公眾號、企業(yè)網(wǎng)站制作、網(wǎng)站內(nèi)鏈、網(wǎng)站策劃
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)