Ama*_*ain 61 regex linux command-line-interface
从ifconfig输出中提取MAC地址的最佳方法是什么?
样本输出:
bash-3.00# ifconfig eth0
eth0 Link encap:Ethernet HWaddr 1F:2E:19:10:3B:52
inet addr:127.0.0.66 Bcast:127.255.255.255 Mask:255.0.0.0
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
....
....
Run Code Online (Sandbox Code Playgroud)
我应该使用cut,AWK还是其他任何东西,以及一种方法相对于另一种方法的优点和缺点.
Mic*_*lis 109
你可以做一只猫 /sys/class/
cat /sys/class/net/*/address
Run Code Online (Sandbox Code Playgroud)
专门为 eth0
cat /sys/class/net/eth0/address
Run Code Online (Sandbox Code Playgroud)
Rob*_*ble 69
我会用:
ifconfig eth0 | grep -o -E '([[:xdigit:]]{1,2}:){5}[[:xdigit:]]{1,2}'
Run Code Online (Sandbox Code Playgroud)
-o将导致grep仅打印与表达式匹配的行的部分. [[:xdigit:]]{1,2}将匹配1或2个十六进制数字(Solaris不输出前导零).
Jer*_*rub 23
我喜欢使用/ sbin/ip来完成这些任务,因为它更容易解析:
$ ip link show eth0
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast qlen 1000
link/ether 00:0c:29:30:21:48 brd ff:ff:ff:ff:ff:ff
Run Code Online (Sandbox Code Playgroud)
您可以使用awk从此输出中轻松获取mac地址:
$ ip link show eth0 | awk '/ether/ {print $2}'
00:0c:29:30:21:48
Run Code Online (Sandbox Code Playgroud)
如果你想付出更多的努力,并解析更多的数据,我建议使用ip命令的-online参数,这将让你将每一行视为一个新设备:
$ ip -o link
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 16436 qdisc noqueue \ link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast qlen 1000\ link/ether 00:0c:29:30:21:48 brd ff:ff:ff:ff:ff:ff
3: eth1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast qlen 1000\ link/ether 00:0c:29:30:21:52 brd ff:ff:ff:ff:ff:ff
4: tun0: <POINTOPOINT,MULTICAST,NOARP,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast qlen 100\ link/[65534]
5: sit0: <NOARP> mtu 1480 qdisc noop \ link/sit 0.0.0.0 brd 0.0.0.0
Run Code Online (Sandbox Code Playgroud)
alb*_*rtb 11
不确定是否确实有任何优势,但你可以简单地使用awk:
ifconfig eth0 | awk '/HWaddr/ {print $5}'
Run Code Online (Sandbox Code Playgroud)