如何获得iw和iwinfo命令输出的所有BSSID?下面是获取所有SSID的iw和iwinfo命令。iw:
iw dev wlan0 scan 2>/dev/null | awk '
/SSID: / {
if (!seen[$0]++) {
printf "\""
for (i = 2; i <= NF; i++) if (i == 2) printf $i
else printf " " $i
printf "\" "
}
}
'iwinfo:
iwinfo wlan0 scan | awk '
/ESSID: ".*"/ {
ORS = " "
if (!seen[$0]++) for (i = 2; i <= NF; i++) print $i
}
'当前awk输出:
"WiFi-1“"WiFi-2”"WiFi-3“"WiFi-4”"WiFi-5“
iw控制台输出:
BSS 01:23:45:67:89:AB(on wlan0)
TSF: 128785915910 usec (1d, 11:46:25)
freq: 2437
beacon interval: 200 TUs
capability: ESS ShortPreamble ShortSlotTime (0x0421)
signal: -71.00 dBm
last seen: 990 ms ago
Information elements from Probe Response frame:
SSID: WiFi-1
Supported rates: 1.0* 2.0* 5.5* 6.0 9.0 11.0* 12.0 18.0
DS Parameter set: channel 6
Country: SK Environment: Indoor/Outdoor
Channels [1 - 13] @ 20 dBm
ERP: <no flags>
Extended supported rates: 24.0 36.0 48.0 54.0
WMM: * Parameter version 1
* BE: CW 15-1023, AIFSN 3
* BK: CW 15-1023, AIFSN 7
* VI: CW 7-15, AIFSN 2, TXOP 3008 usec
* VO: CW 3-7, AIFSN 2, TXOP 1504 usec
BSS CD:EF:A0:A1:A2:A3(on wlan0)
TSF: 2381690679244 usec (27d, 13:34:50)
freq: 2467
beacon interval: 200 TUs
capability: ESS ShortPreamble ShortSlotTime (0x0421)
signal: -94.00 dBm
last seen: 90 ms ago
Information elements from Probe Response frame:
SSID: WiFi-2
Supported rates: 1.0* 2.0* 5.5* 6.0 9.0 11.0* 12.0 18.0
DS Parameter set: channel 12
Country: SK Environment: Indoor/Outdoor
Channels [1 - 13] @ 20 dBm
ERP: <no flags>
Extended supported rates: 24.0 36.0 48.0 54.0
WMM: * Parameter version 1
* BE: CW 15-1023, AIFSN 3
* BK: CW 15-1023, AIFSN 7
* VI: CW 7-15, AIFSN 2, TXOP 3008 usec
* VO: CW 3-7, AIFSN 2, TXOP 1504 useciwinfo控制台输出:
Cell 01 - Address: 01:23:45:67:89:AB
ESSID: "WiFi-1"
Mode: Master Channel: 11
Signal: -49 dBm Quality: 61/70
Encryption: WPA2 PSK (CCMP)
Cell 02 - Address: CD:EF:A0:A1:A2:A3
ESSID: "WiFi-2"
Mode: Master Channel: 11
Signal: -53 dBm Quality: 57/70
Encryption: WPA2 PSK (CCMP)我想使用awk获得以下输出:
"01:23:45:67:89:AB“CD:EF:A0:A1:A2:A3
使用Awk为两个库(iw & iwinfo)捕获所有BSSID的正确方法是什么?
发布于 2017-01-11 15:52:20
使用GNU awk进行第三次arg匹配():
{ cat iw_output; cat iwinfo_output; } |
awk 'match($0,/([[:xdigit:]]{1,2}:){5}[[:xdigit:]]{1,2}/,a) && !seen[a[0]]++{print a[0]}'
01:23:45:67:89:AB
CD:EF:A0:A1:A2:A3或者获取问题中所要求的输出格式:
{ cat iw_output; cat iwinfo_output; } |
awk 'match($0,/([[:xdigit:]]{1,2}:){5}[[:xdigit:]]{1,2}/,a) && !seen[a[0]]++{printf "%s\"%s\"", (c++?OFS:""), a[0]} END{print ""}'
"01:23:45:67:89:AB" "CD:EF:A0:A1:A2:A3"对于其他的awk,您将使用substr($0,RSTART,RLENGTH)而不是a[0]。
发布于 2017-01-11 09:41:13
最新答案
如果要使输出唯一,则可以通过sort和uniq运行我的原始答案中的命令的结果。
{ iw ...; iwinfo ...; } | grep -Eo '([[:xdigit:]]{1,2}:){5}[[:xdigit:]]{1,2}' | sort | uniq如果您想用双引号将它们包装起来,并将换行符替换为空格,您可以这样做:
{ iw ...; iwinfo ...; } | grep -Eo '([[:xdigit:]]{1,2}:){5}[[:xdigit:]]{1,2}' | sort | uniq | sed -E 's|(.*)|"\1"|' | tr '\n' ' '
"01:23:45:67:89:AB" "CD:EF:A0:A1:A2:A3"原始答案
我对你的问题感到困惑,但我认为这会做你想做的事:
{ iw dev wlan0 scan 2>/dev/null; iwinfo wlan0 scan; } | grep -Eo '([[:xdigit:]]{1,2}:){5}[[:xdigit:]]{1,2}'样本输出
01:23:45:67:89:AB
CD:EF:A0:A1:A2:A3
01:23:45:67:89:AB
CD:EF:A0:A1:A2:A3发布于 2017-01-11 09:46:22
@Martin:试着:
Your_command | awk -vs1="\"" '/^Cell/{VAL=VAL?VAL s1 $NF s1:s1 $NF s1} END{print VAL}' https://stackoverflow.com/questions/41579598
复制相似问题