本文主要是介绍Day19-三剑客之awk实践,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
Day19-三剑客之awk实践
练习:/etc/passwd,/etc/fstab
首先准备好测试文件,取passwd文件前5行。
sed -n '1,5p' /etc/passwd >test.txt
[root@oldboy ~]# sed -n '1,5p' /etc/passwd >test.txt
[root@oldboy ~]# cat test.txt
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
问题1:取test.txt文件的第2行到第3行的内容。
方法1:
[root@oldboy ~]# sed -n '2,3p' test.txt
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
方法2:
[root@oldboy ~]# awk 'NR==2,NR==3' test.txt
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin打印2-3行,同时打印行号
[root@oldboy ~]# awk 'NR==2,NR==3{print NR,$0}' test.txt
2 bin:x:1:1:bin:/bin:/sbin/nologin
3 daemon:x:2:2:daemon:/sbin:/sbin/nologin
方法3:
[root@oldboy ~]# awk 'NR>1&&NR<4' test.txt
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
方法4:
[root@oldboy ~]# head -3 test.txt |tail -2
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
方法5:
[root@oldboy ~]# grep -A 1 -n "^bin" test.txt
2:bin:x:1:1:bin:/bin:/sbin/nologin
3-daemon:x:2:2:daemon:/sbin:/sbin/nologin[root@oldboy ~]# grep -B 1 -n "^dae" test.txt
2-bin:x:1:1:bin:/bin:/sbin/nologin
3:daemon:x:2:2:daemon:/sbin:/sbin/nologin
! 取反
&& (并且)
|| (或者)
== (表示相等)
= 赋值 a=1
专业取行 sed
专业取列 awk
专业过滤 grep
问题2:过滤出含有root字符串的行※。
[root@oldboy ~]# awk '/root/' test.txt
root:x:0:0:root:/root:/bin/bash[root@oldboy ~]# grep root test.txt
root:x:0:0:root:/root:/bin/bash[root@oldboy ~]# sed -n '/root/p' test.txt
root:x:0:0:root:/root:/bin/bash
问题3:删除含有root字符串的行※。
[root@oldboy ~]# sed '/root/d' test.txt
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin[root@oldboy ~]# awk '/^[^r]/' test.txt
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
问题4:取文件的第一列、第三列和最后一列内容,并打印行号※。
[root@oldboy ~]# awk -F ":" '{print NR,$1,$3,$NF}' test.txt
1 root 0 /bin/bash
2 bin 1 /sbin/nologin
3 daemon 2 /sbin/nologin
4 adm 3 /sbin/nologin
5 lp 4 /sbin/nologin
问题5:取出Linux中执行ifconfig eth0后对应的IP地址(只能输出IP地址)。
[root@oldboy ~]# ifconfig eth0|sed -rn 's#^.*inet (.*) netm.*$#\1#gp'
10.0.0.130[root@oldboy ~]# hostname -I
10.0.0.130 10.0.0.129[root@oldboy ~]# ifconfig eth0|awk 'NR==2{print $2}'
10.0.0.130
把要取的内容两边相邻的一堆内容做分隔符。
[root@oldboy ~]# ifconfig eth0|awk -F "(inet )|( netm)" 'NR==2{print $2}'
10.0.0.130
#<==竖线正则的意思表示匹配或者左边或者右边,小括号是分组作为一个整体,即以“addr:”或“ Bcast:”做分隔符
多分隔符用法:
[root@oldboy ~]# echo "1::::2====3----4"|awk -F "[:=-]+" '{print $1,$2,$3,$4}'
1 2 3 4
[:=-] #里面任意一个做分隔符
[:=-]+ #遇到[]里的任意多个字符算一个。#上述不同的分隔符连续也算一个。
[root@oldboy ~]# echo "1:::==:2==::==3----4"|awk -F "[:=-]+" '{print $1,$2,$3,$4}'
1 2 3 4
练习:
用awk取stat /etc/hosts结果的644
解答:先取行,在取列。
[root@oldboy ~]# stat /etc/hosts|awk 'NR==4'
Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root)
[root@oldboy ~]# stat /etc/hosts|awk -F "[0/]" 'NR==4{print $2}'
644
带条件的AWK;
【行的条件】
[root@oldboy ~]# stat /etc/hosts|awk -F "[0/]" 'NR==4{print $2}'
644
【内容模糊匹配】
问题6:过滤文件中第一列内容匹配root的字符串,把符合的行的最后一列输出。
解答:这道题在过滤日志信息的时候常用,示例如下。
[root@oldboy ~]# awk -F ":" '$1~/root/ {print $NF}' test.txt
#<==$1~/root/表示第一列内容匹配root条件,$NF表示最后一列。#/etc/passwd
awk -F ":" '$1~/oldboy/{print $NF}' /etc/passwd
问题7:过滤下列test1.txt文件中第三列内容分数大于70,并且小于95的人名和性别。
[root@oldboyedu ~]# cat test1.txt
张三 男 80
李四 女 70
王五 男 90
赵六 女 100
中文乱码:
1)调解xshell属性-终端-字符集-简体中文gb18030(只调一个就好了)
2)如果还不行做如下调整:
[root@oldboy ~]# tail -2 /etc/profile
#export LANG='en_US.UTF-8'
export LANG='zh_CN.UTF-8'# 生效:
. /etc/profile
解答:
[root@oldboy ~]# awk '$3>70&&$3<95{print $1,$2}' test1.txt
张三 男
王五 男
把要取的内容两边相邻的一堆内容做分隔符。
[root@oldboy ~]# ifconfig eth0|awk -F "(inet )|( netm)" 'NR==2{print $2}'
10.0.0.130
#<==竖线正则的意思表示匹配或者左边或者右边,小括号是分组作为一个整体,即以“addr:”或“ Bcast:”做分隔符
【答案】
https://ke.qq.com/course/2806831?taid=9996020988171311
这篇关于Day19-三剑客之awk实践的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!