這里阿銘列出了很多陌生的命令,這些命令在日常的文檔處理工作中非常實用,所以阿銘需要先簡單介紹一下它們,如果你記不住,也沒有關系,以后用到的時候再進一步了解即可。
1. 命令cut
cut命令用來截取某一個字段,其格式為cut -d '分隔字符' [-cf] n,這里的n是數字。該命令有如下幾個可用選項。
-d:后面跟分隔字符,分隔字符要用單引號括起來。
-c:后面接的是第幾個字符。
-f:后面接的是第幾個區塊。
cut命令的用法如下:
?
# cat /etc/passwd|cut -d ':' -f 1 |head -5 root bin daemon adm lp
?
通過上例可以看出,-d選項后面加冒號作為分隔字符,-f 1表示截取第一段,-f和1之間的空格可有可無。示例命令如下:
?
o i # head -n2 /etc/passwd|cut -c1 r b # head -n2 /etc/passwd|cut -c1-10 root0:0 bin1 # head -n2 /etc/passwd|cut -c5-10 0:0 x1:通過上例可以看出,-c選項后面可以是一個數字n,也可以是一個區間n1-n2,還可以是多個數字n1、n2和n3。示例命令如下:
# head -n2 /etc/passwd|cut -c1,3,10 ro0 bn:
?
2. 命令sort
sort命令用做排序,其格式為sort [-t 分隔符] [-kn1,n2] [-nru],這里n1和n2指的是數字,其他選項的含義如下。
-t:后面跟分隔字符,作用跟cut的-d選項一樣。
-n:表示使用純數字排序。
-r:表示反向排序。
-u:表示去重復。
-kn1,n2:表示由n1區間排序到n2區間,可以只寫-kn1,即對n1字段排序。
如果sort不加任何選項,則從首字符向后依次按ASCII碼值進行比較,最后將它們按升序輸出。示例命令如下:
# head -n5 /etc/passwd|sort adm:x:3:4:adm:/var/adm:/sbin/nologin bin:x:1:1:bin:/bin:/sbin/nologin daemon:x:2:2:daemon:/sbin:/sbin/nologin lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin root:x:0:0:root:/root:/bin/bash-t選項后面跟分隔符,-k選項后面跟單個數字表示對第幾個區域的字符串排序,-n選項則表示使用純數字排序。示例命令如下:
# head -n5 /etc/passwd |sort -t: -k3 -n root:x:0:0:root:/root:/bin/bash bin:x:1:1:bin:/bin:/sbin/nologin daemon:x:2:2:daemon:/sbin:/sbin/nologin adm:x:3:4:adm:/var/adm:/sbin/nologin lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
?
-k選項后面跟數字n1和n2表示對第n1和n2區域內的字符串排序,-r選項則表示反向排序。示例命令如下:
# head -n5 /etc/passwd |sort -t: -k3,5 -r lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin adm:x:3:4:adm:/var/adm:/sbin/nologin daemon:x:2:2:daemon:/sbin:/sbin/nologin bin:x:1:1:bin:/bin:/sbin/nologin root:x:0:0:root:/root:/bin/bash
?
這里的-k3,5表示對第3區域至第5區域間的字符串排序。
3. 命令wc
wc命令用于統計文檔的行數、字符數或詞數。該命令的常用選項有-l(統計行數)、-m(統計字符數)和-w(統計詞數)。示例命令如下:
?
#?wc?/etc/passwd 45 103 2499 /etc/passwd #?wc?-l?/etc/passwd 45 /etc/passwd #?wc?-m?/etc/passwd 2499 /etc/passwd #?wc?-w?/etc/passwd 103 /etc/passwd
?
如果wc不跟任何選項,直接跟文檔,則會把行數、詞數和字符數依次輸出。
4. 命令uniq
uniq命令用來刪除重復的行,該命令只有-c選項比較常用,它表示統計重復的行數,并把行數寫在前面。我們先來編寫一個文件,示例命令如下:
# vim testb.txt //把下面的內容寫入testb.txt并保存 111 222 111 333
?
使用uniq前,必須先給文件排序,否則不管用。示例命令如下:
?
# uniq testb.txt 111 222 111 333 # sort testb.txt |uniq 111 222 333 # sort testb.txt |uniq -c 2 111 1 222 1 333
?
5. 命令tee
tee命令后面跟文件名,其作用類似于重定向>,但它比重定向多一個功能,即把文件寫入后面所跟的文件時,還顯示在屏幕上。該命令常用于管道符|后。示例命令如下:
# echo "aaaaaaaaaaaaaaaaaaaaaaaaaaa" |tee testb.txt aaaaaaaaaaaaaaaaaaaaaaaaaaa # cat testb.txt aaaaaaaaaaaaaaaaaaaaaaaaaaa
?
6. 命令tr
tr命令用于替換字符,常用來處理文檔中出現的特殊符號,如DOS文檔中出現的符號^M。該命令常用的選項有以下兩個。
-d:表示刪除某個字符,后面跟要刪除的字符。
-s:表示刪除重復的字符。
tr命令常用于把小寫字母變成大寫字母,如tr '[a-z]' '[A-Z]'。示例命令如下:
?
# head -n2 /etc/passwd |tr '[a-z]' '[A-Z]' ROOT:X:0:0:ROOT:/ROOT:/BIN/BASH BIN:X:1:1:BIN:/BIN:/SBIN/NOLOGIN
?
tr命令還可以替換一個字符,示例命令如下:
?
# grep 'root' /etc/passwd |tr 'r' 'R' Root:x:0:0:Root:/Root:/bin/bash opeRatoR:x:11:0:opeRatoR:/Root:/sbin/nologin不過替換、刪除以及去重復等操作都是針對一個字符來講的,有一定的局限性。如果是針對一個字符串,就不能再使用了,所以你只需簡單了解一下tr命令即可。以后,你還會學到更多可以實現字符串操作的工具。
?
7. 命令split
split命令用于切割文檔,常用的選項為-b和-l。
-b:表示依據大小來分割文檔,單位為byte,示例命令如下:
?
# mkdir split_dir # cd !$ cd split_dir # cp /etc/passwd ./ # split -b 500 passwd # ls passwd xaa xab xac xad xae如果split不指定目標文件名,則會以xaa、xab...這樣的文件名來存取切割后的文件。當然,我們也可以指定目標文件名,如下所示:
# rm –f xa* # split -b 500 passwd 123 # ls 123aa 123ab 123ac 123ad 123ae passwd
?
-l:表示依據行數來分割文檔,示例命令如下:
?
# rm -f 123a* # split -l 10 passwd # wc -l * 45 passwd 10 xaa 10 xab 10 xac 10 xad 5 xae 90 total
?
評論
查看更多