awk命令过滤ifconfig命令中的IPv4地址
admin
2023-02-24 02:20:04
0

前言:

        本文主要讲解如何过滤ifconfig命令结果中的IPv4地址。

        本文章的案例适合查找出所有网卡的IPv4地址。

        本章所有案例的系统是Red Hat 7.6版本

[root@192 opt]# cat /etc/redhat-release 
Red Hat Enterprise Linux Server release 7.6 (Maipo)

方法一:

        使用awk命令、正则表达式、通配符来筛选IPv4地址。

[root@localhost ~]# ifconfig
ens33: flags=4163  mtu 1500
        inet 192.168.109.128  netmask 255.255.255.0  broadcast 192.168.109.255
        inet6 fe80::20c:29ff:fed8:33c3  prefixlen 64  scopeid 0x20
        ether 00:0c:29:d8:33:c3  txqueuelen 1000  (Ethernet)
        RX packets 22836  bytes 1608781 (1.5 MiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 6159  bytes 617125 (602.6 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

lo: flags=73  mtu 65536
        inet 127.0.0.1  netmask 255.0.0.0
        inet6 ::1  prefixlen 128  scopeid 0x10
        loop  txqueuelen 1000  (Local Loopback)
        RX packets 0  bytes 0 (0.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 0  bytes 0 (0.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

[root@localhost ~]# ifconfig|awk '/inet / && $2 !~ /^127/{print $2}'
192.168.109.128

        注释:awk命令用正则来过滤出有IP地址的行并且用通配符来排除以127开头(回环地址)的地址,最后打印出第二列的有效IP地址。

方法二:

        结合使用awk命令和grep命令来过滤IPv4地址。

[root@localhost ~]# ifconfig
ens33: flags=4163  mtu 1500
        inet 192.168.109.128  netmask 255.255.255.0  broadcast 192.168.109.255
        inet6 fe80::20c:29ff:fed8:33c3  prefixlen 64  scopeid 0x20
        ether 00:0c:29:d8:33:c3  txqueuelen 1000  (Ethernet)
        RX packets 24068  bytes 1711773 (1.6 MiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 6769  bytes 690417 (674.2 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

lo: flags=73  mtu 65536
        inet 127.0.0.1  netmask 255.0.0.0
        inet6 ::1  prefixlen 128  scopeid 0x10
        loop  txqueuelen 1000  (Local Loopback)
        RX packets 0  bytes 0 (0.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 0  bytes 0 (0.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

[root@localhost ~]# ifconfig|awk '{match($0,/[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+/);print substr($0,RSTART,RLENGTH)}'|grep -Ev "^127|^$"
192.168.109.128

        注释:先使用awk中match命令结合正则查找出IP地址格式的字符串所在行的位置和长度,再用substr命令来截取IP地址,最后使用grep命令排除以127开头(回环地址)和空行并打印出其它所有的IP地址。

方法三:

        使用awk命令中RS变量的特殊值和正则匹配来筛选出IPv4地址。

[root@localhost ~]# ifconfig
ens33: flags=4163  mtu 1500
        inet 192.168.109.128  netmask 255.255.255.0  broadcast 192.168.109.255
        inet6 fe80::20c:29ff:fed8:33c3  prefixlen 64  scopeid 0x20
        ether 00:0c:29:d8:33:c3  txqueuelen 1000  (Ethernet)
        RX packets 24536  bytes 1748017 (1.6 MiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 6958  bytes 712613 (695.9 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

lo: flags=73  mtu 65536
        inet 127.0.0.1  netmask 255.0.0.0
        inet6 ::1  prefixlen 128  scopeid 0x10
        loop  txqueuelen 1000  (Local Loopback)
        RX packets 0  bytes 0 (0.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 0  bytes 0 (0.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

[root@localhost ~]# ifconfig|awk 'BEGIN{RS=""}!/^lo/{print $6}'
192.168.109.128

        注释:先使用BEGIN来定义RS变量的值为段落分隔(BEGIN{RS=""}),然后用正则匹配来排除以lo开头的段落,最后找出IP地址所在列的位置并打印出来。本方法要确保IP地址要在段落的第六列,当然也可以根据自己的特殊情况来进行调整。

        RS变量:通俗讲就是换行分隔符变量,默认值为"\n"换行符,而awk命令一次性读取多少数据都是由RS变量来决定的。例如:RS=" "(空格),awk一次性读取的数据为一个字符串 不再是一行的数据了。

        RS=""(中间没有空格):此为RS变量的特殊值(段落分隔),以空行或多个连续空行为分隔,一次性读取一段数据。

方法四:

        使用awk命令中的RS和FS变量来筛选出ipv4地址(本方法比较复杂,主要讲的是awk的使用

[root@localhost ~]# ifconfig
ens33: flags=4163  mtu 1500
        inet 192.168.109.128  netmask 255.255.255.0  broadcast 192.168.109.255
        inet6 fe80::20c:29ff:fed8:33c3  prefixlen 64  scopeid 0x20
        ether 00:0c:29:d8:33:c3  txqueuelen 1000  (Ethernet)
        RX packets 25278  bytes 1804185 (1.7 MiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 7240  bytes 745239 (727.7 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

lo: flags=73  mtu 65536
        inet 127.0.0.1  netmask 255.0.0.0
        inet6 ::1  prefixlen 128  scopeid 0x10
        loop  txqueuelen 1000  (Local Loopback)
        RX packets 0  bytes 0 (0.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 0  bytes 0 (0.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

[root@localhost ~]# ifconfig|awk 'BEGIN{RS="";FS="\n"}!/^lo/{$0=$2;FS=" ";$0=$0;print $2}'
192.168.109.128

        注释:先使用BEGIN定义awk以段落来读取数据,列以换行符来分隔(BEGIN{RS="";FS="\n"})。再使用正则匹配排除以lo开头的段落。重新设置$0的值为$2(含有IP地址的那一行内容,此时列的分隔符为换行符),设置FS变量的值为空格(FS=" ",列分隔符为空格),再重新设置$0的值但保持内容不变($0=$0,重置FS的值),最后打印出IP地址。

        FS变量:列的分隔符变量。$0=$2或$2=xxx或$6=$8等等只要重置了$0或列的内容都会重置一次FS变量的值。

方法五:

        结合使用awk和sed命令来过滤IPv4地址。

[root@localhost ~]# ifconfig
ens33: flags=4163  mtu 1500
        inet 192.168.109.128  netmask 255.255.255.0  broadcast 192.168.109.255
        inet6 fe80::20c:29ff:fed8:33c3  prefixlen 64  scopeid 0x20
        ether 00:0c:29:d8:33:c3  txqueuelen 1000  (Ethernet)
        RX packets 26232  bytes 1879377 (1.7 MiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 7636  bytes 791883 (773.3 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

lo: flags=73  mtu 65536
        inet 127.0.0.1  netmask 255.0.0.0
        inet6 ::1  prefixlen 128  scopeid 0x10
        loop  txqueuelen 1000  (Local Loopback)
        RX packets 0  bytes 0 (0.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 0  bytes 0 (0.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

[root@localhost ~]# ifconfig|sed -n '/inet /p'|awk '$2 !~ /^127/{print $2}'
192.168.109.128

        注释:先用sed命令过滤出包含IP地址的行,再使用awk命令排除含有以127开头(回环地址)IP地址的行,最后打印其他行的有效的IP地址。

总结:

        本文章主要使用awk命令来筛选IPv4地址。

        涉及到awk命令的功能主要如下所示:

                RS变量:行分隔符变量,就是一次性读取的数据由此变量来决定。

                FS变量:列分隔符变量,每一列的内容由此变量来进行分隔。

                match命令:查找所匹配格式的字符串在每行中的位置,以及所匹配到的字符串的长度。

                substr命令:根据条件来截取数据。命令格式:substr("原始数据","开始位置","结束位置"),位置主要以数字来定义。没有结束位置则截取到原始数据的末尾。


相关内容

热门资讯

终于明白“葫芦娃哥们到底有挂吗... 网上科普关于“葫芦娃哥们有没有挂”话题很是火热,小编也是针对葫芦娃哥们作*弊开挂的方法以及开挂对应的...
玩家攻略科普“众合推扑克究竟有... 网上科普关于“众合推扑克有没有挂”话题很是火热,小编也是针对众合推扑克作*弊开挂的方法以及开挂对应的...
终于懂了“友谊互娱到底是不是挂... 网上科普关于“友谊互娱有没有挂”话题很是火热,小编也是针对友谊互娱作*弊开挂的方法以及开挂对应的知识...
玩家最新攻略“新海贝之城拼三张... 您好:新海贝之城拼三张这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在...
【今日要闻】“宝宝浙江怎么装挂... 家人们!今天小编来为大家解答宝宝浙江透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪里买很...
辽宁盘锦“幼儿园虐童案”一审宣... 辽宁省盘锦市大洼区人民法院25日一审公开宣判被告人张某虐待被看护人案,对被告人张某以虐待被看护人罪判...
投资约1100亿美元,内塔尼亚... 据凤凰卫视报道,以色列总理内塔尼亚胡12月24日在空军飞行员毕业典礼上发表讲话,宣布未来十年将投入3...
今日重大消息“万圣节消除大作战... 网上科普关于“万圣节消除大作战有没有挂”话题很是火热,小编也是针对万圣节消除大作战作*弊开挂的方法以...
终于明白“齐聚天下到底是不是挂... 网上科普关于“齐聚天下有没有挂”话题很是火热,小编也是针对齐聚天下作*弊开挂的方法以及开挂对应的知识...
玩家分享攻略“新毛豆炸/金/花... 您好:新毛豆炸/金/花这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家在...