以前从未使用过shell脚本,但是我需要在当前任务中使用。
所以我必须运行一个返回如下输出的命令:
awd54a7w6ds54awd47awd refs/heads/SomeInfo1
awdafawe23413f13a3r3r refs/heads/SomeInfo2
a8wd5a8w5da78d6asawd7 refs/heads/SomeInfo3
g9reh9wrg69egs7ef987e refs/heads/SomeInfo4
我需要遍历输出的每一行,只获得“ SomeInfo”部分,并将其以以下格式写入文件:
["SomeInfo1","SomeInfo2","SomeInfo3"]
我已经尝试过这样的事情:
for i in $(some command); do
echo $i | cut -f2 -d"heads/" >> text.txt
done
但是我不知道如何在不使用临时文件的情况下将其格式化为数组。
抱歉,这个问题很愚蠢,可能太简单了,我不确定我可以自己解决这个问题,但是我只是没有时间解决这个问题,因为它只是我个人想要实现的一个额外的便利功能。
答案 0 :(得分:2)
尝试一下
# json_encoder.sh
arr=()
while read line; do
arr+=(\"$(basename "$line")\")
done
printf "[%s]" $(IFS=,; echo "${arr[*]}")
然后调用
./your_command | json_encoder.sh
PS。我个人使用Vim进行这种数据按摩。
答案 1 :(得分:0)
尽管您几乎不应该使用脚本来格式化json,但是在您的情况下,您只是将输出解析为以逗号分隔的行,并添加了[...]
的大写字母。您可以使用bash 参数扩展来避免产生任何其他子shell来获取每一行中的最后一个信息字段,如下所示:
#!/bin/bash
[ -z "$1" -o ! -r "$1" ] && { ## validate file given as argument
printf "error: file doesn't exist or not readable.\n" >&2
exit 1
}
c=0 ## simple flag variable
while read -r line; do ## read each line
if [ "$c" -eq '0' ]; then ## is flag 0?
printf "[\"%s\"" "${line##*/}" ## output ["last"
else ## otherwise
printf ",\"%s\"" "${line##*/}" ## output ,"last"
fi
c=1 ## set flag 1
done < file ## redirect file to loop
echo "]" ## append closing ]
使用/输出示例
使用给定的数据作为输入文件,您将获得以下信息:
$ bash script.sh file
["SomeInfo1","SomeInfo2","SomeInfo3","SomeInfo4"]
仔细研究一下,如果您有任何疑问,请告诉我。
答案 2 :(得分:0)
您也可以在没有任何循环的情况下使用awk:
cat prev_output | awk -v ORS=',' -F'/' '{print "\042"$3"\042"}' | \
sed 's/^/[/g ; s/,$/]\n/g' > new_output
cat new_output
["SomeInfo1","SomeInfo2","SomeInfo3","SomeInfo4"]
答案 3 :(得分:0)
使用Perl单线版
$ cat petar.txt
awd54a7w6ds54awd47awd refs/heads/SomeInfo1
awdafawe23413f13a3r3r refs/heads/SomeInfo2
a8wd5a8w5da78d6asawd7 refs/heads/SomeInfo3
g9reh9wrg69egs7ef987e refs/heads/SomeInfo4
$ perl -ne ' { /.*\/(.*)/ and push(@res,"\"$1\"") } END { print "[".join(",",@res)."]\n" }' petar.txt
["SomeInfo1","SomeInfo2","SomeInfo3","SomeInfo4"]