第十五天課堂總結(jié)

一、三劍客實例講解

環(huán)境


[root@oldboyedu ~]# cat oldgirl.txt

I am oldboy teacher!

I like badminton ball ,billiard ball and chinese chess!

our site is http://www.oldboyedu.com

my qq num is 49000448

問題1

[root@oldboyedu ~/test]# sed -n "2,3p" oldgirl.txt

[root@oldboyedu ~/test]# head -3 oldgirl.txt |tail -2

問題2

[root@oldboyedu ~]# grep "oldboy" oldgirl.txt

[root@oldboyedu ~]# sed '/oldboy/p' -n oldgirl.txt

[root@oldboyedu ~]# awk '/oldboy/' oldgirl.txt

問題3

[root@oldboyedu ~]# grep -v "oldboy" oldgirl.txt

[root@oldboyedu ~]# sed '/oldboy/d' oldgirl.txt

問題4

[root@oldboyedu ~]# sed 's#oldboy#oldgirl#g'? oldgirl.txt

vim替換

問題5

[root@oldboyedu ~]# sed? -e 's#oldboy#oldgirl#g' -e 's#49000448#2432424#g' oldgirl.txt

問題6

插入單行? ? sed? -i? '2a? I teacher linux.'? 第三行? 追加到指定的行后

插入單行? ? sed? -i? '2i? I teacher linux.'? ? 第二行? 追加到指定行的前面

刪除3行? ? sed? -i? '3d'? oldboy.txt

刪,2-5行? ? sed? -i? '2快毛,5d'? oldboy.txt

插入增加多行

增加第三行內(nèi)容? ? sed -i '3i Iam a teacher' oldboy?

增加第三行第四行內(nèi)容??

sed -i '3i Iam a teacher\nYou are my student' oldboy?


這是沒保存的,保存的加? -i

二焕檬、企業(yè)案例


問題一:

(1)

[root@oldboyedu ~/test]# ifconfig eth0 |sed -n 2p |sed 's/^.*inet //g'|sed 's/netm.*$//g'

[root@oldboyedu ~]# ifconfig eth0 |sed -r '2s#^.*inet (.*) netma.*$#\1#gp' -n

[root@oldboyedu ~]# ifconfig eth0 | awk -F "[ :]+" 'NR==2{print $3}'


^.*? ? ? ? ? ? ? ? ? inet


(2)

[root@oldboyedu ~/test]# ifconfig eth0 |sed -n? 's/^.*inet //pg'|sed -n 's/ net.*$//pg'

10.0.0.201


要取一個目標(biāo),刪除目標(biāo)兩邊的澳泵,就得到了

------------------------------------------------------------------

二实愚、、cut? 按列切割

-d 指定分隔符

-f 指定列

-c? 指定字符查看字符數(shù)


練習(xí)


三、三劍客老大? awk

三劍客自身特長

grep? 過濾查找內(nèi)容腊敲。篩子

sed? 取行击喂,替換,刪除兔仰,追加

awk? 取列


參數(shù)

-F 指定分隔符

[root@oldboyedu ~]# awk -F ":" '{print $1}' oldboyedu.txt

? ? ? 列: $1? 第一列? ? $2? 第二列 ..? 以此類推

$0? 整行

$NF 最后一行

$NF-1? 倒數(shù)第二列

NR 是行



四茫负、練習(xí)題


題一


題二


題三

題四

4.通過notepad++打開,把一下內(nèi)容輸入到test.txt文件中

姓名 區(qū)號? 電話? ? 三個月捐款數(shù)量

Mike Harrington:[510] 548-1278:250:100:175

Christian Dobbins:[408] 538-2358:155:90:201

Susan Dalsass:[206] 654-6279:250:60:50

Archie McNichol:[206] 548-1348:250:100:175

Jody Savage:[206] 548-1278:15:188:150

Guy Quigley:[916] 343-6410:250:100:175

Dan Savage:[406] 298-7744:450:300:275

Nancy McNeil:[206] 548-1278:250:80:75

John Goldenrod:[916] 348-4278:250:100:175

Chet Main:[510] 548-5258:50:95:135

Tom Savage:[408] 926-3456:250:168:200

Elizabeth Stachelin:[916] 440-1763:175:75:300

(1)顯示所有電話號碼

awk -F "[ :]+" '/^[^^$]/{print $4}' test.txt

? awk -F "[ :]+" '!/^$/{print $4}' test.txt

awk -F "[ :]+" '/[0-9]/{print $4}' test.txt

(2)顯示Dan的電話號碼

[root@oldboyedu /tmp]# grep "Dan" test.txt |sed -nr 's/^.*\] (.*):450.*$/\1/pg'

[root@oldboyedu /tmp]# awk -F "[ :]"? '$1=="Dan"{print $1 ,$4 }' test.txt

(3)顯示Susan的名字和電話號碼

[root@oldboyedu ~]# awk -F "[ :]+" '$1~/Susan/{print $1, $2, $4}' test.txt

awk -F "[ :]"? '$1=="Susan"{print $1 ,$4 }' test.txt

[root@oldboyedu ~]# awk -F "[ :]+" 'NR==5{print $1, $2, $4}' test.txt

(4)顯示所有以D開頭的姓

[root@oldboyedu /tmp]# awk '$1~/^D/ {print $1}' test.txt

[root@oldboyedu /tmp]# awk '/^D/{print $1}' test.txt

(5)顯示所有區(qū)號為916的人名

[root@oldboyedu ~]# awk -F "[ :]+" '$3~/\[916\]/{print $1,$2,$3}' test.txt

(6)顯示Mike的捐款.顯示每個值時都有以$開頭.如$250$100$175

[root@oldboyedu ~]# awk -F "[ :]+" '$1~/Mike/{print $1,"$"$5,"$"$6,"$"$6}' test.txt


(7)顯示姓,其后跟一個逗號和名

[root@oldboyedu ~]# awk -F "[ :]+" 'NR>1&&!/^$/{print$1,"," $2}' test.txt

[root@oldboyedu ~]# awk -F "[ :]+" 'NR>1&&/^[^^$]/{print$1,"," $2}' test.txt

[root@oldboyedu ~]# awk -F "[ :]+" 'NR>1&&/[a-zA-Z]/{print$1,"," $2}' test.txt

[root@oldboyedu ~]# awk -F "[ :]+" '!/^$/{print $1 ","$2}' test.txt

[root@oldboyedu ~]# awk -F "[ :]+" '/^[^^$]/{print $1 ","$2}' test.txt

(8)在Jody開頭的行上面添加oldboy

[root@oldboyedu ~]# awk -F "[ :]+" '/Jody/{print "oldboy" "\n"$0}' test.txt

[root@oldboyedu ~]# awk -F "[ :]+" '/Jody/{print "oldboy\n"$0}' test.txt

[root@oldboyedu ~]# sed '/Jody/i oldboy' test.txt

(9)刪除空白行

[root@oldboyedu ~]# awk -F "[ :]+" '!/^$/{print$0}' test.txt

[root@oldboyedu ~]# awk -F "[ :]+" '/^[^^$]/{print$0}' test.txt

[root@oldboyedu ~]# awk -F "[ :]+" '/./{print$0}' test.txt

五、練習(xí)

Steve Blenheim:238-923-7366:95 Latham Lane, Easton, PA 83755:11/12/56:20300

Betty Boop:245-836-8357:635 Cutesy Lane, Hollywood, CA 91464:6/23/23:14500

Igor Chevsky:385-375-8395:3567 Populus Place, Caldwell, NJ 23875:6/18/68:23400

Norma Corder:397-857-2735:74 Pine Street, Dearborn, MI 23874:3/28/45:245700

Jennifer Cowan:548-834-2348:583 Laurel Ave., Kingsville, TX 83745:10/1/35:58900

Jon DeLoach:408-253-3122:123 Park St., San Jose, CA 04086:7/25/53:85100

Karen Evich:284-758-2857:23 Edgecliff Place, Lincoln, NB 92086:7/25/53:85100

Karen Evich:284-758-2867:23 Edgecliff Place, Lincoln, NB 92743:11/3/35:58200

Karen Evich:284-758-2867:23 Edgecliff Place, Lincoln, NB 92743:11/3/35:58200

Fred Fardbarkle:674-843-1385:20 Parak Lane, DeLuth, MN 23850:4/12/23:780900

Fred Fardbarkle:674-843-1385:20 Parak Lane, DeLuth, MN 23850:4/12/23:780900

Lori Gortz:327-832-5728:3465 Mirlo Street, Peabody, MA 34756:10/2/65:35200

Paco Gutierrez:835-365-1284:454 Easy Street, Decatur, IL 75732:2/28/53:123500

Ephram Hardy:293-259-5395:235 CarltonLane, Joliet, IL 73858:8/12/20:56700

James Ikeda:834-938-8376:23445 Aster Ave., Allentown, NJ 83745:12/1/38:45000

Barbara Kertz:385-573-8326:832 Ponce Drive, Gary, IN 83756:12/1/46:268500

Lesley Kirstin:408-456-1234:4 Harvard Square, Boston, MA 02133:4/22/62:52600

William Kopf:846-836-2837:6937 Ware Road, Milton, PA 93756:9/21/46:43500

Sir Lancelot:837-835-8257:474 Camelot Boulevard, Bath, WY 28356:5/13/69:24500

Jesse Neal:408-233-8971:45 Rose Terrace, San Francisco, CA 92303:2/3/36:25000

Zippy Pinhead:834-823-8319:2356 Bizarro Ave., Farmount, IL 84357:1/1/67:89500

Arthur Putie:923-835-8745:23 Wimp Lane, Kensington, DL 38758:8/31/69:126000

Popeye Sailor:156-454-3322:945 Bluto Street, Anywhere, USA 29358:3/19/35:22350

Jose Santiago:385-898-8357:38 Fife Way, Abilene, TX 39673:1/5/58:95600

Tommy Savage:408-724-0140:1222 Oxbow Court, Sunnyvale, CA 94087:5/19/66:34200

Yukio Takeshida:387-827-1095:13 Uno Lane, Ashville, NC 23556:7/1/29:57000

Vinh Tranh:438-910-7449:8235 Maple Street, Wilmington, VM 29085:9/23/63:68900

grep練習(xí)

1. 顯示所有包含San的行

2.顯示所有以J開始的人名所在的行

3.顯示所有以700結(jié)尾的行

4.顯示所有不包括834的行

5.顯示所有生日在December的行

6.顯示所有電話號碼的區(qū)號為498的行

7.顯示所有這樣的行:它包含一個大寫字母,后跟四個小寫字母,一個冒號,一個空格,和一個大寫字母

8.顯示姓以K或k開頭的行

9.顯示工資為六位數(shù)的行,并在前面加行號

sed練習(xí)

1. 顯示所有包含San的行

grep -n 'San' test.txt

sed -n '/San/p' test.txt

2.顯示所有以J開始的人名所在的行

grep '^J' test.txt

3.顯示所有以700結(jié)尾的行

grep '700$' test.txt

4.顯示所有不包括834的行

grep -v '834' test.txt

sed -n '/834/!p' test.txt

sed '/834/d' test.txt

awk '!/834/' test.txt

5.顯示所有生日在December的行

grep ':12/' test.txt

sed -n '/:12\//p' test.txt

6.顯示所有電話號碼的區(qū)號為408的行

awk '/408-/' test.txt

7.顯示所有這樣的行:它包含一個大寫字母,后跟四個小寫字母,一個逗號,一個空格,和一個大寫字母

egrep "[A-Z][a-z]{4}, [A-Z]" test.txt

8.顯示姓以K或k開頭的行

awk '$2~/^[Kk]/' test.txt

9.顯示工資為六位數(shù)的行,并在前面加行號

egrep -n '[0-9]{6}$' test.txt

awk '/[0-9]{6}/{print NR,$0}' test.txt

grep -n "[0-9]\{6\}" test.txt (夏云峰不會)

sed練習(xí)

1.把Jon的名字改成Jonathan.

sed -n 's#^Jon#Jonathan#gp' test.txt

2.刪除頭三行

cat -n test.txt|sed -n '4,$p'

sed '1,3d' test.txt

3.顯示5-10行

cat -n test.txt|sed -n '/Jennifer/,/Fred/p'

cat -n test.txt|sed -n '5,10p'

awk 'NR>4&&NR<11{print NR,$0}' test.txt

4.刪除包含Lane的行.

sed '/Lane/d' test.txt

5.顯示所有生日在November-December之間的行

sed -nr '/:(11|12)\//p' test.txt

6.把三個星號(***)添加到以Fred開頭的行

sed -n 's#^(Fred).*#***\1#gp' test.txt

7.用JOSE HAS RETIRED取代包含Jose的行

sed -n '/^Jose/c? JOSE HAS RETIRED' test.txt

8.把Popeye的生日改成11/14/46

awk -F'[ :]' '/^Popeye/{$(NF-1)="11/14/46";print}' test.txt

sed -nr 's#(^Popeye.*:).*(:.*)#\111/14/46\2#gp' test.txt

9.刪除所有空白行

awk -F "[ :]+" '!/^$/{print}' test.txt

awk -F "[ :]+" '/^[^^$]/{print}' test.txt

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末葛躏,一起剝皮案震驚了整個濱河市矮燎,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌薄料,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,122評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異羹蚣,居然都是意外死亡,警方通過查閱死者的電腦和手機乱凿,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,070評論 3 395
  • 文/潘曉璐 我一進(jìn)店門顽素,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人徒蟆,你說我怎么就攤上這事胁出。” “怎么了段审?”我有些...
    開封第一講書人閱讀 164,491評論 0 354
  • 文/不壞的土叔 我叫張陵全蝶,是天一觀的道長。 經(jīng)常有香客問我寺枉,道長抑淫,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,636評論 1 293
  • 正文 為了忘掉前任姥闪,我火速辦了婚禮始苇,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘筐喳。我一直安慰自己催式,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,676評論 6 392
  • 文/花漫 我一把揭開白布疏唾。 她就那樣靜靜地躺著蓄氧,像睡著了一般。 火紅的嫁衣襯著肌膚如雪槐脏。 梳的紋絲不亂的頭發(fā)上喉童,一...
    開封第一講書人閱讀 51,541評論 1 305
  • 那天,我揣著相機與錄音,去河邊找鬼堂氯。 笑死蔑担,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的咽白。 我是一名探鬼主播啤握,決...
    沈念sama閱讀 40,292評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼晶框!你這毒婦竟也來了排抬?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,211評論 0 276
  • 序言:老撾萬榮一對情侶失蹤授段,失蹤者是張志新(化名)和其女友劉穎蹲蒲,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體侵贵,經(jīng)...
    沈念sama閱讀 45,655評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡届搁,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,846評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了窍育。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片卡睦。...
    茶點故事閱讀 39,965評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖漱抓,靈堂內(nèi)的尸體忽然破棺而出表锻,到底是詐尸還是另有隱情,我是刑警寧澤辽旋,帶...
    沈念sama閱讀 35,684評論 5 347
  • 正文 年R本政府宣布浩嫌,位于F島的核電站,受9級特大地震影響补胚,放射性物質(zhì)發(fā)生泄漏码耐。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,295評論 3 329
  • 文/蒙蒙 一溶其、第九天 我趴在偏房一處隱蔽的房頂上張望骚腥。 院中可真熱鬧,春花似錦瓶逃、人聲如沸束铭。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,894評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽契沫。三九已至,卻和暖如春昔汉,著一層夾襖步出監(jiān)牢的瞬間懈万,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,012評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留会通,地道東北人口予。 一個月前我還...
    沈念sama閱讀 48,126評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像涕侈,于是被迫代替她去往敵國和親沪停。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,914評論 2 355

推薦閱讀更多精彩內(nèi)容