day15-2019年3月20日

2019-03-20  本文已影响0人  Linux_wu_sir

awk 是命令行操作或可以作

擅长处理字符串

grep 擅长 过滤查找内容(筛子)

sed   取行,替换,删除,追加

awk  取列

语法

awk        [option]        'pattern{action}' file ...

awk          参数               条件(动作) 文件

$NF指定分隔符后的最后一列。

NR行号

$0==全部内容

参数:

-F

cut  按列切割

-d 指定分割符

-f 指定列

-c 指定字符,

cut -d " " -f1 text  如果多列 可以用,分隔

cut -c3-5 a.txt 显示第3至第5个字符也支持,分割 显示所有行的3-5列

^[^r]非r开头字符

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

练习题:

1.在当前系统中打印出所有普通用户的用户名和家目录(/etc/passwd)

普通用户的用户名awk -F ":" '$3>=1000&&$3<=60000 {print $1,$NF}' /etc/passwd

普通用户的家目录awk -F ":" '$3>=1000&&$3<=60000 {print $1}' /etc/passwd|xargs -i ls -l /home/{}

2.显示当前系统中容量使用率大于5%的文件系统名称和挂载点

df|awk -F "[ |%]+" '$5>5&&NR!=1 { print $1,$6}'

3.为/tmp/grub.conf文件中前三行的行首加#号

sed -rn '1,3s#(.*)#\#\1#gp' /tmp/grub.conf

4.通过notepad++打开,把一下内容输入到test.txt文件中

姓名 区号  电话    三个月捐款数量

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 $2}' test

awk -F "[ :]+" 'NR!=1&&/^[^$]/{print $4}' test

(2)显示Dan的电话号码

grep "^Dan.*" test|awk -F ":" '{print $2}'

awk -F " |:" '$1~/Dan/ { print $4}' test

(3)显示Susan的名字和电话号码

grep "^Susan.*" test|awk -F ":" '{print $1,$2}'

(4)显示所有以D开头的姓

grep "^D.*" test|awk -F " |:" '{print $2}'

awk -F " " ' $1~/^D/ { print $1}' test

(5)显示所有区号为916的人名

sed -nr '/916/p' test|awk -F ":" '{print $1}'

awk -F "[ :]" '$3~/\[916\]/ {print $1,$2}' test

(6)显示Mike的捐款.显示每个值时都有以$开头.如$250$100$175

awk -F ":" 'NR==2 {print $3,$4,$5}' test|sed -rn 's#([0-9]{3})#$\1#gp'

awk -F ":" 'NR==2 {print "$"$3,"$"$4,"$"$5}' test

(7)显示姓,其后跟一个逗号和名

awk -F " |:" '{print $1,$2}' test|sed -rn 's#([a-z,A-Z]+) ([a-z,A-Z]+)#\1,\2#gp'

(8)在Jody开头的行前面添加oldboy

awk -F " " '$1~/Jody/{print "oldboy"$0}' test

(9)删除空白行

grep "." test

sed "/^$/d" test

上一篇下一篇

猜你喜欢

热点阅读