繁体   English   中英

使用JQ和Bash在JSON对象中添加键值对

[英]Add a Key Value Pair in JSON Object Using JQ and Bash

编辑此帖子以进行澄清,因为我第一次做得不好-

我有一个脚本,该脚本可爬网目录并从WP网站中提取信息,并构建对象的JSON数组,这些对象最终将被馈送到可视仪表板中。 该脚本可以完美运行,但是我似乎无法像在第一个对象中那样获取siteurl键以将其发布到每个对象中。

需要将具有null的密钥对替换siteurl数组中的相应siteurl

我觉得我应该可以使用jq和--arg name value选项来执行此操作,但显然我做错了。 不知道我没有正确传递变量还是WPCLI有问题。

输出和脚本如下。

[
  {
    "eventType": "WordpressSite",
    "siteurl": "http://mytest1.com"
  },
  {
    "eventType": "WordpressPlugin",
    "plugin_name": "akismet",
    "plugin_status": "inactive",
    "plugin_update": "available",
    "plugin_version": "4.0.8",
    "siteurl": null
  },
  {
    "eventType": "WordpressPlugin",
    "plugin_name": "hello",
    "plugin_status": "inactive",
    "plugin_update": "none",
    "plugin_version": "1.7",
    "siteurl": null
  },
  {
    "eventType": "WordpressUser",
    "siteurl": null,
    "user_email": "example.user@email.com",
    "user_name": "testuser1",
    "user_registered": "2018-11-26 17:44:09",
    "user_role": "administrator"
  }
]
[
  {
    "eventType": "WordpressSite",
    "siteurl": "http://mytest2.com"
  },
  {
    "eventType": "WordpressPlugin",
    "plugin_name": "akismet",
    "plugin_status": "inactive",
    "plugin_update": "available",
    "plugin_version": "4.0.8",
    "siteurl": null
  },
  {
    "eventType": "WordpressPlugin",
    "plugin_name": "hello",
    "plugin_status": "inactive",
    "plugin_update": "none",
    "plugin_version": "1.7",
    "siteurl": null
  },
  {
    "eventType": "WordpressUser",
    "siteurl": null,
    "user_email": "example.user@email.com",
    "user_name": "testuser2",
    "user_registered": "2018-11-26 17:44:04",
    "user_role": "administrator"
  }
]

#!/bin/bash

#for d in /var/www/* ; do
#   echo "$d"
#done

for f in /var/www/*/public_html/; do
    if [[ -d $f ]]; then
                #echo "$f"

                cd $f;
                siteurl=$(wp option get siteurl)
                users=$(wp user list --fields=display_name,user_email,user_registered,roles --format=json | jq '.[] | .eventType = "WordpressUser"' | jq . --arg siteurl $(wp option get siteurl) | jq '. + {"user_name": .display_name, "user_role": .roles, "siteurl": ."$siteurl"} | del (.display_name, .roles)')
                plugins=$(wp plugin list --format=json | jq '.[] | .eventType = "WordpressPlugin"' | jq '. + {"plugin_name": .name, "plugin_status": .status, "plugin_version": .version, "plugin_update": .update, "siteurl": ."$siteurl"} | del(.name, .status, .version, .update)')


                {
                printf '{"eventType":"WordpressSite","siteurl":"%s"}\n' "$(wp option get siteurl)"
                echo "$plugins"
                echo "$users"
                } | jq -sS .
                cd ../..;
    fi
done

要将"siteurl":"http://mysite1.com"到每个对象:

jq 'map(.siteurl = "http://mytest1.com")' file.json

要从第一个对象复制siteurl

jq '.[0].siteurl as $v | map(.siteurl = $v)' file.json

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM