Bash不会继续执行

时间:2013-10-22 17:11:28

标签: bash sed cut

我正在解析提取的字符串的结果。我的问题是在处理第一个元素后执行停止。

这是我的代码:

#!/bin/bash

SCAN_RESULT=$(arp-scan --ignoredups --interface=$1 --localnet)
HEADER_REMOVED=$(echo "$SCAN_RESULT" | sed '1,2d')
NO_HEADER_LINE_COUNT=$(echo "$HEADER_REMOVED" | wc -l)
CAPTURED_DEVICE_INFO=$(echo "$HEADER_REMOVED" | sed $(expr $NO_HEADER_LINE_COUNT - 2),"$NO_HEADER_LINE_COUNT"d)
DATA=$(echo "$CAPTURED_DEVICE_INFO" | sed 's/[\t]/;/g')

DATA_LINE_COUNT=$(echo "$DATA" | wc -l)

echo -n '['
for ((i=0; i<$DATA_LINE_COUNT; i++))  # stops execution after 1st cycle
do
    EXTRACTED_DATA=$(echo "$DATA" | sed $(expr "$i" + 1)'!d')
    echo -n '{'
    COMMA_INNER=''
    for i in {1..3}
    do
        echo -n "$COMMA_INNER"      
        case $i in
            1) echo -n '"ip":' ;;
            2) echo -n '"mac":' ;;
            3) echo -n '"manufacturer":' ;;
        esac
        echo -n '"'
        echo -n $(echo $EXTRACTED_DATA | cut -d ';' -f$i)
        echo -n '"'
        COMMA_INNER=','
    done
    echo -n '}'
done
echo -n ']'

这是arp-scan的输出字符串:

Interface: eth0, datalink type: EN10MB (Ethernet)
Starting arp-scan 1.8.1 with 16 hosts (http://www.nta-monitor.com/tools/arp-scan/)
192.168.0.1     20:aa:4b:c0:22:78       (Unknown)
192.168.0.5     48:5b:39:a0:60:ba       ASUSTek COMPUTER INC.
192.168.0.7     04:7d:7b:7d:c4:e9       (Unknown)

5 packets received by filter, 0 packets dropped by kernel
Ending arp-scan 1.8.1: 16 hosts scanned in 0.819 seconds (19.54 hosts/sec). 3 responded

这是字符串(来自arp-scan)我希望被处理并作为JSON回显

192.168.0.1     20:aa:4b:c0:22:78       (Unknown)
192.168.0.5     48:5b:39:a0:60:ba       ASUSTek COMPUTER INC.
192.168.0.7     04:7d:7b:7d:c4:e9       (Unknown)

以下是示例输出:

[{"ip":"192.168.0.1","mac":"20:aa:4b:c0:22:78","manufacturer":"(Unknown)"}]

我做错了吗?

3 个答案:

答案 0 :(得分:1)

arp-scan --ignoredups --interface=$1 --localnet | {
  read; read    # Discard the first two header lines
  printf "["
  comma=''
  while read ip mac manufacturer; do
    printf '%s{"ip":"%s", "mac":"%s", "manufacturer":"%s"},' "$comma" "$ip" "$mac" "$manufactuer"
    comma=','
  done
  printf "]\n"
}

答案 1 :(得分:1)

您正在使用

  • 两个循环和
  • 的相同变量(i
  • 使用cut拆分行时使用错误的分隔符(使用' '代替';')。

然而,chepner的解决方案应该会好得多。

答案 2 :(得分:1)

如果我正确地理解了你的问题(一个很大的如果,那就非常不清楚了),这样就可以了:

sed '1,2d;s/^/[{"ip":"/;s/  */","mac":"/;s/  */","manufacturer":"/;s/$/"}]/'