① linux,怎麼把文本里的ip按列排序
function random() { min=$1; max=$2-$1; num=$(date +%s+%N); ((retnum=num%max+min)); echo $retnum; } n=`wc -l ipfile` #獲慎粗取文件ip數寬或鎮 out=$(random 1 n); echo `sed -n "$out,$out p"團拿 ipfile`
② 如何列出linux的文件目錄和所有的文件
顯示目錄文件用linux中ls命令
ls
命令可以說是linux下最常用的命令之一。
-a
列出目錄下的所有文件,包括以
.
開頭的隱含文件。
-b
把文件名中不可輸出的字元用反斜杠加字元編號(就象在C語言里一樣)的形式列出。
-c
輸出文件的
i
節點的修改時間,並以此排序。
-d
將目錄象文件一樣顯示,而不是顯示其下的文件。
-e
輸出時間的全部信息,而不是輸出簡略信息。
-f
-U
對輸出的文件不排序。
-g
無用。
-i
輸出文件的
i
節點的索引信息。
-k
以
k
位元組的形式表示文件的大小。
-l
列出文件的詳細信息。
-m
橫向輸出文件名,並以「,」作分格符。
-n
用數字的
UID,GID
代替名稱。
-o
顯示文件的除組信息外的詳細信息。
-p
-F
在每個文件名後附上一個字元以說明該文件的類型,「*」表示可執行的普通
文件;「/」表示目錄;「@」表示符號鏈接;「|」表示FIFOs;「=」表示套
接字(sockets)。
-q
用?代替不可輸出的字元。
-r
對目錄反向排序。
-s
在每個文件名後輸出該文件的大小。
-t
以時間排序。
-u
以文件上次被訪問的時間排序。
-x
按列輸出,橫向排序。
-A
顯示除
「.」和「..」外的所有文件告頃。
-B
不輸出以
「~」結尾的備份文件。
-C
按列輸出,縱向排序。
-G
輸出文件的組的信息。
-L
列出鏈埋友或接文件名而不是鏈接到的文件。
-N
不限制文件長度。
-Q
把輸出的文件名用雙引號括起來。
-R
列出所有子目錄下的文件。
-S
以文件大彎伍小排序。
-X
以文件的擴展名(最後一個
.
後的字元)排序。
-1
一行只輸出一個文件。
--color=no
不顯示彩色文件名
--help
在標准輸出上顯示幫助信息。
--version
在標准輸出上輸出版本信息並退出。
只列出子目錄
1.
ls
-F
|
grep
/$
或者
alias
sub
=
"ls
-F
|
grep
/$"(linux)
2.
ls
-l
|
grep
"^d"
或者
ls
-lL
|
grep
"^d"
(Solaris)
計算當前目錄下的文件數和目錄數
下面命令可以分別計算當前目錄下的文件和目錄個數:
#
ls
-l
*
|grep
"^-"|wc
-l
----
to
count
files
#
ls
-l
*
|grep
"^d"|wc
-l
--
to
count
dir
顯示彩色目錄列表
打開/etc/bashrc,
加入如下一行:
alias
ls="ls
--color"
③ 如何利用 linux 命令對結果文件 result1.sam 按照第 4 列進行排序
可以用awk配合sort命令
awk '{print $4}' | sort
④ 在linux系統中,ls命令下,如何按文件類型排列
沒有按類型排列
只有按文件大小排列
ls - S
⑤ 在linux中sort命令如何對指定列進行排序
sort -k 3 yourfile.txt
這種問題查枯搭看手冊是最方困扮便了. 你在命汪敗灶令行下運行 man sort 看看它的幫助, 很詳細.
⑥ linux sort 命令整理
無論是工作中使用還是應付各種面試,linux sort 都是必須要掌握的 linux 基本命令之一。尤其是 linux sort -k 命令,經常會被搞暈,索性好好研究一下 sort 命令
語法:
選項:
參數就不一一介紹了,直接上例子,首先先看下原始的排序數據
cat sort.log
1、列印從哪列開始是亂序
sort -c sort.log; echo $?
sort -C sort.log; echo $?
其中,返回結果 1,表示文件不是已經排序好的文件
2、默認排序( 整行進行ASCII字元升序)
sort sort.log
3、高能來了,讓人迷糊的 k 語法,首先看下 k 的語法格式
這個語法格式可以被其中的逗號(」,」)分為兩大部分,Start部分和End部分
Start和End部分都由三部分組成,其中的Modifier部分就是類似n和r的選項部分,可省略
FStart、Fend,表示使用的域,而CStart則表示在FStart域中從第幾個字元開始算"排序首字元",同理,CEnd表示結尾的第幾個字元是排序末尾字元,.CStart、.CEnd是可以省略的,分別表示從本域的開頭部分開始、到本域的域尾結束,CEnd設定為0,也是表示結尾到域尾。口說無憑,上幾個例子吧
3.1 對第三列進行排序,如果不加n,按照 ASCII字元排序
sort -t $' ' -k 3 sort.log
3.2 加n後,按照數值排序
sort -t $' ' -k 3n sort.log
3.3 不指定 FEnd 時,多個 -k 從前往後排序可以,從後往前不行
從後往前,多個 -k,數據符合預期
sort -t $' ' -k 3n -k 1 sort.log
從後往前,多個 -k ,第三列相同時,按照第一列降序排列,數據符合預期
sort -t $' ' -k 3n -k 1r sort.log
更換成從前往後
sort -t $' ' -k 1 -k 3n sort.log
sort -t $' ' -k 1 -k 3nr sort.log
通過 sort -t $' ' -k 1 -k 3n sort.log 和 sort -t $' ' -k 1 -k 3nr sort.log 返回的結果發現,在第一列相等時,無論其三列是正序排列,還是逆序排列,結果都一樣,說明後邊的 -k 未生效
當指定 FEend 後
sort -t $' ' -k 1,1 -k 3nr sort.log
3.4 作用域
緊跟在欄位後的選項(如"-k3n"的"n"和"-k2nr"的"n","r")稱為私有選項,使用短橫線寫在欄位外的選項(如"-n"、"-r")為全局選項。當沒有為欄位分配私有選項時,該排序欄位將繼承全局選項,所有選項包括但不限於"bfnrhM"
除了"b"選項外,其餘選項無論是指定在FStart還是FEnd中都是等價的,對於"b"選項,指定在FStart則作用於FStart,指定在FEnd則作用於FEnd
sort -t $' ' -k1r,2 sort.log ,可以看出一、二列都是倒敘排列
3.5 注意
指定n選項按數值排序時, 由於"n"選項只能識別數字和負號"-",當排序時遇到無法識別字元時,將導致該key的排序立即結束,n選項絕對不會跨域進行比較
默認情況下,sort會進行一次 "最後的排序" ,按照默認規則對整行進行一次排序,這次排序稱為"最後的排序"
sort -t $' ' -k3n sort.log ,在第三列相等時,整行會按照 ASCII 進行最後的升序排列
sort -t $' ' -k3,4n -s sort.log ,加了 -s 後,不會進行最後的排序(1000相同時,e在b的前邊了),而是保留原排序
3.6 按照某個域中的第n個字元進行排序
sort -t $' ' -k2.3,2.3 sort.log ,按第二列第三個字元進行排序
4、 -h 使用易讀性數字(例如:2K、1G)
sort -t $' ' -k5h sort.log
sort -t $' ' -k2,2 sort.log|uniq
sort -t $' ' -k2,2 -u sort.log 會對第二列進行去重,而 sort -t $' ' -k2,2 sort.log|uniq 會對整行進行去重(當然uniq也可以按照第二列進行去重)
sort整理完了,歡迎大牛指教
⑦ linux下mysql,按列排序後結果顯示在終端里,怎樣使結果顯示在表中
數據導入新表
createtable新的表名(你的sql語句)
然後查詢:
select*from新的表名皮雀
如下是我的例子
mysql>create旅襪tabletb_a(select*fromuser);
QueryOK,拆握激19rowsaffected(0.20sec)
Records:19Duplicates:0Warnings:0
mysql>select*fromtb_a;
⑧ Linux中怎麼對第一列排序,然後輸出的結果把第二列的數據帶上。
#!/bin/bash
####/autorun/aa/yy.log是原始數據的路徑,自己替換,注意先刪除第一行的enbid rsrp,最後結果會加襪飢上
count=`cat /autorun/aa/yy.log|wc -l`
cat /autorun/aa/yy.log|awk '{print $1}' > /autorun/aa/yy2.log
let i=0
arr=()
while read line
do
arr[$i]=$line
let i=i+1
done < /autorun/aa/yy2.log
len=${#arr[*]}
let len=len-1
###進行冒泡排序
for((i=0;i<$len;i++))
do
let len=len-i
for((j=0;j<len;j++))
do
let k=j+1
if [ ${arr[$j]} -ge ${arr[$k]} ];then
temp=${arr[$k]};
arr[$k]=${arr[$j]};
arr[$j]=$temp;
fi
done
done
echo "前好數enbid rsrp">/autorun/aa/yy3.log
len=${#arr[*]}
for((i=0;i<$len;i++))
do
echo "`cat /autorun/aa/yy.log|grep ''${arr[$i]}''慧首`">>/autorun/aa/yy3.log
done
⑨ Linux TOP命令按內存佔用排序和按CPU佔用排序
Linux存在著許多不同的Linux版本,但它們都使用了Linux內核。Linux可安裝在各種計算機硬體設備中,比如手機、平板電腦、路由器、視頻游戲控制台、台式計算機、大型機和超級計算機。下面讓我們一起去了解Linux TOP命令 按內存佔用排序和按CPU佔用排序。
Linux TOP命令 按內存佔用排序和按CPU佔用排序:
:在命令行提示符執行top命令
2:輸入大寫P,則結果按CPU佔用降序排序。輸入大寫M,結果按內存佔用降序排序。(註:大寫P可以在capslock狀態輸入p,或者按Shift+p)
另外:
認識top的顯示結果
top命令的顯示結果如下所示:
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統計信息區
前五行是系統整體的統計信息。第一行是任務隊列信息,同 uptime 命令的執行結果。其內容如下:
01:06:48當前時間
up 1:22系統運行時間,格式為時:分
1 user當前登錄用戶數
load average: 0.06, 0.60, 0.48系統負載,即任務隊列的平均長度。
三個數值分別為 1分鍾、5分鍾、15分鍾前到現在的平均值。
第二、三行為進程和CPU的信息。當有多個CPU時,這些內容可能會超過兩行。內容如下:
Tasks: 29 total進程總數
1 running正在運行的進程數
28 sleeping睡眠的進程數
0 stopped停止的進程數
0 zombie僵屍進程數
Cpu(s): 0.3% us用戶空間佔用CPU百分比
1.0% sy內核空間佔用CPU百分比
0.0% ni用戶進程空間內改變過優先順序的進程佔用CPU百分比
98.7% id空閑CPU百分比
0.0% wa等待輸入輸出的CPU時間百分比
0.0% hi
0.0% si
最後兩行為內存信息。內容如下:
Mem: 191272k total物理內存總量
173656k used使用的物理內存總量
17616k free空閑內存總量
22052k buffers用作內核緩存的內存量
Swap: 192772k total交換區總量
0k used使用的交換區總量
192772k free空閑交換區總量
123988k cached緩沖的交換區總量。
內存中的內容被換出到交換區,而後又被換入到內存,但使用過的交換區尚未被覆蓋,
該數值即為這些內容已存在於內存中的交換區的大小。
相應的內存再次被換出時可不必再對交換區寫入。
進程信息區
統計信息區域的下方顯示了各個進程的詳細信息。首先來認識一下各列的含義。
序號列名含義
aPID進程id
bPPID父進程id
cRUSERReal user name
dUID進程所有者的用戶id
eUSER進程所有者的用戶名
fGROUP進程所有者的組名
gTTY啟動進程的終端名。不是從終端啟動的進程則顯示為 ?
hPR優先順序
iNInice值。負值表示高優先順序,正值表示低優先順序
jP最後使用的CPU,僅在多CPU環境下有意義
k%CPU上次更新到現在的CPU時間佔用百分比
lTIME進程使用的CPU時間總計,單位秒
mTIME+進程使用的CPU時間總計,單位1/100秒
n%MEM進程使用的物理內存百分比
oVIRT進程使用的虛擬內存總量,單位kb。VIRT=SWAP+RES
pSWAP進程使用的虛擬內存中,被換出的大小,單位kb。
qRES進程使用的、未被換出的物理內存大小,單位kb。RES=CODE+DATA
rCODE可執行代碼佔用的物理內存大小,單位kb
sDATA可執行代碼以外的部分(數據段+棧)佔用的物理內存大小,單位kb
tSHR共享內存大小,單位kb
unFLT頁面錯誤次數
vnDRT最後一次寫入到現在,被修改過的頁面數。
wS進程狀態。
D=不可中斷的睡眠狀態
R=運行
S=睡眠
T=跟蹤/停止
Z=僵屍進程
xCOMMAND命令名/命令行
yWCHAN若該進程在睡眠,則顯示睡眠中的系統函數名
zFlags任務標志,參考 sched.h
默認情況下僅顯示比較重要的 PID、USER、PR、NI、VIRT、RES、SHR、S、%CPU、%MEM、TIME+、COMMAND 列。可以通過下面的快捷鍵來更改顯示內容。
更改顯示內容
通過 f 鍵可以選擇顯示的內容。按 f 鍵之後會顯示列的列表,按 a-z 即可顯示或隱藏對應的列,最後按回車鍵確定。
按 o 鍵可以改變列的顯示順序。按小寫的 a-z 可以將相應的列向右移動,而大寫的 A-Z 可以將相應的列向左移動。最後按回車鍵確定。
按大寫的 F 或 O 鍵,然後按 a-z 可以將進程按照相應的列進行排序。而大寫的 R 鍵可以將當前的排序倒轉。
⑩ 每天一個linux命令(1)sort
sort 是將文件的每一行作為一個單位,相互比較,比較原則是從首字元向後,依次按照ASCII碼值進行比較,默認將他們按照升序輸出
降序
在輸出中去重
將排序結果輸出到原文件
sort的默認輸出是輸出到標准輸出,如果想把結果輸出到文件,需要 sort file > newfile,但是如果想把結果輸出到原文件這樣就不行了,這時就需要 使用sort -o
以數值來排序
sort 默認是按照字元串排序的,這樣就會出現10比3小的情況,sort -n 就可以告訴sort 以整數排序
-t 後面跟 分隔符
-k 後面跟數字,表示用第幾列排序
如 sort -t : -k 2 表示把每行 以:號分割,按照第二列排序
banana:30:5.5
orange:20:3.4
apple:10:2.5
我們可以看到,當 和soho都是100的時候,排在前面,當當前域按照默認規矩,是從第一個域開始進行升序排序,因此排在了sohu前面。
sort 支持 -k 2 -k3這種模式,如果你需要,你可以繼續這么寫下去
你仔細看看,在-k 3後面偷偷加上了一個小寫字母r,r和-r的作用是一樣,你也可以把前面的-n去掉 在r後面加上n,如下
其實-k 選項 功能很強大,語法[ FStart [ .CStart ] ] [ Modifier ] [ , [ FEnd [ .CEnd ] ][ Modifier ] ]
從逗號前後 分為兩大部分,即-k 2,2,是嚴格使用第一個域排序,如果只設置-k 2 其實是按照從第一個域到行尾。逗號分開的每部分又有一個點表示子域,即-k 1.2表示 按照第一個域的第二個字元排序,Modifiers就是我們用到的n和r 如 -k 1.2nr 具體我們看下面的例子。
我們使用了-k 1.2,這就表示對第一個域的第二個字元開始到本域的最後一個字元為止的字元串進行排序。你會發現因為第二個字母是a而名列榜首。sohu和 google第二個字元都是o,但sohu的h在google的o前面,所以兩者分別排在第二和第三。這和之前說到的按照默認的排序規則 是不同的,當第一個域的第二個字元相同時,他不會去按照第一個字元排序,而是按照後面的字元排序,這是因為-k 1.2是對第一個域的第二個字元開始到本域的最後一個字元為止的字元串進行排序。而之前的誇域其實是一種假象。
-u只識別用-k設定的域,發現相同,就將後續相同的行都刪除
但是這時候,卻一行也沒有刪除。原來-u是會權衡所有-k選項,將都相同的才會刪除,只要其中有一級不同都不會輕易刪除的
可以用到b、d、f、i、n 或 r。
其中n和r你肯定已經很熟悉了。
b表示忽略本域的簽到空白符號。
d表示對本域按照字典順序排序(即,只考慮空白和字母)。
f表示對本域忽略大小寫進行排序。
i表示忽略「不可列印字元」,只針對可列印字元進行排序。(有些ASCII就是不可列印字元,比如\a是報警,\b是退格,\n是換行,\r是回車等等)