可能是一个愚蠢的问题,但看不到 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
有人能帮我吗?