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 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |