美文网首页
day15-2019年3月20日

day15-2019年3月20日

作者: Linux_wu_sir | 来源:发表于2019-03-20 20:36 被阅读0次

    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

    相关文章

      网友评论

          本文标题:day15-2019年3月20日

          本文链接:https://www.haomeiwen.com/subject/vrqxvqtx.html