day15-2019年3月20日
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