Linux實(shí)用命令整理
0. 基本命令
linux 基本命令整理
1. 壓縮 解壓
tar -zcvf a.tar.gz a #把a(bǔ)壓縮成a.tar.gz
tar -zxvf a.tar.gz #把a(bǔ).tar.gz解壓成a
2. vim小結(jié)
2.1 vim替換
:m,ns/word_1/word_2/gc #把word_1用word_2替換,g表示替換所有的, c表示替換每一個(gè)時(shí)需要確認(rèn)
2.2 vim統(tǒng)計(jì)某一個(gè)字符串的個(gè)數(shù)
:m,ns/word_1/&/gn #統(tǒng)計(jì)從m行到n行之間word_1的個(gè)數(shù), n表示只是統(tǒng)計(jì)個(gè)數(shù)不替換
:1,$s/word_1/&/gn #搜索整個(gè)文檔中word_1的個(gè)數(shù),和下面等價(jià)
:%s/word_1/&/gn
2.3 vim中刪除某一字符串
:m,ng/word_1/d #從第m行到第n行刪除所有的word_1
3. 文件搜索
3.1 locate——通過(guò)文件名查找
locate /bin/zip
3.2 find——通過(guò)文件的各種屬性在既定的目錄下查找
find /usr -type f -name "*.png" -size +1M #查找的目錄范圍是/usr,名字以.png結(jié)尾,大小大于1M(+1M,1M,-1M)
find /usr -type f -name "*.png" -size +1M | wc -l #統(tǒng)計(jì)符合條件的行數(shù)
find /usr -type f -name "*.png" -size +1M -delete #刪除符合條件的
3.3 找出目錄dirs下含有字符串“hello”的所有文件的名字(個(gè)數(shù))
find .|xargs grep -ri "IBM" #xargs是一條Unix和類Unix操作系統(tǒng)的常用命令。它的作用是將參數(shù)列表轉(zhuǎn)換成小塊分段傳遞給其他命令,以避免參數(shù)列表過(guò)長(zhǎng)的問(wèn)題。
find .|xargs grep -ri "IBM" -l #只打印出文件名
4. 排序
cat file_name | sort -k2 -r #按第二列(從一開(kāi)始技術(shù))排序,-r表示reverse,從大到小輸出
cat file_name | sort -k1 -n #按第一列排序, -n按數(shù)字排序,默認(rèn)為按字符串排序
cat file_name | sort -k1 -nr | wc -l #統(tǒng)計(jì)滿足條件的個(gè)數(shù)
5. 系統(tǒng)開(kāi)銷
5.1 df——磁盤占用情況
df #列出各文件系統(tǒng)的磁盤空間占用情況(已用 未用)共五列:Size Used Avail Use% Mounted on
df -h #以更易讀的方式顯示 (按K\M\G適當(dāng)轉(zhuǎn)換)
5.2 du——文件大小
df #列出本目錄下,目錄的大小(默認(rèn)的計(jì)數(shù)單位是k)
df -h 文件名 #以更易讀的方式顯示所查文件的大小
5.3 w——CPU負(fù)載度量(簡(jiǎn)單的說(shuō)是進(jìn)程隊(duì)列的長(zhǎng)度,最近一段時(shí)間1min,5min,15min的load度量)
w
6. awk命令
cat file_name | awk '{print $1}' #輸出第一列(默認(rèn)以空格切分)
cat file_name | awk -F ':' '{print $1"\t"$3}' #-F指定切割符號(hào),輸出第3列
cat file_name | awk -F ':' 'BEGIN {print "name,id"} {print $1","$3} END {print "end_name,end_id"}' #BEGIN指定開(kāi)頭輸出,END指出結(jié)尾輸出
cat file_name | awk -F ':' '/keyWord/{print $1}' # 輸出一行中含有關(guān)鍵字keyWord的制定列
cat file_name | awk -F ':' '{print "filename:" FILENAME ",linenumber:" NR ",columns:" NF}' #內(nèi)置變量FILENAME文件名,NR已讀記錄數(shù),NF列數(shù)
cat file_name | awk '{count++} END {print "Count:" count}' #編程,最后輸出總行數(shù)
7. 編碼轉(zhuǎn)換
iconv -f gbk -t utf-8 -c text.txt -o text.out #-f:from -t:to -c從輸出中忽略無(wú)效的輸出 -o輸出文件名字
8. 文件屬性
chmod 屬性 文件名 #更改文件屬性r:1 w:2 x:4
chown 擁有者 文件名
chgrp 組名 文件名
9. 管道 | 重定向 >
ls -l |grep "^-" | wc -l #grep 正則匹配以'-'開(kāi)頭的, wc -l:統(tǒng)計(jì)滿足條件的總的行數(shù)
ls -l |grep "^-" >file_name1 #把滿足結(jié)果的定位到file_name1,注:先清空再定位
ls -l |grep "^-" >>file_name2 #把滿足結(jié)果的輸出到file_name2的后面,注:不清空,在原來(lái)基礎(chǔ)上繼續(xù)存儲(chǔ)
10. 文件傳輸下載
curl http://www.cnblogs.com/kaituorensheng/ #下載網(wǎng)頁(yè),默認(rèn)只下載HTML文檔; -l只顯示頭部; -i 顯示全部
curl http://e.hiphotos.baidu.com/image/pic/item/50da81cb39dbb6fd1e165c260a24ab18972b3764.jpg #下載圖片
curl "www.hotmail.com/when/junk.cgi?birthyear=1905&press=OK" #獲取表單,參數(shù)birthyear=1905,press=OK"
posted on 2014-09-29 10:15 順其自然EVO 閱讀(313) 評(píng)論(0) 編輯 收藏 所屬分類: 測(cè)試學(xué)習(xí)專欄 、linux