成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

正則表達(dá)式-創(chuàng)新互聯(lián)

grep

主要用來(lái)過濾的。

成都創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供五臺(tái)網(wǎng)站建設(shè)、五臺(tái)做網(wǎng)站、五臺(tái)網(wǎng)站設(shè)計(jì)、五臺(tái)網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)與制作、五臺(tái)企業(yè)網(wǎng)站模板建站服務(wù),10年五臺(tái)做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。

cp /etc/passwd 1.txt

grep --color 'root' 1.txt                      #打印符合的行并用顏色顯示

vim .bashrc

#添加

alias grep='grep –color’

grep -c 'root' 1.txt                              #過濾行號(hào)

grep -n 'root' 1.txt                              #打印符合要求的行,并顯示行號(hào)

grep -v 'root' 1.txt                              #取反,打印不符合要去的行

grep –E = egrep                                 #表示特殊符號(hào)如()+?,不用脫義,脫義符號(hào)\

-A :后跟一個(gè)數(shù)字(有無(wú)空格都可以),例如 –A2則表示打印符合要求的行以及下面兩行

-B :后跟一個(gè)數(shù)字,例如 –B2 則表示打印符合要求的行以及上面兩行

-C :后跟一個(gè)數(shù)字,例如 –C2 則表示打印符合要求的行以及上下各兩行

-r : 會(huì)把目錄下面所有的文件全部遍歷

grep 'r.t' 1.txt                                     #r和t一定要打印,并且中間還要有一個(gè)字符

grep 'r*t' 1.txt                                     #表示t一定要打印,r可以有零個(gè)或者多個(gè)

grep 'r.*t' 1.txt                                             #r和t一定要打印,中間可以任意個(gè)任意字符

grep '[0-9]' 1.txt                                  #打印所有包含數(shù)字的行

grep '[^0-9]' 1.txt                                #打印所有非數(shù)字的行,如字符,空行

grep '^[0-9]' 1.txt                                #打印所有以數(shù)字開頭的行

grep '[0-2]' txt = grep '[0,1,2]' 1.txt

grep '^$' 1.txt                                      #打印空行

grep 'in$' 1.txt                                     #打印以in結(jié)尾的行

grep '[a-z]' 1.txt                                  #打印所有的小字母的行

grep '[a-zA-Z]' 1.txt                            #打印所有的大小字母的行

grep 'root\|mysql' 1.txt                    #或者,但是要脫義\

^:以什么開頭

$:以什么結(jié)尾

*:表示*前面的那個(gè)字符可以有零個(gè)或者多個(gè)。

.*:任意個(gè)任意字符

+:一個(gè)或多個(gè)+前面的字符

?:零個(gè)或一個(gè)?前面的字符

需要脫義的字符:? + () [] \

sed

grep能用的,sed都能用,sed的功能還要多,可以刪除d,替換g

-r表示使用正則的特殊符號(hào)不用脫義

sed '10'p -n 1.txt             #p為打印,-n取消自動(dòng)打印,按要求打印行,沒有-n會(huì)重復(fù)打印,

p一般和-n一起用,就是打印一般和-n一起用

sed -n '/root/p' 1.txt                 #打印包含某個(gè)字符的行,可以使用正則^,*$,當(dāng)有關(guān)鍵字要用//

-e 可以實(shí)現(xiàn)同時(shí)進(jìn)行多個(gè)任務(wù)sed -e'/root/p' -e '/body/p' -n 1.txt,也可以用;實(shí)現(xiàn)

sed -n '/root/p;/body/p' 1.txt

sed '/root/d' 1.txt                      #刪除行

sed '1d' 1.txt                               #刪除第一行,打印剩下的

sed '1,10d' 1.txt                         #刪除第一行到第十行,打印剩下的

sed '1,2s/ot/to/g' 1.txt   #s替換,g全局替換,否則只替換第一行在1-2行里,把ot替換成to,剩下照常打印,/可以為#,@,這些只在替換生效

sed 's/[0-9]//g' 1.txt                 #刪除所有的數(shù)字,即把數(shù)字替換為空

sed '/[0-9]/d' 1.txt                     #刪除所有數(shù)字的行

sed 's/[^0-9]//g' 1.txt               #刪除所有的非數(shù)字,即把為數(shù)字替換為空

head -n2 1.txt |sed's/\(root\)\(.*\)\(bash\)/\3\2\1/'     #調(diào)換兩個(gè)字符串的位置,注意脫義符號(hào),還有三個(gè)/

sed 's/^.*$/& loging/g' 1.txt  #在最后加上 loging,一定要在替換才可以加

sed -i 's/ot/to/g' 1.txt               #-i直接修改文件內(nèi)容

sed練習(xí)題:

把/etc/passwd 復(fù)制到/root/test.txt,

用sed打印所有行:sed '/.*/p' -n 1.txt

打印test.txt的3到10行:sed '3,10p' -n 1.txt

打印test.txt 中包含 'root' 的行:sed '/root/p' -n 1.txt

刪除test.txt 的15行以及以后所有行:sed '15,$d' 1.txt

刪除test.txt中包含 'bash' 的行; sed '/bash/d' 1.txt

替換test.txt 中 'root' 為 'toor'

替換test.txt中 '/sbin/nologin' 為 '/bin/login'

刪除test.txt中5到10行中所有的數(shù)字:sed -e 's/[0-9]//g' -e '5,10p' -n 1.txt

刪除test.txt 中所有特殊字符(除了數(shù)字以及大小寫字母):sed  's/[^a-zA-Z0-9]//g' 1.txt

把test.txt中第一個(gè)單詞和最后一個(gè)單詞調(diào)換位置:sed -r 's/(^.*)(:.*:)(.*$)/\3\2\1/' 1.txt

把test.txt中出現(xiàn)的第一個(gè)數(shù)字和最后一個(gè)單詞替換位置

把test.txt 中第一個(gè)數(shù)字移動(dòng)到行末尾

在test.txt 20行到末行最前面加 'aaa:':sed -e 's/^.*$/& aaa/g' -e '10p' -n 1.txt

awk

可以按段打印

awk -F ':' '{print $1}' 1.txt                           #以:為分界符,截取文檔的第一段

awk -F ':' '{print $1"#"$2}'1.txt                #以:為分界符,截取文檔的第一段和第二段并用#分界,自定義分界只能用雙引號(hào)””,不能用單引號(hào)’’

awk -F ':' 'OFS="@" {print$1,$3}' 1.txt            #和上面一個(gè)意思

awk '/oo/' 1.txt                                            #匹配字符或字符串

awk -F ':' '$1 ~/oo/' 1.txt                            #針對(duì)某個(gè)段匹配

awk '/root|mysql/' 1.txt                             #匹配多個(gè)

awk -F ':' '/root/ {print $1,$3};$1~/mysql/;$3 ~'/11/'' 1.txt            #多次匹配,把每次匹配到的都顯示出來(lái)

awk -F ':' '$1~/r*o/ {print $3}' 1.txt #打印匹配的行

條件操作符==,>,<,>=,<=

awk -F ':' '$3=="0"' 1.txt

awk -F ':' '$3>=99' 1.txt                              #初步判斷數(shù)字不用雙引號(hào)

awk -F ':' '$7!="/sbin/nologin"'1.txt       #字母要用雙引號(hào),并且第七段要整一個(gè)字符串

awk -F ':' '$3<$4' 1.txt

awk -F ':' '$3>6 && $3<10'1.txt               #&&兩邊只需要一對(duì)單引號(hào)

awk -F ':' '$3>6 ||$7=="/bin/bash"' 1.txt       #字符串要用雙引號(hào)引起來(lái)

awk內(nèi)置變量 NF(段數(shù)) NR(行數(shù))

head -n3 1.txt |awk -F ':' '{print NF}'                 #打印一共有多少段

head -n3 1.txt |awk -F ':' '{print $NF}'              #打印最后一段的字符

head -n3 1.txt |awk -F ':' '{print NR}'                #打印行號(hào)

awk 'NR>20' 1.txt                                                  #打印20以后的行,row行,fragment段

awk -F ':' 'NR>20 && $1 ~/ssh/' 1.txt

awk -F ':''$1="root"' 1.txt                         #更改某段的值

awk -F ':' '{$7=$3+$4;print $0}' 1.txt                #數(shù)學(xué)計(jì)算, 把第三段和第四段值相加,并賦予第七段

awk -F ':' '{if($1=="root") print$0}' 1.txt #也可以使用關(guān)鍵字

awk -F ':' '{tot=tot+$3};END {print tot}'1.txt           #計(jì)算第三段的總和

cat /etc/passwd|awk -F ':' 'BEGIN {print"name,shell"} {print $1","$7} END {print"blue,/bin/bash"}'          #只是顯示/etc/passwd的賬戶和賬戶對(duì)應(yīng)的shell,而賬戶與shell之間以逗號(hào)分割,而且在所有行添加列名name,shell,在最后一行添加"blue,/bin/nosh"

用awk 打印整個(gè)test.txt (以下操作都是用awk工具實(shí)現(xiàn),針對(duì)test.txt):awk '/.*/' 1.txt

查找所有包含 'bash' 的行:awk '/bash/' 1.txt

用 ':' 作為分隔符,查找第三段等于0的行:awk -F ':' '$3==0' 1.txt

用 ':' 作為分隔符,查找第一段為 'root' 的行,并把該段的 'root' 換成 'toor' (可以

連同sed一起使用):awk -F ':' '$1=="root"' 1.txt |sed 's/root/toor/g'

用 ':' 作為分隔符,打印最后一段:awk -F ':' '{print $7}' 1.txt

打印行數(shù)大于20的所有行:awk -F ':' 'NR>20' 1.txt

用 ':' 作為分隔符,打印所有第三段小于第四段的行:awk -F ':' '$3<$4' 1.txt

用 ':' 作為分隔符,打印第一段以及最后一段,并且中間用 '@' 連接(例如,第一行應(yīng)>該是這樣的形式 'root@/bin/bash' ):awk -F ':' 'OFS="@"{print $1,$7}' 1.txt

用 ':' 作為分隔符,把整個(gè)文檔的第四段相加,求和:

awk -F ':' 'sum=sum+$4 {print sum}' 1.txt|tail -n1

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

分享文章:正則表達(dá)式-創(chuàng)新互聯(lián)
標(biāo)題來(lái)源:http://jinyejixie.com/article34/deddpe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站營(yíng)銷、域名注冊(cè)、自適應(yīng)網(wǎng)站、企業(yè)網(wǎng)站制作、電子商務(wù)網(wǎng)站設(shè)計(jì)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站建設(shè)
邵阳县| 五台县| 无棣县| 鄂尔多斯市| 历史| 岢岚县| 宁国市| 湖北省| 南岸区| 蒲城县| 雅江县| 甘南县| 新河县| 色达县| 霞浦县| 台东县| 萨迦县| 井研县| 壶关县| 苍溪县| 三都| 通河县| 红安县| 南京市| 福海县| 双辽市| 鹿邑县| 巴青县| 高台县| 棋牌| 霍林郭勒市| 瓮安县| 剑河县| 美姑县| 天柱县| 峨眉山市| 荣昌县| 阿克| 海丰县| 福安市| 昌江|