[英]How to iterate a JSON array in bash from jq
我希望能够将 json 文件传递给 WP CLI,以迭代地创建帖子。
所以我想我可以创建一个 JSON 文件:
[
{
"post_type": "post",
"post_title": "Test",
"post_content": "[leaflet-map][leaflet-marker]",
"post_status": "publish"
},
{
"post_type": "post",
"post_title": "Number 2",
"post_content": "[leaflet-map fitbounds][leaflet-circle]",
"post_status": "publish"
}
]
并用 jq 迭代数组:
cat posts.json | jq --raw-output .[]
我希望能够迭代这些以执行类似的功能:
wp post create \
--post_type=post \
--post_title='Test Map' \
--post_content='[leaflet-map] [leaflet-marker]' \
--post_status='publish'
有没有办法用jq
或类似的方法来做到这一点?
到目前为止,我得到的最接近的是:
> for i in $(cat posts.json | jq -c .[]); do echo $i; done
但这似乎与字符串中的(有效)空格有关。 输出:
{"post_type":"post","post_title":"Test","post_content":"[leaflet-map][leaflet-marker]","post_status":"publish"}
{"post_type":"post","post_title":"Number
2","post_content":"[leaflet-map
fitbounds][leaflet-circle]","post_status":"publish"}
我离这种方法不远了,还是可以做到?
使用一段while
来读取整行,而不是迭代命令替换产生的单词。
while IFS= read -r obj; do
...
done < <(jq -c '.[]' posts.json)
也许这对你有用:
制作一个 bash 可执行文件,也许称之为wpfunction.sh
#!/bin/bash
wp post create \
--post_type="$1"\
--post_title="$2" \
--post_content="$3" \
--post_status="$4"
然后在您的posts.json
上运行jq
并将其通过管道posts.json
到xargs
jq -M -c '.[] | [.post_type, .post_title, .post_content, .post_status][]' \
posts.json | xargs -n4 ./wpfunction`
我正在尝试看看这将如何处理包含引号的 post_content ......
首先生成您希望传递的参数数组,然后使用@sh
转换为与 shell 兼容的形式。 然后你可以传递给 xargs 来调用命令。
$ jq -r '.[] | ["post", "create", (to_entries[] | "--\(.key)=\(.value|tojson)")] | @sh' input.json | xargs wp
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.