shell特殊符號,cut、sort、wc、uniq、tee、tr、split命令
*代表0個或多個任意字符
[root@localhost ~]# ls *txt
11.txt 1.txt 22.txt 2.txt aa.txt a.txt
?只代表一個任意字符
不管是數字還是字母,只要是一個字符的都能匹配出來
[root@localhost ~]# ls ?.txt
1.txt 2.txt a.txt b.txt
[root@localhost ~]# ls ?txt
ls: 無法訪問?txt: 沒有那個文件或目錄
註釋符號#,這個符號後面的內容都會被忽略
[root@localhost ~]# a=123 #456
[root@localhost ~]# echo $a
123
脫義字符 \,這個字符會將後面的特殊符號(如*)還原為普通字符。
[root@localhost ~]# ls -ld test*
drwxr-xr-x. 2 root root 6 11月 17 14:06 test
[root@localhost ~]# ls -ld test\*
ls: 無法訪問test*: 沒有那個文件或目錄
管道符 | ,它的作用是將前面命令的輸出作為後面命令的輸入。並不是所有命令都可以用在管道符中,常用命令:cat、less、head、tail、grep、cut、sort、wc、uniq、tr、split、sed、awk等。
[root@localhost ~]# cat 1.txt | wc -l
1
cut命令
cut命令用來截取某一個字段。
格式為:cut -d‘分隔符 ’-[fc]n,n為數字。
-d:後面跟分隔符,分隔符要用單引號引起來。
-f:後面接的是第幾個區塊
-c:後面接的是第幾個字符
(-c不需要和-f,-d需要-f)
[root@localhost ~]# head -5 /etc/passwd | cut -d ‘:‘ -f 1-4
root:x:0:0
bin:x:1:1
daemon:x:2:2
adm:x:3:4
lp:x:4:7
-d後的冒號為分隔符,-f 1-4表示截取1-4段
[root@localhost ~]# head -5 /etc/passwd | cut -c 1-4
root
bin:
daem
adm:
lp:x
-c後可以是1個數字,也可以是區間1-4,還可以是多個數字n1,n2,n3(用逗號隔開)。
[root@localhost ~]# head -5 /etc/passwd | cut -c 1,6,8
rx0
b::
dnx
a::
l47
sort命令
sort命令用作排序。
格式為:sort -[-t 分隔符] [-kn1,n2] [-nru] n1,n2為數字。
-t:後面跟分割字符,作用和cut -d一樣。
-n:表示使用純數字排序。
-r:表示反向排序。
-u:表示去除重復。
-kn1,n2:表示n1-n2區間排序,也可以只寫-kn1。
如果sort不加任何選項,則兇首字符向後一次按ASCII碼值進行比較,最後將它們按升序輸出。
[root@localhost ~]# head -n 5 /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選項則表示使用純數字排序。
[root@localhost ~]# head -n 5 /etc/passwd | sort -t ‘:‘ -k 3 -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反向排序。
[root@localhost ~]# head -n 5 /etc/passwd | sort -t ‘:‘ -k 3,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
wc命令
wc命令用於統計文檔的行數、字符數、或詞數。
-l 統計行數
-w 統計詞數
-m 統計字符數
wc後不跟任何參數直接跟文檔則會把行數、詞數、字符數依次輸出。
[root@localhost ~]# wc /etc/passwd
24 44 1128 /etc/passwd
[root@localhost ~]# wc -l /etc/passwd
24 /etc/passwd
[root@localhost ~]# wc -w /etc/passwd
44 /etc/passwd
[root@localhost ~]# wc -m /etc/passwd
1128 /etc/passwd
uniq命令
uniq命令用來刪除重復行,常用選項-c,表示統計重復的行數,並把行數寫在前面。
使用uniq前,必須要先給文件排序(sort),否則不管用。
tee命令
tee命令後根文件名,起作用類似於輸出重定向(>),它還能把寫入後面所跟文件時,還顯示在屏幕上。常用於管道符 | 後。
-a:向文件中重定向時使用追加模式
使用-a參數。追加。
tr命令
tr命令用於替換字符,常用來處理文檔中出現的特殊符號。
-d 表示刪除某個字符。
[root@localhost ~]# echo "huangdalinux" | tr ‘a‘ ‘A‘
huAngdAlinux #將字符串中的a替換成A
[root@localhost ~]# echo "huangdalinux" | tr ‘an‘ ‘AN‘
huANgdAliNux #將字符串中的a和n替換成A和N
[root@localhost ~]# echo "huangdalinux" | tr ‘a-z‘ ‘A-Z‘
HUANGDALINUX #將字符串中的小寫字母替換成大寫字母
使用-d參數,刪除字符串中的某個字符
[root@localhost ~]# echo "huangdalinux" | tr -d ‘a‘
hungdlinux
[root@localhost ~]# echo "huangdalinux" | tr -d ‘a,u‘
hngdlinx
s
plit命令
split命令用於切割文檔,常用選項為-b和-l
-b:表示依據大小來分割文檔,默認單位為byte。
-l:表示依據行數來分割文檔。
指定目標文件名。
特殊符號$,用作變量前面的標識符。
特殊符號;。如果想在一行中運行兩個或兩個以上的命令,需要再命令之間加符號;。
特殊符號~。表示用戶的家目錄,root用戶為/root,普通用戶為/home/用戶名/
特殊符號&。可以把一條命令放在後臺執行。接在命令後。
輸出重定向>,輸出重定向追加>>,錯誤重定向2>,錯誤重定向追加2>>, 正確和錯誤輸出都重定向&>.正確和錯誤輸出都重定向追加&>>
中括號[],中括號內為字符組合,代表字符組合中的任意一個,可以是一個範圍。
特殊符號&&和||
command1;command2
使用;時,不管command1是否執行成功,都會執行command2。
command1&&command2
使用&&時,只有command1執行成功,才會執行command2。
command1||command2
使用||時,command1執行成功後則command2不執行,否則執行command2,即command1和command2中總有一條命令會執行。
本文出自 “網管的學習之路” 博客,請務必保留此出處http://754599082.blog.51cto.com/11510506/1982863
shell特殊符號,cut、sort、wc、uniq、tee、tr、split命令