0

可能是一个愚蠢的问题,但看不到 while abort 的原因。

我有一个这样的文件:

"id": "00000000000000000",
"visibilitystate": 1,
"profilestate": 8
"somethingelse": "abc",
"id": "99999999999999999",
"againsomethingelse": "cba"
"visibilitystate": 0,
"profilestate": 9

100 万次或更多的重复次数、编号、名称和值在 id 和 id 之间可能不同,但 id 总是不同的。我的第一个想法是循环读取,将值存储在数组中,然后插入 mysql-db。

我试试这个:

set -x
#Data extract array
array=(0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0)

#Control array
array2=(0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0)

while read a; do
    if [[ ${array2[0]} == 1 ]]; then
        awk '/"id":/ { exit 42 }'
        if [[ $? -eq 42 ]]; then
            echo mysql
            array2[0]=0
        fi
    fi
    if [[ ${array2[0]} == 0 ]]; then
        awk '/"id":/ { exit 42 }'
        if [ $? -eq 42 ]; then
            array[0]=`sed -n 's/.*"id":."\(.*\)",.*/\1/p'`
            array2[0]=1
        fi
    fi
done <testf

set +x

读完一行,循环退出,不明白为什么。

输出:

+ array=(0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0)
+ array2=(0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0)
+ read a
+ [[ 0 == 1 ]]
+ [[ 0 == 0 ]]
+ awk '/"id":/ { exit 42 }'
+ '[' 42 -eq 42 ']'
++ sed -n 's/.*"id":."\(.*\)",.*/\1/p'
+ array[0]=
+ array2[0]=1
+ read a
+ set +x

有人能帮我吗?

4

1 回答 1

2

剧本有3个问题。您在循环中使用了 3 个不同的命令,这些命令从标准输入(awk两次和sed)读取。

当您使用awk '/"id":/ { exit 42 }'它时,它会读取其他所有内容(输入文件)。您可能希望在$a. 那将是这样的:

echo $a | awk '/"id":/ { exit 42 }'

第二个错误是一样的,但是在 next 中if

第三个错误类似,但在这种情况下,当您使用sed. 您可能想要执行以下操作:

array[0]=`echo $a | sed -n 's/.*"id":."\(.*\)",.*/\1/p'`

顺便说一句,test是 bash 中的保留字,您应该避免将其用作文件名(但与您的问题无关)。

于 2012-10-15T01:39:10.693 回答