加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Linux > 正文

linux – 如何格式化ifconfig的输出

发布时间:2020-12-14 01:22:49 所属栏目:Linux 来源:网络整理
导读:我需要将命令ifconfig -a的结果转换为以下格式 IFACE eth0 192.168.30.8 EthernetIFACE eth1 212.233.112.171 EthernetIFACE lo 127.0.0.1 Local Loopback IFACE pan0 0.0.0.0 EthernetIFACE tunl0 0.0.0.0 IPIP Tunnel 我知道我应该用sed或类似的东西做到这
我需要将命令ifconfig -a的结果转换为以下格式

IFACE eth0 192.168.30.8 Ethernet
IFACE eth1 212.233.112.171 Ethernet
IFACE lo 127.0.0.1 Local Loopback 
IFACE pan0 0.0.0.0 Ethernet
IFACE tunl0 0.0.0.0 IPIP Tunnel

我知道我应该用sed或类似的东西做到这一点.
现在我有以下“脚本”:

ifconfig -a | sed -r -n -e 'N' -e 's/(w+)(s*)(Linksencap:)(w+(sw+)*)([^n]*)ns+(inetsaddr:)([0-9]{1,3}(.[0-9]{1,3}){3}).*/IFACE 1 8 4/p'

原来的ifconfig -a输出是(…表示无限部分)

eth0      Link encap:Ethernet  HWaddr f4:ce:46:99:22:57
          inet addr:192.168.30.8  Bcast:192.168.31.255  Mask:255.255.254.0
          ...
eth1      Link encap:Ethernet  HWaddr 00:23:7d:fd:a2:d0
          inet addr:212.233.112.171  Bcast:212.233.112.175  Mask:255.255.255.240
          ...
lo        Link encap:Local Loopback
          inet addr:127.0.0.1  Mask:255.0.0.0
          ...
pan0      Link encap:Ethernet  HWaddr f6:d0:8a:0e:7b:95
          BROADCAST MULTICAST  MTU:1500  Metric:1
          ...
tunl0     Link encap:IPIP Tunnel  HWaddr
          NOARP  MTU:1480  Metric:1
          ...

此转换的第一个问题是IP地址位于接口名称和类型的第二行.使用-N参数来连接行,但它们是成对连接的,如果接口的名称在奇数行上 – 我有麻烦:脚本跳过奇数行上的接口,就像这样(注意那里没有提到输出中的pan0.):

IFACE eth0 192.168.30.8 Ethernet 
IFACE eth1 212.233.112.171 Ethernet 
IFACE lo 127.0.0.1 Local Loopback
IFACE tunl0 IPIP Tunnel

第二个问题是,当ifconfig -a输出中没有IP地址时,我不知道如何插入零地址.

解决方法

请注意,ifconfig输出因平台而异,因此这不是一种非常便携的方法.

至于sed解决方案,我认为你需要将解析分解为多个步骤,这样的事情应该可行(GNU sed):

parse.sed

s/^([^ ]+) */1n/                               # interface name
s/Link encap:(.*)(  |$).*/1/                    # link encapsulation
N                                                # append next line to PS
/inet addr/! s/n[^n]*$/n0.0.0.0n/            # use 0.0.0.0 if no "inet addr"
s/ *inet addr:([^ ]+).*/1n/                    # capture ip address if present
s/n[^n]*$//                                    # cleanup the last line
s/([^n]+)n([^n]+)n([^n]+)/IFACE 1 3 2/p  # print entry
s/.*//                                           # empty PS
: loop                                           # 
N                                                #  
/^n$/b                                          #   skip until next empty line
s/.*//                                           #  /
b loop                                           # /

说明

我们的想法是使用换行符分隔符捕获模式空间中的所有相关信息.

测试

像这样运行:

ifconfig -a | sed -rf parse.sed

输出:

IFACE eth0 192.168.30.8 Ethernet
IFACE eth1 212.233.112.171 Ethernet
IFACE lo 127.0.0.1 Local Loopback
IFACE pan0 0.0.0.0 Ethernet
IFACE tunl0 IPIP Tunnel

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读