jq将一个文件的内容更新为另一个文件作为键值

时间:2018-05-28 06:40:59

标签: json jq

我正在尝试从branch2.json.Employes值更新branches.json.branch2值 使用jq,如何将一个文件的内容合并到另一个文件 以下是文件

我试过这个,但它确实有效,它只打印原始数据而不更新细节

#!/bin/sh
#call file with branch name for example ./update.sh branch2
set -xe
branchName=$1
fullPath=`pwd`/$1".json"
list=$(cat ${fullPath})
branchDetails=$(echo ${list} | /usr/local/bin/jq -r '.Employes')
newJson=$(cat branches.json | 
      jq --arg updateKey "$1" --arg updateValue "$branchDetails" 'to_entries | 
       map(if .key == "$updateKey"
          then . + {"value":"$updateValue"} 
          else . 
          end) | 
          from_entries')

echo $ newJson&> results.json

branch1.json

{
  "Employes": [
    {
      "Name": "Ikon",
      "age": "30"
    },
    {
      "Name": "Lenon",
      "age": "35"
    }
  ]
}

branch2.json

{
  "Employes": [
    {
      "Name": "Ken",
      "age": "40"
    },
    {
      "Name": "Frank",
      "age": "23"
    }
  ]
}

brances.json / results.json fromat

{
  "branch1": [
      {
        "Name": "Ikon",
        "age": "30"
      },
      {
        "Name": "Lenon",
        "age": "35"
      }
    ],
  "branch2": [
      {
        "Name": "Ken",
        "age": "40"
      },
      {
        "Name": "Frank",
        "age": "23"
      }
    ]

}

注意:我没有任何给定点的所有分支文件的列表,因此脚本只负责更新该分支的详细信息。

1 个答案:

答案 0 :(得分:0)

如果文件名是要更新的属性的名称,则可以使用input_filename来选择文件。无需测试,只需传入要更新的文件即可。请注意您在输入文件中传递的顺序。

根据需要合并文件的内容。要简单地替换,只需做一个简单的任务。

$ jq 'reduce inputs as $i (.;
    .[input_filename|rtrimstr(".json")] = $i.Employes
)' branches.json branch{1,2}.json

您的脚本只需要:

#!/bin/sh
#call file with branch name for example ./update.sh branch2
set -xe
branchName=$1
newJson=$(jq 'reduce inputs as $i (.; .[input_filename|rtrimstr(".json")] = $i.Employees)' branches.json "$branchName.json")