[
    {
        "tags": [
            "json",
            "object",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4199134,
                    "reputation": 3707,
                    "user_id": 3439731,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://i.sstatic.net/FMgxG.jpg?s=256",
                    "display_name": "Raghav Garg",
                    "link": "https://stackoverflow.com/users/3439731/raghav-garg"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1544607412,
                "post_id": 53739817,
                "comment_id": 94332601,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1544607434,
                "creation_date": 1544607434,
                "answer_id": 53740029,
                "question_id": 53739817,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `with_entries()` is much shorter, with which you can just do\r\n\r\n    jq &#39;with_entries(select((.value | length) &gt; 0))&#39; json\r\n\r\nFor your question, `from_entries` does the opposite conversion of `to_entries`. And using `with_entries(foo)` is a shorthand for `to_entries | map(foo) | from_entries` syntax.",
                "title": "How to reconstruct single object after its deconstruction in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1544656530,
        "creation_date": 1544606753,
        "last_edit_date": 1544656530,
        "question_id": 53739817,
        "body_markdown": "I receive a quite big json file with lots of properties that are there only for historical reasons and are not used anymore. To simplify this file, I&#39;ve used `jq`, deconstructed json with `to_entries`, but now I don&#39;t know how to rebuild my object back with sub-objects that remained.\r\n\r\nHere&#39;s example:\r\n\r\ninput\r\n\r\n    {\r\n      &quot;empty1&quot;: [],\r\n      &quot;empty2&quot;: [],\r\n      &quot;full1&quot;: &quot;test&quot;,\r\n      &quot;full2&quot;: { &quot;a&quot;: 1, &quot;b&quot;: 2 }\r\n    }\r\n\r\ncurrent filter:\r\n\r\n    to_entries[] | select((.value | length) &gt; 0) | { (.key) : .value }\r\n\r\ncurrent output\r\n\r\n    {&quot;full1&quot;:&quot;test&quot;}\r\n    {&quot;full2&quot;:{&quot;a&quot;:1,&quot;b&quot;:2}}\r\n\r\ndesired output\r\n\r\n    {\r\n      &quot;full1&quot;: &quot;test&quot;,\r\n      &quot;full2&quot;: {\r\n        &quot;a&quot;: 1,\r\n        &quot;b&quot;: 2\r\n      }\r\n    }",
        "link": "https://stackoverflow.com/questions/53739817/how-to-reconstruct-single-object-after-its-deconstruction-in-jq",
        "title": "How to reconstruct single object after its deconstruction in jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 25691120,
                    "reputation": 175,
                    "user_id": 19452526,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/SUjcc.jpg?s=256",
                    "display_name": "Richard",
                    "link": "https://stackoverflow.com/users/19452526/richard"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1658794459,
                "post_id": 53742316,
                "comment_id": 129135282,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25691120,
                    "reputation": 175,
                    "user_id": 19452526,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/SUjcc.jpg?s=256",
                    "display_name": "Richard",
                    "link": "https://stackoverflow.com/users/19452526/richard"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1658794541,
                "post_id": 53742316,
                "comment_id": 129135294,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1544615052,
                "creation_date": 1544615052,
                "answer_id": 53742317,
                "question_id": 53742316,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use quotes:\r\n\r\n    $ jq &#39;.&quot;1&quot;&#39; example.json\r\n    &quot;foo&quot;\r\n    ",
                "title": "How to get value of numeric object property via jq?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1544615700,
                "creation_date": 1544615700,
                "answer_id": 53742485,
                "question_id": 53742316,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The command:\r\n\r\n    jq .&quot;1&quot; example.json\r\n\r\ndoesn&#39;t work because the quotes are interpreted by the shell and the first argument that `jq` receives is `.1`. The command above is identical to `jq .1 example.json` and it is not correct as `jq` reports.\r\n\r\nYou need to enclose the `jq` program in apostrophes to prevent the shell interpret any character in it:\r\n\r\n    jq &#39;.&quot;1&quot;&#39; example.json\r\n\r\nThis way, `jq` receives `.&quot;1&quot;` as its program and happily interprets it.\r\n\r\nYou can also put the key name into square brackets (as you have already tried) but it doesn&#39;t add any improvement, it&#39;s the same program only bloated. And it gives you more reasons to put it into apostrophes to protect it from the shell:\r\n\r\n    jq &#39;.[&quot;1&quot;]&#39; example.json\r\n\r\n",
                "title": "How to get value of numeric object property via jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1544624566,
        "creation_date": 1544615052,
        "last_edit_date": 1544624566,
        "question_id": 53742316,
        "body_markdown": "I have a json object with numeric keys in an `example.json` file:\r\n\r\n    {\r\n      &quot;1&quot;: &quot;foo&quot;,\r\n      &quot;2&quot;: &quot;bar&quot;\r\n    }\r\n\r\nI want to get its properties by key via `jq`, and I have tried:\r\n\r\n    $ jq .&quot;1&quot; example.json\r\n    0.1\r\n\r\nand\r\n\r\n    jq .[&quot;1&quot;] example.json\r\n    jq: error (at example.json:4): Cannot index object with number\r\n\r\nThe result should be\r\n\r\n    &quot;foo&quot;\r\n\r\nthough.",
        "link": "https://stackoverflow.com/questions/53742316/how-to-get-value-of-numeric-object-property-via-jq",
        "title": "How to get value of numeric object property via jq?"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq",
            "flatten"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1544673653,
                "creation_date": 1544673653,
                "answer_id": 53754835,
                "question_id": 53754702,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can only apply `@csv` over an array content, just enclose your filter within a `[..]` as below\r\n\r\n    jq -r &#39;[.Volumes[] | .VolumeId, .AvailabilityZone, .Attachments[].InstanceId, .Attachments[].State, (.Tags // [] | from_entries.Name)]|@csv&#39;\r\n\r\nUsing the above might still retain the quotes, so using `join()` would also be appropriate here\r\n\r\n    jq -r &#39;[.Volumes[] | .VolumeId, .AvailabilityZone, .Attachments[].InstanceId, .Attachments[].State, (.Tags // [] | from_entries.Name)] | join(&quot;,&quot;)&#39;",
                "title": "Can&#39;t put JSON output into CSV format with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1594237613,
                "creation_date": 1594237613,
                "answer_id": 62802552,
                "question_id": 53754702,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The [accepted Answer](https://stackoverflow.com/a/53754835/5025060) resolves another obscure jq error: \r\n\r\n&gt; string (&quot;xxx&quot;) cannot be csv-formatted, only array\r\n\r\nIn my case I did not want the ***entire*** output of jq, but rather each Elastic Search *document* I supplied to jq to be printed as a CSV string on a line of its own.  To accomplish this I simply ***moved the brackets to enclose only the items to be included on each line***.\r\n\r\nFirst, by placing my brackets only around items to be included on each line of output, I produced:\r\n```\r\njq -r &#39;.hits.hits[]._source | [.syscheck.path, .syscheck.size_after]&#39;\r\n[\r\n  &quot;/etc/group-&quot;,\r\n  &quot;783&quot;\r\n]\r\n[\r\n  &quot;/etc/gshadow-&quot;,\r\n  &quot;640&quot;\r\n]\r\n[\r\n  &quot;/etc/group&quot;,\r\n  &quot;795&quot;\r\n]\r\n[\r\n  &quot;/etc/gshadow&quot;,\r\n  &quot;652&quot;\r\n]\r\n[\r\n  &quot;/etc/ssh/sshd_config&quot;,\r\n  &quot;3940&quot;\r\n]\r\n```\r\nPiping this to `| @csv` prints each document&#39;s values of .syscheck.path and .syscheck.size_after, quoted and comma-separated, on a separate line:\r\n```\r\n$ jq -r &#39;.hits.hits[]._source | [.syscheck.path, .syscheck.size_after] | @csv&#39;\r\n&quot;/etc/group-&quot;,&quot;783&quot;\r\n&quot;/etc/gshadow-&quot;,&quot;640&quot;\r\n&quot;/etc/group&quot;,&quot;795&quot;\r\n&quot;/etc/gshadow&quot;,&quot;652&quot;\r\n&quot;/etc/ssh/sshd_config&quot;,&quot;3940&quot;\r\n```\r\n\r\nOr to omit quotation marks, following the pattern noted in the accepted Answer:\r\n```\r\n$ jq -r &#39;.hits.hits[]._source | [.syscheck.path, .syscheck.size_after] | join(&quot;,&quot;)&#39;\r\n/etc/group-,783\r\n/etc/gshadow-,640\r\n/etc/group,795\r\n/etc/gshadow,652\r\n/etc/ssh/sshd_config,3940\r\n```",
                "title": "Can&#39;t put JSON output into CSV format with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1594237613,
        "creation_date": 1544672392,
        "last_edit_date": 1544686920,
        "question_id": 53754702,
        "body_markdown": "I&#39;m building a list of AWS EBS volumes attributes so I can store it as CSV in a variable, using jq. I&#39;m going to output the variable to a spread sheet.\r\n\r\nThe first command gives the values I&#39;m looking for using jq:\r\n\r\n    aws ec2 describe-volumes | jq -r &#39;.Volumes[] | .VolumeId, .AvailabilityZone, .Attachments[].InstanceId, .Attachments[].State, (.Tags // [] | from_entries.Name)&#39;\r\n\r\nGives output that I want like this:\r\n\r\n    MIAPRBcdm0002_test_instance\r\n    vol-0105a1678373ae440\r\n    us-east-1c\r\n    i-0403bef9c0f6062e6\r\n    attached\r\n    MIAPRBcdwb00000_app1_vpc\r\n    vol-0d6048ec6b2b6f1a4\r\n    us-east-1c\r\n    MIAPRBcdwb00001 /carbon\r\n    vol-0cfcc6e164d91f42f\r\n    us-east-1c\r\n    i-0403bef9c0f6062e6\r\n    attached\r\n\r\nHowever, if I put it into CSV format so I can output the variable to a spread sheet, the command blows up and doesn&#39;t work:\r\n\r\n    aws ec2 describe-volumes | jq -r &#39;.Volumes[] | .VolumeId, .AvailabilityZone, .Attachments[].InstanceId, .Attachments[].State, (.Tags // [] | from_entries.Name)| @csv&#39;\r\n    jq: error (at &lt;stdin&gt;:4418): string (&quot;vol-743d1234&quot;) cannot be csv-formatted, only array\r\n\r\nEven putting the top level of the JSON into CSV format fails for EBS volumes:\r\n\r\n    aws ec2 describe-volumes | jq -r &#39;.Volumes[].VolumeId | @csv&#39;\r\n    jq: error (at &lt;stdin&gt;:4418): string (&quot;vol-743d1234&quot;) cannot be csv-formatted, only array\r\n\r\nHere is the [AWS EBS Volumes JSON FILE][1] that I am working with, with these commands (the file has been cleaned of company identifiers, but is valid json).\r\n\r\nHow can I get this json into CSV format using jq?\r\n\r\n\r\n  [1]: https://gist.github.com/bluethundr/786ded200aee380e9bb9831af505437b",
        "link": "https://stackoverflow.com/questions/53754702/cant-put-json-output-into-csv-format-with-jq",
        "title": "Can&#39;t put JSON output into CSV format with jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "strptime",
            "strftime"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1002989,
                    "reputation": 1385,
                    "user_id": 1017466,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/73d62289ed695b520ad2a3ae80c45277?s=256&d=identicon&r=PG",
                    "display_name": "bluethundr",
                    "link": "https://stackoverflow.com/users/1017466/bluethundr"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1544729131,
                "post_id": 53766924,
                "comment_id": 94389354,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1544725364,
                "creation_date": 1544725364,
                "answer_id": 53767984,
                "question_id": 53766924,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You will first have to parse the string. You could use `strptime`.  Here is an illustration of how to do so: \r\n\r\n    &lt;&lt;&lt; &#39;&quot;2018-12-11T18:54.11Z&quot;&#39; jq -c &#39;\r\n    strptime(&quot;%Y-%m-%dT%H:%M.%SZ&quot;)&#39; \r\n    [2018,11,11,18,54,11,2,344]\r\n\r\nThis does not quite match your needs, because in this context &quot;%S&quot; has a specific meaning:\r\n\r\n    %S     The second as a decimal number (range 00 to 60).\r\n           (The range is up to 60 to allow for occasional leap seconds.)\r\n\r\nSo it looks like you might have to munge the incoming date-time string, e.g.:\r\n\r\n\r\n    if test(&quot;\\\\....Z$&quot;) then sub(&quot;.Z$&quot;; &quot;Z&quot;) else . end\r\n    | strptime(&quot;%Y-%m-%dT%H:%M.%SZ&quot;)\r\n    | strftime(&quot;%Y-%m-%d %H:%M:%S&quot;)\r\n \r\n",
                "title": "Format Time with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1544787949,
        "creation_date": 1544721061,
        "last_edit_date": 1544787949,
        "question_id": 53766924,
        "body_markdown": "I&#39;m building a list of EBS Volumes in AWS.\r\n\r\nI need to put the create time into a more user-friendly format. Management complains about unreadable times.\r\n\r\nIf I run this command it gives me the time the volume was created in this format:\r\n\r\n    aws ec2 describe-volumes --volume-ids vol-066e24cb8d2294605 | jq -r  &#39;.Volumes[].CreateTime&#39;\r\n\r\n    2018-12-11T18:54:26.110Z\r\n\r\nI&#39;m trying to format the time using strftime, but it doesn&#39;t work. What I get is this error:\r\n\r\n    aws ec2 describe-volumes --volume-ids vol-066e24cb8d2294605 | jq -r  &#39;.Volumes[] | .CreateTime | strftime (&quot;%Y-%m-%d %H:%M:%S&quot;)&#39;\r\n    \r\n    jq: error (at &lt;stdin&gt;:39): strftime/1 requires parsed datetime inputs\r\n\r\n\r\nWhat is the problem I&#39;m having? How can I create a user friendly time given the time format provided to me by AWS?\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53766924/format-time-with-jq",
        "title": "Format Time with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1544732547,
                "creation_date": 1544732547,
                "answer_id": 53769515,
                "question_id": 53768947,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Two helper functions will help you get you to your destination:\r\n\r\n    def sigma( f ): reduce .[] as $o (null; . + ($o | f )) ;\r\n    \r\n    def group( keyname ):\r\n      map(select(has(keyname)))\r\n      | group_by( .[keyname] )\r\n      | map({(keyname) : .[0][keyname], \r\n              cost: sigma(.cost[].totalcost | tonumber) })\r\n    ;\r\n   \r\nWith these, the following invocations:\r\n \r\n    group(&quot;account&quot;),\r\n    group(&quot;anotheraccount&quot;)\r\n\r\nyield:\r\n\r\n    [{&quot;account&quot;:&quot;1&quot;,&quot;cost&quot;:17.009999999999998},{&quot;account&quot;:&quot;2&quot;,&quot;cost&quot;:2.25}]\r\n    [{&quot;anotheraccount&quot;:&quot;a&quot;,&quot;cost&quot;:2}]\r\n\r\nYou should be able to manage the final formating step in jq.\r\n\r\n\r\n\r\n",
                "title": "jq: count nest object values based on group by"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1544732547,
        "creation_date": 1544729899,
        "last_edit_date": 1544731971,
        "question_id": 53768947,
        "body_markdown": "Json:\r\n\r\n        [\r\n      {\r\n      &quot;account&quot;: &quot;1&quot;,\r\n      &quot;cost&quot;: [\r\n          {\r\n             &quot;usage&quot;:&quot;low&quot;,\r\n             &quot;totalcost&quot;: &quot;2.01&quot;\r\n          }\r\n       ]\r\n      },\r\n      {\r\n      &quot;account&quot;: &quot;2&quot;,\r\n      &quot;cost&quot;: [\r\n          {\r\n             &quot;usage&quot;:&quot;low&quot;,\r\n             &quot;totalcost&quot;: &quot;2.25&quot;\r\n          }\r\n       ]\r\n      },\r\n      {\r\n      &quot;account&quot;: &quot;1&quot;,\r\n      &quot;cost&quot;: [\r\n          {\r\n             &quot;usage&quot;:&quot;low&quot;,\r\n             &quot;totalcost&quot;: &quot;15&quot;\r\n          }\r\n       ]\r\n      },\r\n      {\r\n      &quot;anotheraccount&quot;: &quot;a&quot;,\r\n      &quot;cost&quot;: [\r\n          {\r\n             &quot;usage&quot;:&quot;low&quot;,\r\n             &quot;totalcost&quot;: &quot;2&quot;\r\n          }\r\n       ]\r\n      }\r\n    ]\r\n\r\nResults expected:\r\n\r\n    account\tcost\r\n    1\t\t17.01\r\n    2\t\t2.25\r\n    anotheraccount cost\r\n    a              2\r\n\r\nI am able to pull out data but not sure how to aggregate it.\r\n\r\n    jq &#39;.[] | {account,cost : .cost[].totalcost}&#39;\r\n\r\nIs there a way to do this in using jq, so I get all types of accounts and costs associated with them?",
        "link": "https://stackoverflow.com/questions/53768947/jq-count-nest-object-values-based-on-group-by",
        "title": "jq: count nest object values based on group by"
    },
    {
        "tags": [
            "key",
            "edit",
            "jq",
            "recursive-descent"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1544748720,
                "last_edit_date": 1544748720,
                "creation_date": 1544736349,
                "answer_id": 53770309,
                "question_id": 53769485,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The simplest is to use `walk`:\r\n\r\n    walk( if type == &quot;object&quot;\r\n          then with_entries( if .key != &quot;_id&quot; then .key |= gsub(&quot;_&quot;;&quot;&quot;) else . end ) \r\n          else . end)\r\n\r\nIf your jq does not have `walk`, you can easily find its def by googling: jq &quot;def walk&quot;\r\n\r\n## Bonus\r\n\r\nYou can use the following helper function:\r\n\r\n    def camelcase:\r\n      def u:  if 97 &lt;= . and . &lt;= 122 then . - 32  else . end;\r\n      def c:\r\n        if length &lt;= 1 then\r\n          if .[0] == 95 then [] else . end\r\n        else if .[0] == 95 then [.[1]|u] + (.[2:] | c) else [.[0]] + (.[1:]|c) end\r\n        end;\r\n    \r\n      explode | c | implode;\r\n\r\n## Extra bonus\r\n\r\n    def camel_Case:\r\n      if test(&quot;_&quot;)\r\n      then .[0:1] as $first\r\n      | if $first | (. ==  ascii_downcase)\r\n        then $first | ascii_upcase + ([2:]|camelcase)\r\n        else camelcase\r\n        end\r\n      else .\r\n      end ;",
                "title": "Descend JSON doc paths and update field names with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1544787884,
        "creation_date": 1544732393,
        "last_edit_date": 1544787884,
        "question_id": 53769485,
        "body_markdown": "I&#39;d like to descend, to any depth, all the paths in a MongoDB JSON doc and possibly modify each field name using `jq` (`mongo shell` doesn&#39;t seem capable of doing this.).  Specifically, I&#39;d like to remove all underscores (&quot;_&quot;) in all field names except for &quot;_id&quot;.  I&#39;ve tried various combinations of `recurse` and `with_entries` without success.  So, e.g., transform this:\r\n\r\n    {\r\n      &quot;_id&quot;: &quot;doc1&quot;,\r\n      &quot;field_11&quot;: &quot;value_11&quot;,\r\n      &quot;field_12&quot;: {\r\n        &quot;field_121&quot;: {\r\n          &quot;field_1211&quot;: &quot;value_1211&quot;,\r\n          &quot;field_1212&quot;: &quot;value_1212&quot;\r\n        },\r\n        &quot;field_122&quot;: {\r\n          &quot;field_1221&quot;: &quot;value_1221&quot;,\r\n          &quot;field_1222&quot;: &quot;value_1222&quot;\r\n        }\r\n      },\r\n      &quot;field_13&quot;: [\r\n        {\r\n          &quot;field_131&quot;: {\r\n            &quot;field_1311&quot;: &quot;value_1311&quot;,\r\n            &quot;field_1312&quot;: &quot;value_1312&quot;\r\n          },\r\n          &quot;field_132&quot;: {\r\n            &quot;field_1321&quot;: &quot;value_1321&quot;,\r\n            &quot;field_1322&quot;: &quot;value_1322&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;field_one_four&quot;: &quot;value_one_four&quot;,\r\n      &quot;Field_One_Five&quot;: &quot;Value_One_Five&quot;\r\n    }\r\n\r\nto this:\r\n\r\n    {\r\n      &quot;_id&quot;: &quot;doc1&quot;,\r\n      &quot;field11&quot;: &quot;value_11&quot;,\r\n      &quot;field12&quot;: {\r\n        &quot;field121&quot;: {\r\n          &quot;field1211&quot;: &quot;value_1211&quot;,\r\n          &quot;field1212&quot;: &quot;value_1212&quot;\r\n        },\r\n        &quot;field122&quot;: {\r\n          &quot;field1221&quot;: &quot;value_1221&quot;,\r\n          &quot;field1222&quot;: &quot;value_1222&quot;\r\n        }\r\n      },\r\n      &quot;field13&quot;: [\r\n        {\r\n          &quot;field131&quot;: {\r\n            &quot;field1311&quot;: &quot;value_1311&quot;,\r\n            &quot;field1312&quot;: &quot;value_1312&quot;\r\n          },\r\n          &quot;field132&quot;: {\r\n            &quot;field1321&quot;: &quot;value_1321&quot;,\r\n            &quot;field1322&quot;: &quot;value_1322&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;fieldonefour&quot;: &quot;value_one_four&quot;,\r\n      &quot;FieldOneFive&quot;: &quot;Value_One_Five&quot;\r\n    }\r\n\r\nBonus:  What if I want to remove underscores **and** convert compound field names to camelcase?  I.e., `&quot;field_one_four&quot;` would become `&quot;fieldOneFour&quot;` and `&quot;Field_One_Five&quot;` would become `&quot;fieldOneFive&quot;`.",
        "link": "https://stackoverflow.com/questions/53769485/descend-json-doc-paths-and-update-field-names-with-jq",
        "title": "Descend JSON doc paths and update field names with jq"
    },
    {
        "tags": [
            "json",
            "service",
            "kubernetes",
            "jq",
            "kubectl"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1550860689,
                "last_edit_date": 1550860689,
                "creation_date": 1544747020,
                "answer_id": 53771930,
                "question_id": 53771929,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`kubectl get -f quotem_v2.yaml -o json | jq &#39;.items[] | select(.kind==&quot;Service&quot;)&#39;`\r\n\r\n - The command above usese kubectl get with -o flag to output json\r\n - Then it uses the jq command line json parser to get the items array, and from the items array, select the elements whose &#39;kind&#39; attribute matches &#39;Service&#39;\r\n\r\n",
                "title": "How can I extract the kubernetes Service object from JSON returned from kubectl"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1550860689,
        "creation_date": 1544747020,
        "last_edit_date": 1544788030,
        "question_id": 53771929,
        "body_markdown": "Given the kubectl command below, and its response, I want to yank out the Service object. The command will get the current state of all the k8s objects that are created by my deployment descriptor, which is named quotem.yaml.\r\n\r\n`% kubectl get -f quotem_v2.yaml -o json`\r\n \r\n        {\r\n            &quot;apiVersion&quot;: &quot;v1&quot;,\r\n            &quot;items&quot;: [\r\n                {\r\n                    &quot;apiVersion&quot;: &quot;v1&quot;,\r\n                    &quot;kind&quot;: &quot;Service&quot;,\r\n                    &quot;metadata&quot;: {\r\n                        &quot;annotations&quot;: {\r\n                            &quot;getambassador.io/config&quot;: &quot;---\\napiVersion: ambassador/v0\\nkind:  Mapping\\nname:  qotm_mapping_v2\\nprefix: /qotm/\\nservice: qotm-v2\\nweight: 300\\n&quot;,\r\n                            &quot;kubectl.kubernetes.io/last-applied-configuration&quot;: &quot;{\\&quot;apiVersion\\&quot;:\\&quot;v1\\&quot;,\\&quot;kind\\&quot;:\\&quot;Service\\&quot;,\\&quot;metadata\\&quot;:{\\&quot;annotations\\&quot;:{\\&quot;getambassador.io/config\\&quot;:\\&quot;---\\\\napiVersion: ambassador/v0\\\\nkind:  Mapping\\\\nname:  qotm_mapping_v2\\\\nprefix: /qotm/\\\\nservice: qotm-v2\\\\nweight: 300\\\\n\\&quot;},\\&quot;name\\&quot;:\\&quot;qotm-v2\\&quot;,\\&quot;namespace\\&quot;:\\&quot;default\\&quot;},\\&quot;spec\\&quot;:{\\&quot;ports\\&quot;:[{\\&quot;name\\&quot;:\\&quot;http-qotm\\&quot;,\\&quot;port\\&quot;:80,\\&quot;targetPort\\&quot;:\\&quot;http-api\\&quot;}],\\&quot;selector\\&quot;:{\\&quot;app\\&quot;:\\&quot;qotm-v2\\&quot;}}}\\n&quot;\r\n                        },\r\n                        &quot;creationTimestamp&quot;: &quot;2018-12-13T17:53:51Z&quot;,\r\n                        &quot;name&quot;: &quot;qotm-v2&quot;,\r\n                        &quot;namespace&quot;: &quot;default&quot;,\r\n                        &quot;resourceVersion&quot;: &quot;202117&quot;,\r\n                        &quot;selfLink&quot;: &quot;/api/v1/namespaces/default/services/qotm-v2&quot;,\r\n                        &quot;uid&quot;: &quot;0cf4a4a5-ff00-11e8-9839-080027ced2f4&quot;\r\n                    },\r\n           ......\r\n        }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53771929/how-can-i-extract-the-kubernetes-service-object-from-json-returned-from-kubectl",
        "title": "How can I extract the kubernetes Service object from JSON returned from kubectl"
    },
    {
        "tags": [
            "json",
            "stream",
            "jq",
            "data-munging"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1544752339,
                "creation_date": 1544752339,
                "answer_id": 53772534,
                "question_id": 53772040,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not sure that I understand your problem, but this might get you started.\r\n\r\n    jq -nr &#39;inputs\r\n            | [ .id, ( .records[] | .name + &quot;:&quot; + (.value | tostring) ) ]\r\n            | join (&quot;,&quot;)&#39;\r\n\r\nIf you want ID space comma space at the start of the line, you could do this.\r\n\r\n    jq -nr &#39;inputs\r\n            | .id + &quot; , &quot; + \r\n            ( [ .records[] | .name + &quot;:&quot; + (.value | tostring)  ] | join (&quot;,&quot;) )&#39;\r\n\r\nI believe the [manual entry][1] under &quot;Array/Object Value Iterator: .[]&quot; explains why you are getting the results you see.\r\n\r\nGood luck!\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/v1.6/",
                "title": "jq command line, combine array of objects, do I need reduce? Or map? Or"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1544769751,
                "last_edit_date": 1544769751,
                "creation_date": 1544752633,
                "answer_id": 53772560,
                "question_id": 53772040,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use string interpolation with `map`:\r\n\r\n\r\n    .id + &quot; , &quot; + (.records | map(&quot;\\(.name):\\(.value)&quot;) | join(&quot;,&quot;))\r\n\r\nor even interpolation-within-interpolation:\r\n\r\n    &quot;\\(.id) , \\(.records | map(&quot;\\(.name):\\(.value)&quot;) | join(&quot;,&quot;))&quot;\r\n\r\n",
                "title": "jq command line, combine array of objects, do I need reduce? Or map? Or"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1544965825,
        "creation_date": 1544748054,
        "last_edit_date": 1544965825,
        "question_id": 53772040,
        "body_markdown": "I have some JSON that looks like this. \r\n\r\n    { &quot;id&quot;: &quot;tjh&quot;,\r\n    &quot;records&quot;: [\r\n      {  &quot;name&quot;: &quot;number_of_logins&quot;,\r\n         &quot;shortname&quot;: &quot;nol&quot;,\r\n         &quot;value&quot;: 3 \r\n       },\r\n       {  &quot;name&quot;: &quot;failed_attempts&quot;,\r\n          &quot;shortname&quot;: &quot;fa&quot;,\r\n          &quot;value&quot;: 4 \r\n       },\r\n       {  &quot;name&quot;: &quot;locations&quot;,\r\n          &quot;shortname&quot;: &quot;loc&quot;,\r\n          &quot;value&quot;: 5 \r\n       }\r\n    ]} \r\n\r\nIt is in lines format with thousands of records in the file. Keep this in mind as an answer that might work for a single record, needs to work for the whole file.\r\n\r\nI need to transform it to\r\n\r\n    ID , name:value,name:value,name:value\r\n    ID , name:value,name:value,name:value\r\n    ID , name:value,name:value,name:value\r\n\r\nOne line per json entry in the file. \r\n\r\nSo basically one line of output per id, or per id record in the file.\r\n\r\nI am struggling with the following. \r\n\r\nIt seems I can reformat to get ID,list of values. \r\nI can also reformat to get ID,list of name.\r\n\r\nWhen I add both I get duplicates. \r\n\r\nHere it is on jqplay, https://jqplay.org/s/QTk42jn-a0\r\n\r\nFor example: \r\n\r\nThis is close: \r\n\r\n    .id , (.records[].name + &quot;:&quot;)\r\n\r\nIt Returns, \r\n\r\n    &quot;tjh&quot;\r\n    &quot;number_of_logins:&quot;\r\n    &quot;failed_attempts:&quot;\r\n    &quot;locations:&quot;\r\n\r\nThis is REALLY close, I just need to add the value. \r\n\r\nThis is what happens when I go to add the value: \r\n\r\nFilter: \r\n\r\n    .id , (.records[].name + &quot;:&quot; + (.records[].value|tostring))\r\n\r\nOutput:\r\n\r\n    &quot;tjh&quot;\r\n    &quot;number_of_logins:3&quot;\r\n    &quot;failed_attempts:3&quot;\r\n    &quot;locations:3&quot;\r\n    &quot;number_of_logins:4&quot;\r\n    &quot;failed_attempts:4&quot;\r\n    &quot;locations:4&quot;\r\n    &quot;number_of_logins:5&quot;\r\n    &quot;failed_attempts:5&quot;\r\n    &quot;locations:5&quot;\r\n\r\nIt is like I am triggering a full outer join somehow. \r\n\r\nI suspect I might need reduce, or map. \r\n\r\nAny advice is welcome, the interactive website url for testing jq, with my snippet is here. \r\n\r\nhttps://jqplay.org/s/QTk42jn-a0\r\n\r\nThanks, \r\n\r\nTom\r\n",
        "link": "https://stackoverflow.com/questions/53772040/jq-command-line-combine-array-of-objects-do-i-need-reduce-or-map-or",
        "title": "jq command line, combine array of objects, do I need reduce? Or map? Or"
    },
    {
        "tags": [
            "json",
            "mongodb",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1544772536,
                "creation_date": 1544772536,
                "answer_id": 53775224,
                "question_id": 53774996,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [tag:jq] to parse JSON.\r\n\r\n    jq -r &#39;.mongodb_url&#39; ~/.config/server_config.json",
                "title": "get single line key value pair from json file using BASH for mongodb backup script"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1545029780,
                "last_edit_date": 1545029780,
                "creation_date": 1544772571,
                "answer_id": 53775231,
                "question_id": 53774996,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `jq` bash command to parse the JSON file.\r\n\r\n*Sample `test.json` File Contents:*\r\n\t\r\n    {\r\n        &quot;a&quot;: 1,\r\n\t    &quot;b&quot;: 2,\r\n\t    &quot;c&quot;: 4\r\n\t}\r\n\r\nbash command: `jq &#39;.b&#39; test.json`\r\n\r\nOutput: `2`\r\n",
                "title": "get single line key value pair from json file using BASH for mongodb backup script"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1666425066,
        "creation_date": 1544771459,
        "last_edit_date": 1666425066,
        "question_id": 53774996,
        "body_markdown": "I have a config file located in \r\n~/.config/server_config.json\r\n\r\nthis json file contains the following info:\r\n\r\n    {\r\n        &quot;server_name&quot;: &quot;server1&quot;,\r\n        &quot;mongodb_url&quot;:&quot;mongodb://user:password@localhost:27017/dbname&quot;\r\n        &quot;other stuff&quot;: &quot;stuff2&quot;\r\n    }\r\n\r\n\r\nI have a bash script that i use in a cronjob that will perform a mongodump daily, monthly, weekly, and do auto rotate backups, gzip, etc.\r\n\r\nI want to be able to check this config file for the existence of the mongodb_url.\r\n\r\nif exists, use that url that contains the username and password to pass into the mongodump script.\r\n\r\nif the mongodb url does not exist in the json file, run the mongodump command normally using localhost with no authentication. \r\n\r\n\r\nhere is a snippet from the backup script\r\n\r\n    else # daily\r\n        echo &quot;Starting critical tables daily backup $(date)&quot; &gt;&gt; $LOG_LOCATION\r\n        for DATABASE in ${FULL_BACKUPS_ONLY_LIST//,/ }\r\n            do\r\n                for TABLE in ${CRITICAL_TABLES_LIST//,/ }\r\n                do\r\n                        echo &quot;backing up $DATABASE $TABLE ...&quot;\r\n                        mongodump -d $DATABASE -c $TABLE --out $FINAL_BACKUP_DIR\r\n                done\r\n            done\r\n    fi\r\n     \r\n\r\nI basically want to be able to parse this json file to use the right mongodb url with username and password included. \r\n\r\nim thinking about using python to first parse the json file, then send the url as an input argument into the bash script since parsing json with bash seems very difficult. Unless there is some sed/awk magic that can happen. \r\n",
        "link": "https://stackoverflow.com/questions/53774996/get-single-line-key-value-pair-from-json-file-using-bash-for-mongodb-backup-scri",
        "title": "get single line key value pair from json file using BASH for mongodb backup script"
    },
    {
        "tags": [
            "json",
            "object",
            "awk",
            "timestamp",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7750510,
                    "reputation": 134447,
                    "user_id": 5866580,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/f69cec226400d61f887446d813471488?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RavinderSingh13",
                    "link": "https://stackoverflow.com/users/5866580/ravindersingh13"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1544788322,
                "post_id": 53779150,
                "comment_id": 94409545,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12896995,
                    "reputation": 13,
                    "user_id": 9327045,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/da980b29c58ddd01e7cfda020d0249c1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "fnoss",
                    "link": "https://stackoverflow.com/users/9327045/fnoss"
                },
                "reply_to_user": {
                    "account_id": 7750510,
                    "reputation": 134447,
                    "user_id": 5866580,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/f69cec226400d61f887446d813471488?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RavinderSingh13",
                    "link": "https://stackoverflow.com/users/5866580/ravindersingh13"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1544788725,
                "post_id": 53779150,
                "comment_id": 94409759,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1544792108,
                "last_edit_date": 1544792108,
                "creation_date": 1544791751,
                "answer_id": 53780144,
                "question_id": 53779150,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here’s one approach, which uses [tag:jq]:\r\n \r\n    def addnow: \r\n      . as $in\r\n      | to_entries\r\n      | (map(.key)|index(&quot;bladesetName&quot;)) as $i\r\n      | if $i \r\n        then .[0:$i]+[{key:&quot;time&quot;,value:now}]+.[$i:] | from_entries\r\n        else $in \r\n        end ;\r\n\r\n    walk(if type==&quot;object&quot; then addnow else . end)\r\n\r\nIf you really want the time as a string, simply add `tostring`, as in `(now|tostring)`\r\n\r\nIf your jq does not have `walk`, then now would be a good time to upgrade; otherwise simply copy and paste its def, which can easily be found on the web, e.g. by googling: jq “def walk”",
                "title": "Print result of timestamp function one line before string"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1544792489,
        "creation_date": 1544787940,
        "last_edit_date": 1544792489,
        "question_id": 53779150,
        "body_markdown": "At the bottom is some example json data which I&#39;d like to add timestamps to. i.e `&quot;time&quot;: &quot;1544785866.176123088&quot;` The timestamps need to be unique on each iteration and need to occur on the line above &quot;bladesetName&quot;. Unfortunately, what I have so far is not working. After printing the time to the file in the needed places I was going to add 1ns to each entry. Is there a better way of doing this?\r\n\r\n    timestamp() {\r\n        date +%s.%N\r\n    }\r\n\r\n    awk &quot;/bladesetName/{ print &#39;&quot;time&quot; &quot;$(timestamp)&quot;&#39; }1&quot; volumes3.json\r\n\r\nThis throws an error\r\n\r\n    awk: /bladesetName/{ print &#39;time 1544786158.644385726&#39; }1\r\n    awk:                       ^ invalid char &#39;&#39;&#39; in expression\r\n\r\n.\r\n\r\n    {\r\n    &quot;pasxml&quot;: {\r\n        &quot;@version&quot;: &quot;6.0.0&quot;,\r\n        &quot;system&quot;: {\r\n            &quot;name&quot;: &quot;example1&quot;,\r\n            &quot;IPV4&quot;: &quot;0.0.0.0&quot;,\r\n            &quot;alertLevel&quot;: &quot;critical&quot;,\r\n            &quot;state&quot;: &quot;online&quot;\r\n        },\r\n        &quot;volumes&quot;: {\r\n            &quot;volume&quot;: [\r\n                {\r\n                    &quot;@id&quot;: &quot;1&quot;,\r\n                    &quot;name&quot;: &quot;/&quot;,\r\n                    &quot;bladesetName&quot;: {\r\n                        &quot;@id&quot;: &quot;1&quot;,\r\n                        &quot;#text&quot;: &quot;Set-1&quot;\r\n                    },\r\n                    &quot;state&quot;: &quot;Online&quot;,\r\n                    &quot;raid&quot;: &quot;Object RAID6+&quot;,\r\n                    &quot;director&quot;: &quot;Shelf-001,1&quot;,\r\n                    &quot;volservice&quot;: &quot;0x0400000000000004(FM)&quot;,\r\n                    &quot;objectId&quot;: &quot;I-xD0200000000000004-xG7ee84b0c-xU00004a75726a656e&quot;,\r\n                    &quot;recoveryPriority&quot;: &quot;1&quot;,\r\n                    &quot;efsaMode&quot;: &quot;retry&quot;,\r\n                    &quot;spaceUsedGB&quot;: &quot;0&quot;,\r\n                    &quot;spaceAvailableGB&quot;: &quot;693903.38&quot;,\r\n                    &quot;hardQuotaGB&quot;: &quot;0.52&quot;,\r\n                    &quot;softQuotaGB&quot;: &quot;0.52&quot;,\r\n                    &quot;userQuotaPolicy&quot;: {\r\n                        &quot;@inherit&quot;: &quot;0&quot;,\r\n                        &quot;#text&quot;: &quot;disabled&quot;\r\n                    },\r\n                    &quot;stats&quot;: null\r\n                },\r\n                {\r\n                    &quot;@id&quot;: &quot;8&quot;,\r\n                    &quot;name&quot;: &quot;/datacentre/archvol/pan101&quot;,\r\n                    &quot;bladesetName&quot;: {\r\n                        &quot;@id&quot;: &quot;1&quot;,\r\n                        &quot;#text&quot;: &quot;Set-1&quot;\r\n                    },\r\n                    &quot;alertLevel&quot;: &quot;critical&quot;,\r\n                    &quot;state&quot;: &quot;Online&quot;,\r\n                    &quot;raid&quot;: &quot;Object RAID6+&quot;,\r\n                    &quot;director&quot;: &quot;Shelf-008,1&quot;,\r\n                    &quot;volservice&quot;: &quot;0x04000000000000ec(FM)&quot;,\r\n                    &quot;objectId&quot;: &quot;I-xD02000000000000ec-xG5c7aef6f-xU00004a75726a656e&quot;,\r\n                    &quot;recoveryPriority&quot;: &quot;50&quot;,\r\n                    &quot;efsaMode&quot;: &quot;retry&quot;,\r\n                    &quot;spaceUsedGB&quot;: &quot;117000.09&quot;,\r\n                    &quot;spaceAvailableGB&quot;: &quot;693903.38&quot;,\r\n                    &quot;hardQuotaGB&quot;: &quot;117000.00&quot;,\r\n                    &quot;softQuotaGB&quot;: &quot;90000.00&quot;,\r\n                    &quot;userQuotaPolicy&quot;: {\r\n                        &quot;@inherit&quot;: &quot;1&quot;,\r\n                        &quot;#text&quot;: &quot;disabled&quot;\r\n                    },\r\n                    &quot;stats&quot;: null\r\n                },\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53779150/print-result-of-timestamp-function-one-line-before-string",
        "title": "Print result of timestamp function one line before string"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1544797780,
                "post_id": 53781422,
                "comment_id": 94414582,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1055927,
                    "reputation": 3276,
                    "user_id": 1058646,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/8d8b80b5266b05dae852093e7733236a?s=256&d=identicon&r=PG",
                    "display_name": "NoviceMe",
                    "link": "https://stackoverflow.com/users/1058646/noviceme"
                },
                "reply_to_user": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1544798057,
                "post_id": 53781422,
                "comment_id": 94414752,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1055927,
                    "reputation": 3276,
                    "user_id": 1058646,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/8d8b80b5266b05dae852093e7733236a?s=256&d=identicon&r=PG",
                    "display_name": "NoviceMe",
                    "link": "https://stackoverflow.com/users/1058646/noviceme"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1544799167,
                "post_id": 53781422,
                "comment_id": 94415351,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1544799593,
                "post_id": 53781422,
                "comment_id": 94415636,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1055927,
                    "reputation": 3276,
                    "user_id": 1058646,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/8d8b80b5266b05dae852093e7733236a?s=256&d=identicon&r=PG",
                    "display_name": "NoviceMe",
                    "link": "https://stackoverflow.com/users/1058646/noviceme"
                },
                "reply_to_user": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1544800411,
                "post_id": 53781422,
                "comment_id": 94416080,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1544800533,
                "post_id": 53781422,
                "comment_id": 94416156,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1055927,
                    "reputation": 3276,
                    "user_id": 1058646,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/8d8b80b5266b05dae852093e7733236a?s=256&d=identicon&r=PG",
                    "display_name": "NoviceMe",
                    "link": "https://stackoverflow.com/users/1058646/noviceme"
                },
                "reply_to_user": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1544800652,
                "post_id": 53781422,
                "comment_id": 94416214,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1544796982,
        "creation_date": 1544796982,
        "question_id": 53781422,
        "body_markdown": "I have following json: \r\n\r\n     [\r\n      {\r\n      &quot;account&quot;: &quot;1&quot;,\r\n      &quot;cost&quot;: [\r\n          {\r\n             &quot;usage&quot;:&quot;low&quot;,\r\n             &quot;totalcost&quot;: &quot;2.01&quot;\r\n          }\r\n       ]\r\n      },\r\n      {\r\n      &quot;account&quot;: &quot;2&quot;,\r\n      &quot;cost&quot;: [\r\n          {\r\n             &quot;usage&quot;:&quot;low&quot;,\r\n             &quot;totalcost&quot;: &quot;2.25&quot;\r\n          }\r\n       ]\r\n      },\r\n      {\r\n      &quot;account&quot;: &quot;1&quot;,\r\n      &quot;cost&quot;: [\r\n          {\r\n             &quot;usage&quot;:&quot;low&quot;,\r\n             &quot;totalcost&quot;: &quot;15&quot;\r\n          }\r\n       ]\r\n      },\r\n      {\r\n      &quot;anotheraccount&quot;: &quot;a&quot;,\r\n      &quot;cost&quot;: [\r\n          {\r\n             &quot;usage&quot;:&quot;low&quot;,\r\n             &quot;totalcost&quot;: &quot;2&quot;\r\n          }\r\n       ]\r\n      }\r\n    ]\r\n\r\nI run following command on it: \r\n\r\n    jq &#39;.[] | {account,cost : .cost[].totalcost}&#39; \r\n\r\nwhich gives me: \r\n\r\n      {\r\n      &quot;account&quot;: &quot;1&quot;,\r\n      &quot;cost&quot;: &quot;2.01&quot;\r\n       }\r\n      {\r\n      &quot;account&quot;: “2”,\r\n      &quot;cost&quot;: “2.25”\r\n       }\r\n       {\r\n      &quot;account&quot;: “1”,\r\n      &quot;cost&quot;: “15”\r\n       }\r\n\r\nThen I try to pipe to aggregate values, but getting wrong results:\r\n\r\n    jq &#39;.[] | {account,cost : .cost[].totalcost}&#39;  | jq -n &#39;reduce (inputs | to_entries[]) as {$key,$value} ({}; .[$key] += $value)&#39;\r\n\r\ngetting: \r\n\r\n    {\r\n    \t“account”: “121”\r\n    \t“cost”: 19.26\r\n    }\r\n\r\nbut I am trying to achieve following output: \r\n\r\n    {\r\n    \t“account”: “1”\r\n    \t“cost”: “17.01”\r\n    }\r\n    {\r\n    \t“account”: “2”\r\n    \t“cost”: “2.25”\r\n    }\r\n\r\nI am new to jq. jq is not a necessity to use in this, in anyway I can aggregate the values will work for me. ",
        "link": "https://stackoverflow.com/questions/53781422/jq-aggregate-cost-in-nested-json",
        "title": "jq: aggregate cost in nested json"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1544804910,
                "post_id": 53782274,
                "comment_id": 94418483,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1544804773,
                "creation_date": 1544804773,
                "answer_id": 53783494,
                "question_id": 53782274,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you have not followed the [tag:mcve] guidelines, it’s difficult to ascertain what precisely you want, as “empty array” has no specific meaning in the CSV context, but it would make sense to use `&quot;[]&quot;` instead of `[]` in the expression ` // [] `",
                "title": "Replace empty values with empty arrays in jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1544804773,
        "creation_date": 1544800106,
        "question_id": 53782274,
        "body_markdown": "I am getting a list of EBS volumes in an AWS account. I need to print out the volume id the size and the time it was attached.\r\n\r\nIf a volume is not attached, it has an empty value for &quot;attach time&quot;. I wold like to replace empty values for attach time with an empty array.\r\n\r\nIf I try to substitute an empty array, I get this error:\r\n\r\n    cat nonprod-ebs-sanitized.json | jq -r &#39;.Volumes[]  | [ .VolumeId, .Size, (.Attachments[].AttachTime  // [] )] | @csv&#39;\r\n    \r\n    jq: error (at &lt;stdin&gt;:4041): array ([]) is not valid in a csv row\r\n\r\nIf I substitute anything else, like exclamation marks the substitution works:\r\n\r\n    cat nonprod-ebs-sanitized.json | jq -r &#39;.Volumes[]  | [ .VolumeId, .Size, (.Attachments[].AttachTime  // &quot;!!!!!!!&quot; )] | @csv&#39;\r\n\r\n    &quot;vol-0c21e56a50a1c5009&quot;,50,&quot;!!!!!!!&quot;\r\n    &quot;vol-0b6d7b1488438cc95&quot;,120,&quot;!!!!!!!&quot;\r\n    &quot;vol-066e24cb8d2294605&quot;,8,&quot;2018-12-11T18:54:26.000Z&quot;\r\n\r\nHow can I get substituting an empty array for empty attach time values to work?\r\n\r\nHere is the original json I am working with: [ORIGINAL JSON][1]\r\n\r\n\r\n  [1]: https://gist.github.com/bluethundr/431ee7f8f3fa4f3a752c8a1fd0c8e094",
        "link": "https://stackoverflow.com/questions/53782274/replace-empty-values-with-empty-arrays-in-jq",
        "title": "Replace empty values with empty arrays in jq"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1544820265,
                "last_edit_date": 1544820265,
                "creation_date": 1544819091,
                "answer_id": 53786464,
                "question_id": 53786403,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`@csv`&#39;s input must be a flat array, but your filter (`.Images[] | [.ImageId, ([.BlockDeviceMappings[].Ebs.VolumeSize])]`) produces a nested array because you put volume sizes into a subarray (**[**`.BlockDeviceMappings[].Ebs.VolumeSize`**]**):\r\n\r\n    $ jq -rc &#39;.Images[] | [.ImageId, ([.BlockDeviceMappings[].Ebs.VolumeSize])]&#39; file.json \r\n    [&quot;ami-000bd263d51e443f2&quot;,[100,5,10,20,40,30,5]]\r\n\r\n\r\nSo, use following command instead.\r\n\r\n    jq -r &#39;.Images[] | [ .ImageId, .BlockDeviceMappings[].Ebs.VolumeSize ] | @csv&#39; ab-prod-images.json\r\n\r\nwhich yields:\r\n\r\n    &quot;ami-000bd263d51e443f2&quot;,100,5,10,20,40,30,5\r\n",
                "title": "List of numbers is invalid output for CSV in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1544886497,
        "creation_date": 1544818764,
        "last_edit_date": 1544886497,
        "question_id": 53786403,
        "body_markdown": "I need to get a list of amazon images created by the company. This will go into a variable that I will put into csv format and output to a spread sheet.\r\n\r\nI need to account for the image id and the size of the volumes attached to it.\r\n\r\nIf I try this command:\r\n\r\n    cat ab-prod-images.json |  jq -r &#39;.Images[] | [.ImageId, ([.BlockDeviceMappings[].Ebs.VolumeSize])] | @csv&#39;\r\n\r\nThis is the error I get:\r\n\r\n    jq: error (at &lt;stdin&gt;:53471): array ([100,5,10,2...) is not valid in a csv row\r\n\r\nI&#39;m storing the output of that command in a variable, that I&#39;ll use to output to a spread sheet.\r\n\r\nWhat I want is for a comma separated list of volume sizes to appear in the same cell in the spread sheet. \r\n\r\nThis is an example of the json that I&#39;m using:\r\n\r\n    {\r\n\t&quot;Images&quot;: [\r\n\t\t{\r\n\t\t\t&quot;VirtualizationType&quot;: &quot;hvm&quot;,\r\n\t\t\t&quot;Description&quot;: &quot;TRAN05-12-13-2018&quot;,\r\n\t\t\t&quot;Hypervisor&quot;: &quot;xen&quot;,\r\n\t\t\t&quot;ImageId&quot;: &quot;ami-000bd263d51e443f2&quot;,\r\n\t\t\t&quot;State&quot;: &quot;available&quot;,\r\n\t\t\t&quot;BlockDeviceMappings&quot;: [{\r\n\t\t\t\t\t&quot;DeviceName&quot;: &quot;/dev/sda1&quot;,\r\n\t\t\t\t\t&quot;Ebs&quot;: {\r\n\t\t\t\t\t\t&quot;SnapshotId&quot;: &quot;snap-0f1076dce3103833f&quot;,\r\n\t\t\t\t\t\t&quot;DeleteOnTermination&quot;: true,\r\n\t\t\t\t\t\t&quot;VolumeType&quot;: &quot;gp2&quot;,\r\n\t\t\t\t\t\t&quot;VolumeSize&quot;: 100,\r\n\t\t\t\t\t\t&quot;Encrypted&quot;: false\r\n\t\t\t\t\t}\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;DeviceName&quot;: &quot;/dev/sdi&quot;,\r\n\t\t\t\t\t&quot;Ebs&quot;: {\r\n\t\t\t\t\t\t&quot;SnapshotId&quot;: &quot;snap-0c7d71a9d3887a048&quot;,\r\n\t\t\t\t\t\t&quot;DeleteOnTermination&quot;: true,\r\n\t\t\t\t\t\t&quot;VolumeType&quot;: &quot;gp2&quot;,\r\n\t\t\t\t\t\t&quot;VolumeSize&quot;: 5,\r\n\t\t\t\t\t\t&quot;Encrypted&quot;: false\r\n\t\t\t\t\t}\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;DeviceName&quot;: &quot;/dev/sdg&quot;,\r\n\t\t\t\t\t&quot;Ebs&quot;: {\r\n\t\t\t\t\t\t&quot;SnapshotId&quot;: &quot;snap-00402196b9e023a72&quot;,\r\n\t\t\t\t\t\t&quot;DeleteOnTermination&quot;: true,\r\n\t\t\t\t\t\t&quot;VolumeType&quot;: &quot;gp2&quot;,\r\n\t\t\t\t\t\t&quot;VolumeSize&quot;: 10,\r\n\t\t\t\t\t\t&quot;Encrypted&quot;: false\r\n\t\t\t\t\t}\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;DeviceName&quot;: &quot;/dev/sdk&quot;,\r\n\t\t\t\t\t&quot;Ebs&quot;: {\r\n\t\t\t\t\t\t&quot;SnapshotId&quot;: &quot;snap-05f65a62735de2846&quot;,\r\n\t\t\t\t\t\t&quot;DeleteOnTermination&quot;: true,\r\n\t\t\t\t\t\t&quot;VolumeType&quot;: &quot;gp2&quot;,\r\n\t\t\t\t\t\t&quot;VolumeSize&quot;: 20,\r\n\t\t\t\t\t\t&quot;Encrypted&quot;: false\r\n\t\t\t\t\t}\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;DeviceName&quot;: &quot;/dev/sdj&quot;,\r\n\t\t\t\t\t&quot;Ebs&quot;: {\r\n\t\t\t\t\t\t&quot;SnapshotId&quot;: &quot;snap-0d350170b9d5c62bb&quot;,\r\n\t\t\t\t\t\t&quot;DeleteOnTermination&quot;: true,\r\n\t\t\t\t\t\t&quot;VolumeType&quot;: &quot;gp2&quot;,\r\n\t\t\t\t\t\t&quot;VolumeSize&quot;: 40,\r\n\t\t\t\t\t\t&quot;Encrypted&quot;: false\r\n\t\t\t\t\t}\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;DeviceName&quot;: &quot;/dev/sdh&quot;,\r\n\t\t\t\t\t&quot;Ebs&quot;: {\r\n\t\t\t\t\t\t&quot;SnapshotId&quot;: &quot;snap-04679d09d89609e79&quot;,\r\n\t\t\t\t\t\t&quot;DeleteOnTermination&quot;: true,\r\n\t\t\t\t\t\t&quot;VolumeType&quot;: &quot;gp2&quot;,\r\n\t\t\t\t\t\t&quot;VolumeSize&quot;: 30,\r\n\t\t\t\t\t\t&quot;Encrypted&quot;: false\r\n\t\t\t\t\t}\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;DeviceName&quot;: &quot;/dev/sdf&quot;,\r\n\t\t\t\t\t&quot;Ebs&quot;: {\r\n\t\t\t\t\t\t&quot;SnapshotId&quot;: &quot;snap-0b5f861fd93da6b20&quot;,\r\n\t\t\t\t\t\t&quot;DeleteOnTermination&quot;: true,\r\n\t\t\t\t\t\t&quot;VolumeType&quot;: &quot;gp2&quot;,\r\n\t\t\t\t\t\t&quot;VolumeSize&quot;: 5,\r\n\t\t\t\t\t\t&quot;Encrypted&quot;: false\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t],\r\n\t\t\t&quot;Architecture&quot;: &quot;x86_64&quot;,\r\n\t\t\t&quot;ImageLocation&quot;: &quot;155775729998/AB-P-RIDD-TRAN05-12-13-2018&quot;,\r\n\t\t\t&quot;RootDeviceType&quot;: &quot;ebs&quot;,\r\n\t\t\t&quot;OwnerId&quot;: &quot;123456789101&quot;,\r\n\t\t\t&quot;RootDeviceName&quot;: &quot;/dev/sda1&quot;,\r\n\t\t\t&quot;CreationDate&quot;: &quot;2018-12-14T01:39:31.000Z&quot;,\r\n\t\t\t&quot;Public&quot;: false,\r\n\t\t\t&quot;ImageType&quot;: &quot;machine&quot;,\r\n\t\t\t&quot;Name&quot;: &quot;TRAN05-12-13-2018&quot;\r\n\t\t}\r\n\t]\r\n}\r\n\r\nHere is the full and complete json that I&#39;m trying to use: [FULL JSON][1]\r\n\r\nHow can I get the list of VolumeSizes to go into the same cell in the spread sheet I&#39;m creating?\r\n\r\n  [1]: https://gist.github.com/bluethundr/fe8bc9bbfae7293b054b6b01d455c015",
        "link": "https://stackoverflow.com/questions/53786403/list-of-numbers-is-invalid-output-for-csv-in-jq",
        "title": "List of numbers is invalid output for CSV in jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "boolean",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1544828233,
                "post_id": 53787854,
                "comment_id": 94427434,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1002989,
                    "reputation": 1385,
                    "user_id": 1017466,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/73d62289ed695b520ad2a3ae80c45277?s=256&d=identicon&r=PG",
                    "display_name": "bluethundr",
                    "link": "https://stackoverflow.com/users/1017466/bluethundr"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1544828396,
                "post_id": 53787854,
                "comment_id": 94427482,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1545118278,
                "last_edit_date": 1545118278,
                "creation_date": 1544828586,
                "answer_id": 53787971,
                "question_id": 53787854,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to use `tostring`.\r\n\r\n    .bool_value | tostring\r\nUsage in your case:\r\n\r\n    jq -r &#39;.Images[] | [.ImageId, ( [.BlockDeviceMappings[].Ebs.DeleteOnTermination | tostring] | join(&quot;,&quot;) )] | @csv&#39; file\r\nyields:\r\n\r\n    &quot;ami-000bd263d51e443f2&quot;,&quot;true,true,true,true,true,true,true&quot;",
                "title": "Add Boolean value to an csv array with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1544859623,
                "creation_date": 1544859623,
                "answer_id": 53790513,
                "question_id": 53787854,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a def of `join` that can be used with all extant versions of jq (that is, jq 1.3 and up), and which provides the flexible semantics of jq 1.6 (i.e. it only requires that all the items in the array be scalars):\r\n\r\n    def join(c):\r\n      if length==0 then &quot;&quot;\r\n      else reduce .[1:][] as $x (.[0]|tostring; . + c + ($x|tostring))\r\n      end;\r\n\r\n---\r\nFor ease of reference:\r\n\r\n* `tostring` is available in all extant versions of jq;\r\n\r\n* jq 1.3 does not have `join/1` (but it does have `@csv`).\r\n",
                "title": "Add Boolean value to an csv array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1545118278,
        "creation_date": 1544827656,
        "last_edit_date": 1544857716,
        "question_id": 53787854,
        "body_markdown": "I need to get a list of amazon images, and one of the values I need to show is a boolean value (true/false). \r\n\r\nFor example I can extract the Image IDs from the list I need to process without problem:\r\n\r\n    cat oneimage.json | jq -r &#39;.Images[] | [.ImageId] | @csv&#39;\r\n    &quot;ami-000bd263d51e443f2&quot;\r\n\r\nBut the next value I need to add to the list is a true/false value and jq chokes at the next command:\r\n\r\n    cat oneimage.json | jq -r &#39;.Images[] | [.ImageId, ([.BlockDeviceMappings[].Ebs.DeleteOnTermination] | join(&quot;,&quot;))] | @csv&#39;\r\n    jq: error (at &lt;stdin&gt;:89): string (&quot;&quot;) and boolean (true) cannot be added\r\n\r\nThe json includes a list of volumes. The &quot;DeleteOnTermination&quot; value will be unique for each volume in the list and has to go into the same &#39;cell&#39; in csv format. \r\n\r\nThe goal is to output the csv to a spread sheet and have all the DeleteOnTermination values separated by a comma on one line in a cell for each image.\r\n\r\nHere is the json I&#39;m using for this test:\r\n\r\n    {\r\n\t&quot;Images&quot;: [{\r\n\t\t&quot;VirtualizationType&quot;: &quot;hvm&quot;,\r\n\t\t&quot;Description&quot;: &quot;AB-P-RIDD-TRAN05-12-13-2018&quot;,\r\n\t\t&quot;Hypervisor&quot;: &quot;xen&quot;,\r\n\t\t&quot;ImageId&quot;: &quot;ami-000bd263d51e443f2&quot;,\r\n\t\t&quot;State&quot;: &quot;available&quot;,\r\n\t\t&quot;BlockDeviceMappings&quot;: [{\r\n\t\t\t\t&quot;DeviceName&quot;: &quot;/dev/sda1&quot;,\r\n\t\t\t\t&quot;Ebs&quot;: {\r\n\t\t\t\t\t&quot;SnapshotId&quot;: &quot;snap-0f1076dce3103833f&quot;,\r\n\t\t\t\t\t&quot;DeleteOnTermination&quot;: true,\r\n\t\t\t\t\t&quot;VolumeType&quot;: &quot;gp2&quot;,\r\n\t\t\t\t\t&quot;VolumeSize&quot;: 100,\r\n\t\t\t\t\t&quot;Encrypted&quot;: false\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;DeviceName&quot;: &quot;/dev/sdi&quot;,\r\n\t\t\t\t&quot;Ebs&quot;: {\r\n\t\t\t\t\t&quot;SnapshotId&quot;: &quot;snap-0c7d71a9d3887a048&quot;,\r\n\t\t\t\t\t&quot;DeleteOnTermination&quot;: true,\r\n\t\t\t\t\t&quot;VolumeType&quot;: &quot;gp2&quot;,\r\n\t\t\t\t\t&quot;VolumeSize&quot;: 5,\r\n\t\t\t\t\t&quot;Encrypted&quot;: false\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;DeviceName&quot;: &quot;/dev/sdg&quot;,\r\n\t\t\t\t&quot;Ebs&quot;: {\r\n\t\t\t\t\t&quot;SnapshotId&quot;: &quot;snap-00402196b9e023a72&quot;,\r\n\t\t\t\t\t&quot;DeleteOnTermination&quot;: true,\r\n\t\t\t\t\t&quot;VolumeType&quot;: &quot;gp2&quot;,\r\n\t\t\t\t\t&quot;VolumeSize&quot;: 10,\r\n\t\t\t\t\t&quot;Encrypted&quot;: false\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;DeviceName&quot;: &quot;/dev/sdk&quot;,\r\n\t\t\t\t&quot;Ebs&quot;: {\r\n\t\t\t\t\t&quot;SnapshotId&quot;: &quot;snap-05f65a62735de2846&quot;,\r\n\t\t\t\t\t&quot;DeleteOnTermination&quot;: true,\r\n\t\t\t\t\t&quot;VolumeType&quot;: &quot;gp2&quot;,\r\n\t\t\t\t\t&quot;VolumeSize&quot;: 20,\r\n\t\t\t\t\t&quot;Encrypted&quot;: false\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;DeviceName&quot;: &quot;/dev/sdj&quot;,\r\n\t\t\t\t&quot;Ebs&quot;: {\r\n\t\t\t\t\t&quot;SnapshotId&quot;: &quot;snap-0d350170b9d5c62bb&quot;,\r\n\t\t\t\t\t&quot;DeleteOnTermination&quot;: true,\r\n\t\t\t\t\t&quot;VolumeType&quot;: &quot;gp2&quot;,\r\n\t\t\t\t\t&quot;VolumeSize&quot;: 40,\r\n\t\t\t\t\t&quot;Encrypted&quot;: false\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;DeviceName&quot;: &quot;/dev/sdh&quot;,\r\n\t\t\t\t&quot;Ebs&quot;: {\r\n\t\t\t\t\t&quot;SnapshotId&quot;: &quot;snap-04679d09d89609e79&quot;,\r\n\t\t\t\t\t&quot;DeleteOnTermination&quot;: true,\r\n\t\t\t\t\t&quot;VolumeType&quot;: &quot;gp2&quot;,\r\n\t\t\t\t\t&quot;VolumeSize&quot;: 30,\r\n\t\t\t\t\t&quot;Encrypted&quot;: false\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;DeviceName&quot;: &quot;/dev/sdf&quot;,\r\n\t\t\t\t&quot;Ebs&quot;: {\r\n\t\t\t\t\t&quot;SnapshotId&quot;: &quot;snap-0b5f861fd93da6b20&quot;,\r\n\t\t\t\t\t&quot;DeleteOnTermination&quot;: true,\r\n\t\t\t\t\t&quot;VolumeType&quot;: &quot;gp2&quot;,\r\n\t\t\t\t\t&quot;VolumeSize&quot;: 5,\r\n\t\t\t\t\t&quot;Encrypted&quot;: false\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t],\r\n\t\t&quot;Architecture&quot;: &quot;x86_64&quot;,\r\n\t\t&quot;ImageLocation&quot;: &quot;123456789191/AB-P-RIDD-TRAN05-12-13-2018&quot;,\r\n\t\t&quot;RootDeviceType&quot;: &quot;ebs&quot;,\r\n\t\t&quot;OwnerId&quot;: &quot;123456789191&quot;,\r\n\t\t&quot;RootDeviceName&quot;: &quot;/dev/sda1&quot;,\r\n\t\t&quot;CreationDate&quot;: &quot;2018-12-14T01:39:31.000Z&quot;,\r\n\t\t&quot;Public&quot;: false,\r\n\t\t&quot;ImageType&quot;: &quot;machine&quot;,\r\n\t\t&quot;Name&quot;: &quot;AB-P-RIDD-TRAN05-12-13-2018&quot;\r\n\t}]\r\n}\r\n\r\nHow can get the DeleteOnTermination value to appear in one csv cell, separated by commas with one DeleteOnTermination value for each volume?",
        "link": "https://stackoverflow.com/questions/53787854/add-boolean-value-to-an-csv-array-with-jq",
        "title": "Add Boolean value to an csv array with jq"
    },
    {
        "tags": [
            "json",
            "ansible",
            "jq",
            "key-value"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4624068,
                    "reputation": 54457,
                    "user_id": 3748349,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ArUlH.png?s=256",
                    "display_name": "Hans Z.",
                    "link": "https://stackoverflow.com/users/3748349/hans-z"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1544896987,
                "post_id": 53795759,
                "comment_id": 94441415,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1544897166,
                "creation_date": 1544897166,
                "answer_id": 53795878,
                "question_id": 53795759,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes, this is feasible for `jq` tool:\r\n\r\n    jq -r &#39;.plays[].tasks[].hosts | to_entries[] | &quot;\\(.key +&quot;: &quot;+ .value.hw_system_serial)&quot;&#39; input.json\r\n\r\nThe output:\r\n\r\n    hostname01-con: &lt;SERIALNUMBER&gt;\r\n    hostname02-con: &lt;SERIALNUMBER&gt;\r\n    hostname03-con: &lt;SERIALNUMBER&gt;\r\n    hostname04-con: &lt;SERIALNUMBER&gt;\r\n    hostname05-con: &lt;SERIALNUMBER&gt;\r\n    hostname06-con: &lt;SERIALNUMBER&gt;\r\n    hostname07-con: &lt;SERIALNUMBER&gt;\r\n\r\n",
                "title": "Return key/value pairs in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1544938056,
        "creation_date": 1544896184,
        "last_edit_date": 1544938056,
        "question_id": 53795759,
        "body_markdown": "I have the following json output (generated by ansible) and a seemingly easy task of pulling a few key/value pairs out with `jq`. However, I can&#39;t seem to get the output I want.\r\n\r\n\r\n    {\r\n    &quot;custom_stats&quot;: {}, \r\n    &quot;plays&quot;: [\r\n        {\r\n            &quot;play&quot;: {\r\n                &quot;id&quot;: &quot;001dd8b7-1cca-07c6-2280-00000000043a&quot;, \r\n                &quot;name&quot;: &quot;Ansible Ad-Hoc&quot;\r\n            }, \r\n            &quot;tasks&quot;: [\r\n                {\r\n                    &quot;hosts&quot;: {\r\n                        &quot;hostname01-con&quot;: {\r\n                            &quot;_ansible_no_log&quot;: false, \r\n                            &quot;_ansible_verbose_always&quot;: true, \r\n                            &quot;action&quot;: &quot;debug&quot;, \r\n                            &quot;changed&quot;: false, \r\n                            &quot;hw_system_serial&quot;: &quot;&lt;SERIALNUMBER&gt;&quot;\r\n                        }, \r\n                        &quot;hostname02-con&quot;: {\r\n                            &quot;_ansible_no_log&quot;: false, \r\n                            &quot;_ansible_verbose_always&quot;: true, \r\n                            &quot;action&quot;: &quot;debug&quot;, \r\n                            &quot;changed&quot;: false, \r\n                            &quot;hw_system_serial&quot;: &quot;&lt;SERIALNUMBER&gt;&quot;\r\n                        }, \r\n                        &quot;hostname03-con&quot;: {\r\n                            &quot;_ansible_no_log&quot;: false, \r\n                            &quot;_ansible_verbose_always&quot;: true, \r\n                            &quot;action&quot;: &quot;debug&quot;, \r\n                            &quot;changed&quot;: false, \r\n                            &quot;hw_system_serial&quot;: &quot;&lt;SERIALNUMBER&gt;&quot;\r\n                        }, \r\n                        &quot;hostname04-con&quot;: {\r\n                            &quot;_ansible_no_log&quot;: false, \r\n                            &quot;_ansible_verbose_always&quot;: true, \r\n                            &quot;action&quot;: &quot;debug&quot;, \r\n                            &quot;changed&quot;: false, \r\n                            &quot;hw_system_serial&quot;: &quot;&lt;SERIALNUMBER&gt;&quot;\r\n                        }, \r\n                        &quot;hostname05-con&quot;: {\r\n                            &quot;_ansible_no_log&quot;: false, \r\n                            &quot;_ansible_verbose_always&quot;: true, \r\n                            &quot;action&quot;: &quot;debug&quot;, \r\n                            &quot;changed&quot;: false, \r\n                            &quot;hw_system_serial&quot;: &quot;&lt;SERIALNUMBER&gt;&quot;\r\n                        }, \r\n                        &quot;hostname06-con&quot;: {\r\n                            &quot;_ansible_no_log&quot;: false, \r\n                            &quot;_ansible_verbose_always&quot;: true, \r\n                            &quot;action&quot;: &quot;debug&quot;, \r\n                            &quot;changed&quot;: false, \r\n                            &quot;hw_system_serial&quot;: &quot;&lt;SERIALNUMBER&gt;&quot;\r\n                        }, \r\n                        &quot;hostname07-con&quot;: {\r\n                            &quot;_ansible_no_log&quot;: false, \r\n                            &quot;_ansible_verbose_always&quot;: true, \r\n                            &quot;action&quot;: &quot;debug&quot;, \r\n                            &quot;changed&quot;: false, \r\n                            &quot;hw_system_serial&quot;: &quot;&lt;SERIALNUMBER&gt;&quot;\r\n                        }, \r\n                        &quot;hostname01-con&quot;: {\r\n                            &quot;_ansible_no_log&quot;: false, \r\n                            &quot;_ansible_verbose_always&quot;: true, \r\n                            &quot;action&quot;: &quot;debug&quot;, \r\n                            &quot;changed&quot;: false, \r\n                            &quot;hw_system_serial&quot;: &quot;&lt;SERIALNUMBER&gt;&quot;\r\n                        }, \r\n                        &quot;hostname02-con&quot;: {\r\n                            &quot;_ansible_no_log&quot;: false, \r\n                            &quot;_ansible_verbose_always&quot;: true, \r\n                            &quot;action&quot;: &quot;debug&quot;, \r\n                            &quot;changed&quot;: false, \r\n                            &quot;hw_system_serial&quot;: &quot;&lt;SERIALNUMBER&gt;&quot;\r\n                        }, \r\n                        &quot;hostname03-con&quot;: {\r\n                            &quot;_ansible_no_log&quot;: false, \r\n                            &quot;_ansible_verbose_always&quot;: true, \r\n                            &quot;action&quot;: &quot;debug&quot;, \r\n                            &quot;changed&quot;: false, \r\n                            &quot;hw_system_serial&quot;: &quot;&lt;SERIALNUMBER&gt;&quot;\r\n                        }, \r\n                        &quot;hostname04-con&quot;: {\r\n                            &quot;_ansible_no_log&quot;: false, \r\n                            &quot;_ansible_verbose_always&quot;: true, \r\n                            &quot;action&quot;: &quot;debug&quot;, \r\n                            &quot;changed&quot;: false, \r\n                            &quot;hw_system_serial&quot;: &quot;&lt;SERIALNUMBER&gt;&quot;\r\n                        }, \r\n                        &quot;hostname05-con&quot;: {\r\n                            &quot;_ansible_no_log&quot;: false, \r\n                            &quot;_ansible_verbose_always&quot;: true, \r\n                            &quot;action&quot;: &quot;debug&quot;, \r\n                            &quot;changed&quot;: false, \r\n                            &quot;hw_system_serial&quot;: &quot;&lt;SERIALNUMBER&gt;&quot;\r\n                        }, \r\n                        &quot;hostname01-con&quot;: {\r\n                            &quot;_ansible_no_log&quot;: false, \r\n                            &quot;_ansible_verbose_always&quot;: true, \r\n                            &quot;action&quot;: &quot;debug&quot;, \r\n                            &quot;changed&quot;: false, \r\n                            &quot;hw_system_serial&quot;: &quot;&lt;SERIALNUMBER&gt;&quot;\r\n                        }, \r\n                        &quot;hostname02-con&quot;: {\r\n                            &quot;_ansible_no_log&quot;: false, \r\n                            &quot;_ansible_verbose_always&quot;: true, \r\n                            &quot;action&quot;: &quot;debug&quot;, \r\n                            &quot;changed&quot;: false, \r\n                            &quot;hw_system_serial&quot;: &quot;&lt;SERIALNUMBER&gt;&quot;\r\n                        }, \r\n                        &quot;hostname03-con&quot;: {\r\n                            &quot;_ansible_no_log&quot;: false, \r\n                            &quot;_ansible_verbose_always&quot;: true, \r\n                            &quot;action&quot;: &quot;debug&quot;, \r\n                            &quot;changed&quot;: false, \r\n                            &quot;hw_system_serial&quot;: &quot;&lt;SERIALNUMBER&gt;&quot;\r\n                        }, \r\n                        &quot;hostname04-con&quot;: {\r\n                            &quot;_ansible_no_log&quot;: false, \r\n                            &quot;_ansible_verbose_always&quot;: true, \r\n                            &quot;action&quot;: &quot;debug&quot;, \r\n                            &quot;changed&quot;: false, \r\n                            &quot;hw_system_serial&quot;: &quot;&lt;SERIALNUMBER&gt;&quot;\r\n                        }, \r\n                        &quot;hostname05-con&quot;: {\r\n                            &quot;_ansible_no_log&quot;: false, \r\n                            &quot;_ansible_verbose_always&quot;: true, \r\n                            &quot;action&quot;: &quot;debug&quot;, \r\n                            &quot;changed&quot;: false, \r\n                            &quot;hw_system_serial&quot;: &quot;&lt;SERIALNUMBER&gt;&quot;\r\n                        }, \r\n                        &quot;hostname06-con&quot;: {\r\n                            &quot;_ansible_no_log&quot;: false, \r\n                            &quot;_ansible_verbose_always&quot;: true, \r\n                            &quot;action&quot;: &quot;debug&quot;, \r\n                            &quot;changed&quot;: false, \r\n                            &quot;hw_system_serial&quot;: &quot;&lt;SERIALNUMBER&gt;&quot;\r\n                        }, \r\n                        &quot;hostname07-con&quot;: {\r\n                            &quot;_ansible_no_log&quot;: false, \r\n                            &quot;_ansible_verbose_always&quot;: true, \r\n                            &quot;action&quot;: &quot;debug&quot;, \r\n                            &quot;changed&quot;: false, \r\n                            &quot;hw_system_serial&quot;: &quot;&lt;SERIALNUMBER&gt;&quot;\r\n                        }\r\n                    }, \r\n                    &quot;task&quot;: {\r\n                        &quot;id&quot;: &quot;001dd8b7-1cca-07c6-2280-00000000043c&quot;, \r\n                        &quot;name&quot;: &quot;debug&quot;\r\n                    }\r\n                }\r\n            ]\r\n        }\r\n    ], \r\n    &quot;stats&quot;: {\r\n        &quot;hostname01-con&quot;: {\r\n            &quot;changed&quot;: 0, \r\n            &quot;failures&quot;: 0, \r\n            &quot;ok&quot;: 1, \r\n            &quot;skipped&quot;: 0, \r\n            &quot;unreachable&quot;: 0\r\n        }, \r\n        &quot;hostname02-con&quot;: {\r\n            &quot;changed&quot;: 0, \r\n            &quot;failures&quot;: 0, \r\n            &quot;ok&quot;: 1, \r\n            &quot;skipped&quot;: 0, \r\n            &quot;unreachable&quot;: 0\r\n        }, \r\n        &quot;hostname03-con&quot;: {\r\n            &quot;changed&quot;: 0, \r\n            &quot;failures&quot;: 0, \r\n            &quot;ok&quot;: 1, \r\n            &quot;skipped&quot;: 0, \r\n            &quot;unreachable&quot;: 0\r\n        }, \r\n        &quot;hostname04-con&quot;: {\r\n            &quot;changed&quot;: 0, \r\n            &quot;failures&quot;: 0, \r\n            &quot;ok&quot;: 1, \r\n            &quot;skipped&quot;: 0, \r\n            &quot;unreachable&quot;: 0\r\n        }, \r\n        &quot;hostname05-con&quot;: {\r\n            &quot;changed&quot;: 0, \r\n            &quot;failures&quot;: 0, \r\n            &quot;ok&quot;: 1, \r\n            &quot;skipped&quot;: 0, \r\n            &quot;unreachable&quot;: 0\r\n        }, \r\n        &quot;hostname06-con&quot;: {\r\n            &quot;changed&quot;: 0, \r\n            &quot;failures&quot;: 0, \r\n            &quot;ok&quot;: 1, \r\n            &quot;skipped&quot;: 0, \r\n            &quot;unreachable&quot;: 0\r\n        }, \r\n        &quot;hostname07-con&quot;: {\r\n            &quot;changed&quot;: 0, \r\n            &quot;failures&quot;: 0, \r\n            &quot;ok&quot;: 1, \r\n            &quot;skipped&quot;: 0, \r\n            &quot;unreachable&quot;: 0\r\n        }, \r\n        &quot;hostname01-con&quot;: {\r\n            &quot;changed&quot;: 0, \r\n            &quot;failures&quot;: 0, \r\n            &quot;ok&quot;: 1, \r\n            &quot;skipped&quot;: 0, \r\n            &quot;unreachable&quot;: 0\r\n        }, \r\n        &quot;hostname02-con&quot;: {\r\n            &quot;changed&quot;: 0, \r\n            &quot;failures&quot;: 0, \r\n            &quot;ok&quot;: 1, \r\n            &quot;skipped&quot;: 0, \r\n            &quot;unreachable&quot;: 0\r\n        }, \r\n        &quot;hostname03-con&quot;: {\r\n            &quot;changed&quot;: 0, \r\n            &quot;failures&quot;: 0, \r\n            &quot;ok&quot;: 1, \r\n            &quot;skipped&quot;: 0, \r\n            &quot;unreachable&quot;: 0\r\n        }, \r\n        &quot;hostname04-con&quot;: {\r\n            &quot;changed&quot;: 0, \r\n            &quot;failures&quot;: 0, \r\n            &quot;ok&quot;: 1, \r\n            &quot;skipped&quot;: 0, \r\n            &quot;unreachable&quot;: 0\r\n        }, \r\n        &quot;hostname05-con&quot;: {\r\n            &quot;changed&quot;: 0, \r\n            &quot;failures&quot;: 0, \r\n            &quot;ok&quot;: 1, \r\n            &quot;skipped&quot;: 0, \r\n            &quot;unreachable&quot;: 0\r\n        }, \r\n        &quot;hostname01-con&quot;: {\r\n            &quot;changed&quot;: 0, \r\n            &quot;failures&quot;: 0, \r\n            &quot;ok&quot;: 1, \r\n            &quot;skipped&quot;: 0, \r\n            &quot;unreachable&quot;: 0\r\n        }, \r\n        &quot;hostname02-con&quot;: {\r\n            &quot;changed&quot;: 0, \r\n            &quot;failures&quot;: 0, \r\n            &quot;ok&quot;: 1, \r\n            &quot;skipped&quot;: 0, \r\n            &quot;unreachable&quot;: 0\r\n        }, \r\n        &quot;hostname03-con&quot;: {\r\n            &quot;changed&quot;: 0, \r\n            &quot;failures&quot;: 0, \r\n            &quot;ok&quot;: 1, \r\n            &quot;skipped&quot;: 0, \r\n            &quot;unreachable&quot;: 0\r\n        }, \r\n        &quot;hostname04-con&quot;: {\r\n            &quot;changed&quot;: 0, \r\n            &quot;failures&quot;: 0, \r\n            &quot;ok&quot;: 1, \r\n            &quot;skipped&quot;: 0, \r\n            &quot;unreachable&quot;: 0\r\n        }, \r\n        &quot;hostname05-con&quot;: {\r\n            &quot;changed&quot;: 0, \r\n            &quot;failures&quot;: 0, \r\n            &quot;ok&quot;: 1, \r\n            &quot;skipped&quot;: 0, \r\n            &quot;unreachable&quot;: 0\r\n        }, \r\n        &quot;hostname06-con&quot;: {\r\n            &quot;changed&quot;: 0, \r\n            &quot;failures&quot;: 0, \r\n            &quot;ok&quot;: 1, \r\n            &quot;skipped&quot;: 0, \r\n            &quot;unreachable&quot;: 0\r\n        }, \r\n        &quot;hostname07-con&quot;: {\r\n            &quot;changed&quot;: 0, \r\n            &quot;failures&quot;: 0, \r\n            &quot;ok&quot;: 1, \r\n            &quot;skipped&quot;: 0, \r\n            &quot;unreachable&quot;: 0\r\n        }\r\n    }\r\n}\r\n\r\n\r\nBasically I&#39;d just like the key of the inner-most object along with its value for `hw_system_serial`, returned on the same line. Something like this:\r\n\r\n    hostname01-con: &lt;SERIAL_NUMBER_1&gt;\r\n    hostname02-con: &lt;SERIAL_NUMBER_2&gt;\r\n    etc\r\n\r\nI feel like this should be trivial (I could have written a little ruby or python script in this time...), but try as I might I can&#39;t get it correct. I&#39;ve tried all sorts of things, but I either end up iterating over the list of hosts for *every* serial number or returning two separate lists (one hosts and one serial numbers).\r\n\r\nFor example, this:\r\n\r\n    .plays[].tasks[].hosts | keys as $hosts | .[].hw_system_serial as $serial | $hosts | join(&quot;: &quot;) + $serial\r\n\r\nreturns a list of every host name on a single line followed by one serial number.\r\n\r\nI *think* it will work if I can convert `$serial` to an array, but my attempts to use `split()` have also failed (e.g. `$serial | split(&quot;\\r&quot;)` returns a list of single-item arrays rather than an array of items).\r\n\r\nWhat am I missing here? I feel like `jq` should have an easy time with this (again, any scripting language with a JSON parser...), but is it just not the right tool for the job?",
        "link": "https://stackoverflow.com/questions/53795759/return-key-value-pairs-in-jq",
        "title": "Return key/value pairs in jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "intersection"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1545052178,
                "post_id": 53810833,
                "comment_id": 94479983,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3737085,
                    "reputation": 11105,
                    "user_id": 3107798,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/8c1946036d22a624bd3167099c4448c1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jjbskir",
                    "link": "https://stackoverflow.com/users/3107798/jjbskir"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1679582741,
                "post_id": 53810833,
                "comment_id": 133750385,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1633063582,
                "last_edit_date": 1633063582,
                "creation_date": 1545034520,
                "answer_id": 53811178,
                "question_id": 53810833,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming arrays do not contain duplicates (if they do, use `unique` to filter out duplicate results):\r\n\r\n``` shell\r\njq -cn &#39;[&quot;a&quot;,&quot;b&quot;,&quot;e&quot;,&quot;c&quot;] as $A | [&quot;g&quot;,&quot;a&quot;,&quot;t&quot;,&quot;c&quot;] as $B | $A - ($A - $B)&#39;\r\n```\r\n``` shell\r\necho &#39;{ &quot;group_a&quot; : [&quot;a&quot;,&quot;b&quot;,&quot;e&quot;,&quot;c&quot;], &quot;group_b&quot; : [&quot;g&quot;,&quot;a&quot;,&quot;t&quot;,&quot;c&quot;] }&#39; |\r\n jq -c &#39;.group_a - (.group_a - .group_b)&#39;\r\n```\r\nThey both yield:\r\n```\r\n[&quot;a&quot;,&quot;c&quot;]\r\n```",
                "title": "Get intersection of arrays in JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1741355412,
                "last_edit_date": 1741355412,
                "creation_date": 1741352871,
                "answer_id": 79492409,
                "question_id": 53810833,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To get a general intersection operation for any number of arrays, here&#39;s my solution:\r\n\r\n```\r\n$ echo &quot;[ [1, 2], [2, 3], [4, 2] ]&quot; | \\\r\n  jq &#39;reduce .[1:][] as $item(.[0]; . - (. - $item))&#39;\r\n[\r\n  2\r\n]\r\n```\r\n\r\nInput: array of arrays. The inner arrays are those that should be intersected.\r\n\r\nOutput: array of all values that are present in all inner arrays of input.",
                "title": "Get intersection of arrays in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1741355412,
        "creation_date": 1545032768,
        "last_edit_date": 1633063513,
        "question_id": 53810833,
        "body_markdown": "I&#39;m new to jq,\r\n\r\nand would like to get the intersection of two arrays (similar question BUT with **different approach**: [link][1]).\r\nI managed to get the union of two arrays and addition of two arrays:\r\ni.e:\r\n\r\n    A=[&#39;a&#39;,&#39;b&#39;,&#39;e&#39;,&#39;c&#39;]\r\n    B=[&#39;g&#39;,&#39;a&#39;,&#39;t&#39;,&#39;c&#39;]\r\n\r\nI have wrote:\r\n\r\n    echo &#39;{&quot;group_a&quot;:[&quot;A&quot;,&quot;B&quot;,&quot;C&quot;,&quot;ABC&quot;],&quot;group_b&quot;:[&quot;B&quot;,&quot;D&quot;]}&#39; | jq .group_a+.group_b\r\n\r\nA+B = [&#39;a&#39;,&#39;b&#39;,&#39;e&#39;,&#39;c&#39;,&#39;g&#39;,&#39;g&#39;,&#39;a&#39;,&#39;t&#39;,&#39;c&#39;] \r\n\r\n    echo &#39;{&quot;group_a&quot;:[&quot;A&quot;,&quot;B&quot;,&quot;C&quot;,&quot;ABC&quot;],&quot;group_b&quot;:[&quot;B&quot;,&quot;D&quot;]}&#39; | jq .group_a+.group_b | jq &#39;unique&#39;\r\n\r\nA U B = [&#39;a&#39;,&#39;b&#39;,&#39;e&#39;,&#39;c&#39;,&#39;g&#39;,&#39;t&#39;] \r\n\r\nbut how do i now apply this simple logic:\r\n\r\n    intersection = unique((A+B) - (A U B))\r\ni&#39;m used to one liners, and I&#39;d like this snippet to be readable and elegant for future use.\r\nso how do i implement this in jq style?\r\n\r\nany assistance will be helpful, Thank you all!\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/38364458/how-to-get-the-intersection-of-two-json-arrays-using-jq",
        "link": "https://stackoverflow.com/questions/53810833/get-intersection-of-arrays-in-jq",
        "title": "Get intersection of arrays in JQ"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1545079590,
                "creation_date": 1545079590,
                "answer_id": 53822759,
                "question_id": 53822333,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s a number of issues in your query. The types in your hierarchy of objects are:\r\n\r\n* (root) - object\r\n* DBInstances - array of object\r\n* DBSubnetGroup - object\r\n* Subnets - array of object\r\n\r\nYou generally don&#39;t want to use `[]` on objects as it will just enumerate over all values when all you really want is a specific property.\r\n\r\nIf you just want to output all the subnet statuses, your query should be this:\r\n\r\n    .DBInstances[].DBSubnetGroup.Subnets[].SubnetStatus",
                "title": "Unable to iterate over json values with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1545079590,
        "creation_date": 1545077273,
        "question_id": 53822333,
        "body_markdown": "I&#39;m building a list of RDS instances in AWS. Working with local json file for now.\r\n\r\nI am able to get up to the `&#39;.DBInstances[].DBSubnetGroup[]&#39;` level in the [ORIGINAL JSON][1] file. With this command:\r\n\r\n    jq -r &#39;.DBInstances[].DBSubnetGroup[]&#39; ab-prod-rds.json\r\n\r\nBut I am unable to get at the information in the `&#39;.DBInstances[].DBSubnetGroup[].Subnets.SubnetStatus&#39;` level of the same.\r\n\r\nWhen I give this command: `jq -r &#39;.DBInstances[].DBSubnetGroup[].Subnets.SubnetStatus&#39; ab-prod-rds.json`\r\n\r\nThe error I get is: `jq: error (at ab-prod-rds.json:618): Cannot index array with string &quot;Subnets&quot;`\r\n\r\nWhat am I doing wrong? How can I format the query to access this info?\r\n\r\n\r\n  [1]: https://gist.github.com/bluethundr/092ca6e39016188f56d8b46b203be06d",
        "link": "https://stackoverflow.com/questions/53822333/unable-to-iterate-over-json-values-with-jq",
        "title": "Unable to iterate over json values with jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "grouping",
            "jq",
            "file-conversion"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1546087462,
                "last_edit_date": 1546087462,
                "creation_date": 1545109396,
                "answer_id": 53826677,
                "question_id": 53825395,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The key to a simple solution is the generic function `aggregate_by`:\r\n\r\n    # In this formulation, f must either always evaluate to a string or\r\n    # always to an integer, it being understood that negative integers\r\n    # might be problematic\r\n    def aggregate_by(s; f; g):\r\n      reduce s as $x  (null; .[$x|f] += [$x|g]);\r\n\r\nIf the CSV can be accurately parsed by simply splitting on commas, then the desired transformation can be accomplished using the following jq filter:\r\n\r\n    aggregate_by(inputs | split(&quot;,&quot;); .[0]; .[1])\r\n\r\nThis assumes jq is invoked with the -R (raw) and -n options.  \r\n\r\n## Output\r\n\r\nWith the given CSV input, the output would be:\r\n\r\n    {\r\n      &quot;b00nw33&quot;: [\r\n        &quot;harrypotter788.flv&quot;,\r\n        &quot;harrypotter788.mov&quot;,\r\n        &quot;levitation271.avi&quot;\r\n      ],\r\n      &quot;b01spider&quot;: [\r\n        &quot;schimbvalutar109.avi&quot;\r\n      ]\r\n    }\r\n\r\n## Handling non-trivial CSV\r\n\r\nThe above solution assumes that the CSV is as uncomplicated as the sample.  If, on the contrary, the CSV cannot be accurately parsed by simply splitting at commas, a more general parser will be needed.  \r\n\r\nOne approach would be to use the very robust and fast csv2json parser at https://github.com/fadado/CSV\r\n\r\nAlternatively, you could use one of the many available &quot;csv2tsv&quot; parsers to generate TSV, which jq can handle directly (by splitting on tabs, i.e. `split(&quot;\\t&quot;)` rather than `split(&quot;,&quot;)`).  \r\n\r\nIn any case, once the CSV has been converted to JSON, the filter `aggregate_by` defined above can be used.\r\n\r\nIf you are interested in a jq parser for CSV, you might want to look at `fromcsvfile` (https://gist.github.com/pkoppstein/bbbbdf7489c8c515680beb1c75fa59f2); see also \r\nthe definitions for `fromcsv` being proposed at https://github.com/stedolan/jq/issues/1650#issuecomment-448050902\r\n",
                "title": "Convert CSV to Grouped JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1546087462,
        "creation_date": 1545098363,
        "last_edit_date": 1545138218,
        "question_id": 53825395,
        "body_markdown": "I have several large CSV&#39;s which I would like to export to a particular JSON format but I&#39;m not really sure how to convert it over. It&#39;s a list of usernames and urls.\r\n\r\n    b00nw33,harrypotter788.flv\r\n    b00nw33,harrypotter788.mov\r\n    b00nw33,levitation271.avi\r\n    b01spider,schimbvalutar109.avi\r\n    ... \r\n\r\nI want to export them to JSON grouped by the username like the following\r\n\r\n    {\r\n      &quot;b00nw33&quot;: [\r\n        &quot;harrypotter788.flv&quot;,\r\n        &quot;harrypotter788.mov&quot;,\r\n        &quot;levitation271.avi&quot;\r\n      ],\r\n      &quot;b01spider&quot;: [\r\n        &quot;schimbvalutar109.avi&quot;\r\n      ]\r\n    }\r\n\r\nWhat is the JQ to do this? Thank you!",
        "link": "https://stackoverflow.com/questions/53825395/convert-csv-to-grouped-json",
        "title": "Convert CSV to Grouped JSON"
    },
    {
        "tags": [
            "json",
            "select",
            "jq",
            "string-matching",
            "amazon-route53"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1545132944,
                "last_edit_date": 1545132944,
                "creation_date": 1545118359,
                "answer_id": 53828257,
                "question_id": 53828173,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It is a simple filter on `jq` to use `endswith` or `test` to match `us-west-2` on the `.Config.Comment` field value. (See it working on [jqplay.org](https://jqplay.org/s/jNfXsn0hPj) )\r\n\r\n    jq &#39;.HostedZones[] | select( .Config.Comment | test(&quot;us-west-2$&quot;) ).Id&#39;\r\n\r\nAs ever, to remove the outer quotes, use the `--raw-output` mode with `jq -r ..`\r\n",
                "title": "How to get the HostedZoneId of a HostedZone in As route53 with same name?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1545132944,
        "creation_date": 1545117929,
        "last_edit_date": 1545128905,
        "question_id": 53828173,
        "body_markdown": "I have 2 hosted zone with the same name. I want to get the hostedZoneId of a Hostedzone used for us-west-2 region.\r\n\r\n    aws route53 list-hosted-zones-by-name --dns-name domainname\r\n\r\nIt gives the following output:\r\n\r\n    {\r\n        &quot;HostedZones&quot;: [\r\n            {\r\n                &quot;ResourceRecordSetCount&quot;: 3, \r\n                &quot;CallerReference&quot;: &quot;2018-08-07T14:02:30.733383821+05:30&quot;, \r\n                &quot;Config&quot;: {\r\n                    &quot;Comment&quot;: &quot;Private Hosted Zone for tenant:us-west-2&quot;, \r\n                    &quot;PrivateZone&quot;: true\r\n                }, \r\n                &quot;Id&quot;: &quot;/hostedzone/D2JGX0PDINSIDA&quot;, \r\n                &quot;Name&quot;: &quot;domainname.&quot;\r\n            }, \r\n            {\r\n                &quot;ResourceRecordSetCount&quot;: 3, \r\n                &quot;CallerReference&quot;: &quot;2018-08-16T16:38:29.821900042+05:30&quot;, \r\n                &quot;Config&quot;: {\r\n                    &quot;Comment&quot;: &quot;Private Hosted Zone for tenant:eu-west-1&quot;, \r\n                    &quot;PrivateZone&quot;: true\r\n                }, \r\n                &quot;Id&quot;: &quot;/hostedzone/Q1HEEHGD5JH3G3&quot;, \r\n                &quot;Name&quot;: &quot;domainname.&quot;\r\n            }\r\n        ], \r\n        &quot;DNSName&quot;: &quot;domainname&quot;, \r\n        &quot;IsTruncated&quot;: false, \r\n        &quot;MaxItems&quot;: &quot;100&quot;\r\n    }\r\n\r\nAs you can see there are two records for the same name, I want to get the Id of a hostedZone used for us-west-2. I dont have any uniqueness now to identify the HostedZone used for Us other than the Comment.\r\n\r\nI tried with jq but I am not aware of how to provide conditions to it.\r\n\r\n    aws route53 list-hosted-zones-by-name --dns-name domainname | jq &quot;.HostedZones | .[] | .Config&quot;\r\n\r\nAny help would be appreciated or any references\r\n",
        "link": "https://stackoverflow.com/questions/53828173/how-to-get-the-hostedzoneid-of-a-hostedzone-in-as-route53-with-same-name",
        "title": "How to get the HostedZoneId of a HostedZone in As route53 with same name?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "edit",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1545238821,
                "creation_date": 1545238821,
                "answer_id": 53855948,
                "question_id": 53855828,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem with your attempt is that you&#39;ve expanded .foofoo.barbar by writing .foofoo.barbar[].\r\n\r\nWhat you want instead is to reset it:\r\n\r\n\r\n    .foofoo.barbar |= map(select(.bar !=&quot;cccc&quot;))",
                "title": "Filter an array inside JSON w/ jq while retaining surrounding structure"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1545248819,
        "creation_date": 1545238451,
        "last_edit_date": 1545248819,
        "question_id": 53855828,
        "body_markdown": " JSON data as below, I want to discard when &quot;bar&quot;=&quot;cccc&quot; without altering the structure.\r\n \r\n\r\n    {\r\n          &quot;foofoo&quot;: {\r\n            &quot;barbar&quot;: [\r\n              {\r\n                &quot;foo&quot;: &quot;0000&quot;,\r\n                &quot;bar&quot;: &quot;aaaa&quot;\r\n              },\r\n              {\r\n                &quot;foo&quot;: &quot;1111&quot;,\r\n                &quot;bar&quot;: &quot;bbbb&quot;\r\n              },\r\n              {\r\n                &quot;foo&quot;: &quot;2222&quot;,\r\n                &quot;bar&quot;: &quot;cccc&quot;\r\n              }\r\n              ]\r\n          }\r\n    }\r\n\r\n\r\nsomething like this does the trick but it alters the JSON structure.\r\n\r\n    .foofoo.barbar[] | select(.bar !=&quot;cccc&quot;)\r\n\r\nresults in:\r\n\r\n    {\r\n      &quot;foo&quot;: &quot;0000&quot;,\r\n      &quot;bar&quot;: &quot;aaaa&quot;\r\n    }\r\n    {\r\n      &quot;foo&quot;: &quot;1111&quot;,\r\n      &quot;bar&quot;: &quot;bbbb&quot;\r\n    }\r\n\r\nneeded result is:\r\n\r\n    {\r\n      &quot;foofoo&quot;: {\r\n        &quot;barbar&quot;: [\r\n        {\r\n          &quot;foo&quot;: &quot;0000&quot;,\r\n          &quot;bar&quot;: &quot;aaaa&quot;\r\n        }\r\n        {\r\n          &quot;foo&quot;: &quot;1111&quot;,\r\n          &quot;bar&quot;: &quot;bbbb&quot;\r\n        }\r\n        ]\r\n      }\r\n    }\r\n\r\nThanks!\r\n",
        "link": "https://stackoverflow.com/questions/53855828/filter-an-array-inside-json-w-jq-while-retaining-surrounding-structure",
        "title": "Filter an array inside JSON w/ jq while retaining surrounding structure"
    },
    {
        "tags": [
            "json",
            "path",
            "jq",
            "scalar"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1545294616,
                "last_edit_date": 1545294616,
                "creation_date": 1545293703,
                "answer_id": 53864717,
                "question_id": 53864041,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The key to answering both questions is `paths`.\r\nFor example, the following filter produces the desired output in the first case:\r\n\r\n    paths as $p\r\n    | getpath($p)\r\n    | select(scalars)\r\n    | ($p | map(select(type==&quot;string&quot;))) + [.]\r\n\r\nThe same filter can be used with any valid JSON as input.  Replacing .cond2 with a valid nested array along the lines shown in the Q, the output would be:\r\n\r\n    [&quot;cond1&quot;,&quot;a&quot;]\r\n    [&quot;cond1&quot;,&quot;b&quot;]\r\n    [&quot;cond1&quot;,&quot;c&quot;]\r\n    [&quot;cond2&quot;,&quot;x2&quot;]\r\n    [&quot;cond2&quot;,&quot;x3&quot;]\r\n    [&quot;cond2&quot;,&quot;x1&quot;]\r\n    [&quot;cond2&quot;,&quot;x2&quot;]\r\n\r\n",
                "title": "Gathering all root to leaf values along every path in a tree-like json object with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1545294616,
        "creation_date": 1545290402,
        "last_edit_date": 1545294496,
        "question_id": 53864041,
        "body_markdown": "Gathering all root to leaf values along every path in a tree-like json object with JQ. It seems like this should be easy with the walk or flatten functions, but I can&#39;t figure it out despite some helpful questions that have already been asked.\r\n\r\nI have this\r\n\r\n     {\r\n         &quot;cond1&quot;:[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;],\r\n         &quot;cond2&quot;:[&quot;a1&quot;,&quot;b2&quot;,&quot;c&quot;],\r\n         &quot;cond2&quot;:[&quot;a&quot;,&quot;b&quot;,&quot;c3&quot;]    \r\n     }    \r\n\r\nI want this\r\n\r\n    [&quot;cond1&quot;,&quot;a&quot;]\r\n    [&quot;cond1&quot;,&quot;b&quot;]\r\n    [&quot;cond1&quot;,&quot;c&quot;]\r\n    [&quot;cond2&quot;,&quot;a1&quot;]\r\n    [&quot;cond2&quot;,&quot;b2&quot;]\r\n    [&quot;cond2&quot;,&quot;c&quot;]\r\n    [&quot;cond2&quot;:&quot;a&quot;]\r\n    [&quot;cond2&quot;:&quot;b&quot;]\r\n    [&quot;cond2&quot;:&quot;c3&quot;]\r\n\r\nSimilar questions:\r\nhttps://github.com/stedolan/jq/issues/646\r\nhttps://stackoverflow.com/questions/38689645/jq-how-do-i-print-a-parent-value-of-an-object-when-i-am-already-deep-into-the\r\n\r\nAlso, how would the answer be different if instead of [&quot;a&quot;,&quot;b&quot;,&quot;c&quot;] the array consisted on nested objects i.e. [[&quot;x2&quot;,&quot;x3&quot;],[&quot;x1,&quot;x2&quot;]]\r\n",
        "link": "https://stackoverflow.com/questions/53864041/gathering-all-root-to-leaf-values-along-every-path-in-a-tree-like-json-object-wi",
        "title": "Gathering all root to leaf values along every path in a tree-like json object with JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 6,
                "creation_date": 1545322876,
                "post_id": 53872349,
                "comment_id": 94592049,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10266894,
                    "reputation": 959,
                    "user_id": 7576611,
                    "user_type": "registered",
                    "accept_rate": 29,
                    "profile_image": "https://lh4.googleusercontent.com/-5qWm5XliK5c/AAAAAAAAAAI/AAAAAAAAAAs/GoUmSiF72uI/s256-rj/photo.jpg",
                    "display_name": "Shabbir Bata",
                    "link": "https://stackoverflow.com/users/7576611/shabbir-bata"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1545323031,
                "post_id": 53872349,
                "comment_id": 94592109,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1545323236,
                "post_id": 53872349,
                "comment_id": 94592220,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10266894,
                    "reputation": 959,
                    "user_id": 7576611,
                    "user_type": "registered",
                    "accept_rate": 29,
                    "profile_image": "https://lh4.googleusercontent.com/-5qWm5XliK5c/AAAAAAAAAAI/AAAAAAAAAAs/GoUmSiF72uI/s256-rj/photo.jpg",
                    "display_name": "Shabbir Bata",
                    "link": "https://stackoverflow.com/users/7576611/shabbir-bata"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1545327650,
                "post_id": 53872349,
                "comment_id": 94594395,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1545324595,
                "last_edit_date": 1545324595,
                "creation_date": 1545324278,
                "answer_id": 53872817,
                "question_id": 53872349,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `&#39;` to enclose the `sed` script, in order to avoid escaping `&quot;`.\r\nYour goal is to search for `JAVA_OPTS`, and then modify the string in the line after.\r\n\r\nI always have this super tutorial open aside in order to help: [Sed - An Introduction and Tutorial by Bruce Barnett][1]\r\n\r\n`N`: this `sed` command reads the next line in the file and happends it to the pattern buffer.\r\n\r\nThe example below is doing the trick but this is going to break easily when the `json` data vary; it is recommended to use `jq` as @Iniam suggested.\r\n\r\nIf you still want to have something working for the example in your question, give a try to this:\r\n\r\n    sed -i &#39;/&quot;name&quot;[[:blank:]]*:[[:blank:]]*&quot;JAVA_OPTS&quot;[[:blank:]]*,/ { N ; s/-Dspring.cloud.config.label=\\(.*\\) -Duser/-Dspring.cloud.config.label=${Config_Label} -Duser/ ; }&#39; file.json\r\n\r\n\r\nSame version on several lines:\r\n\r\n    sed -i &#39;/&quot;name&quot;[[:blank:]]*:[[:blank:]]*&quot;JAVA_OPTS&quot;[[:blank:]]*,/ {\r\n        N\r\n        s/-Dspring.cloud.config.label=\\(.*\\) -Duser/-Dspring.cloud.config.label=${Config_Label} -Duser/\r\n    } &#39; file.json\r\n\r\n\r\n  [1]: http://www.grymoire.com/Unix/Sed.html",
                "title": "How to edit value in json using sed"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1545329672,
                "creation_date": 1545329672,
                "answer_id": 53874034,
                "question_id": 53872349,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When modifying objects in jq, all it takes really is:\r\n\r\n1. Find the object you want to update  \r\n\r\n        # the environment object with the name &quot;JAVA_OPTS&quot;\r\n        .environment[] | select(.name == &quot;JAVA_OPTS&quot;)\r\n\r\n2. Assign a new value to the property you want updated\r\n\r\n        # update the value property using (= or |=)\r\n        .environment[] | select(.name == &quot;JAVA_OPTS&quot;).value = ...\r\n\r\nAt this point, it&#39;s just a question of, updating a string to replace with something else. You can use a regular expression to do the replacement or any other replacement approach you&#39;d like:\r\n\r\n    sub(&quot;(?&lt;k&gt;-Dspring\\\\.cloud\\\\.config\\\\.label)=&lt;some value&gt;&quot;; &quot;\\(.k)=${Config_Label}&quot;)\r\n\r\nPutting that all together:\r\n\r\n    .environment[] | select(.name == &quot;JAVA_OPTS&quot;).value\r\n        |= sub(&quot;(?&lt;k&gt;-Dspring\\\\.cloud\\\\.config\\\\.label)=&lt;some value&gt;&quot;; &quot;\\(.k)=${Config_Label}&quot;)",
                "title": "How to edit value in json using sed"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1545334286,
                "creation_date": 1545334286,
                "answer_id": 53874926,
                "question_id": 53872349,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could also do this with a simple Node script as well.  If the shell environment variable is, say VERSION, you could use the following script for this replacement, as well as other possible manipulations of the file for the build process you might be running:\r\n\r\n    #!/usr/bin/env node\r\n    // replace.js\r\n    const chunks = [];\r\n    \r\n    process.stdin.resume();\r\n    process.stdin.setEncoding(&#39;utf8&#39;);\r\n    \r\n    process.stdin.on(&#39;data&#39;, (chunk) =&gt; {\r\n    \tchunks.push(chunk);\r\n    });\r\n    \r\n    process.stdin.on(&#39;end&#39;, () =&gt; {\r\n    \tconst json = JSON.parse(chunks.join(&#39;&#39;));\r\n    \t\r\n    \t// Process json.environment array\r\n    \tjson.environment = json.environment.map(obj =&gt; {\r\n    \t\tif (obj.name == &#39;JAVA_OPTS&#39;) {\r\n          \t\t\tobj.value = obj.value.replace(/(-Dspring.cloud.config.label=)([^\\s]+)/, `$1${process.env.VERSION}`);\r\n    \t\t}\r\n    \t\treturn obj;\r\n    \t});\r\n    \r\n    \tprocess.stdout.write(JSON.stringify(json, null, 2));\r\n    \tprocess.stdout.write(&#39;\\n&#39;);\r\n    });\r\n\r\nYou can then run it like:\r\n\r\n    $ VERSION=v6.7 ./replace.js &lt; YOURFILE.json",
                "title": "How to edit value in json using sed"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1545335102,
                "creation_date": 1545335102,
                "answer_id": 53875084,
                "question_id": 53872349,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the file contains _Dspring.cloud.config.label_ only once \r\n\r\nYou can directly use this:\r\n\r\n     sed &#39;s/Dspring.cloud.config.label=\\S*/Dspring.cloud.config.label=${Config_Label}/g&#39; json\r\n\r\nif you want to commit this change into your put -i after sed\r\n\r\nbut if _Dspring.cloud.config.label_ string comes multiple times please share more details of file.\r\n\r\n\r\n [![enter image description here][1]][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/sMpq5.png",
                "title": "How to edit value in json using sed"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1545339105,
                "creation_date": 1545339105,
                "answer_id": 53875855,
                "question_id": 53872349,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since \r\n\r\n&gt; Dspring.cloud.config.label \r\n\r\nwas occurring only once in the json file, I have made use of sed function as mentioned by one of the users (Mohit Rathore). \r\nThis may not be an exceptional solution, but it was simple and it worked in this use case.\r\n\r\n    sed -i &quot;s/Dspring.cloud.config.label=\\S*/Dspring.cloud.config.label=${Config_Label}/g&quot; file.json \r\n\r\nThank you. ",
                "title": "How to edit value in json using sed"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 1,
        "last_activity_date": 1545339105,
        "creation_date": 1545322607,
        "last_edit_date": 1545328010,
        "question_id": 53872349,
        "body_markdown": "I have the following json file: \r\n\r\n\r\n    &quot;environment&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;DD_AGENT_HOST&quot;,\r\n              &quot;value&quot;: &quot;somevalue.com&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;DD_AGENT_PORT&quot;,\r\n              &quot;value&quot;: &quot;1234&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;DD_TRACE_SPAN_TAGS&quot;,\r\n              &quot;value&quot;: &quot;env:test&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;JAVA_OPTS&quot;,\r\n              &quot;value&quot;: &quot;-javaagent:/dd-java-agent/dd-java-agent.jar -Xms512m -Xmx2548m -XX:MaxPermSize=512m -Dspring.profiles.active=testapp -Dspring.cloud.config.label=&lt;some value&gt; -Duser.timezone=America/New_York&quot;\r\n            }\r\n\r\nI am trying to change a particular parameter in value for key &quot;JAVA_OPTS&quot;. \r\nThis is a part of Jenkins job,\r\n\r\nThis is what I am trying to achieve, is to be able to change the value for parameter ${Config_Label} `-Dspring.cloud.config.label=${Config_Label}`\r\n\r\nAnd I have tried this solution which does not seem to work:\r\n\r\n    sed -i &quot;/value/c\\   \\&quot;value\\&quot; : \\&quot;-javaagent:/dd-java-agent/dd-java-agent.jar -Xms512m -Xmx2548m -XX:MaxPermSize=512m -Dspring.profiles.active=testapp -Dencrypt.key=bjb4343knwdc -Dspring.cloud.config.label=${Config_Label} -Duser.timezone=America/New_York&quot;\\&quot;,&quot; file.json\r\n\r\n\r\nBut the syntax doesn&#39;t work and the Jenkins job fails with error \r\n\r\n&gt; unexpected EOF while looking for matching `&quot;&#39;\r\n\r\nHoping someone could correct me here. \r\nThank you. ",
        "link": "https://stackoverflow.com/questions/53872349/how-to-edit-value-in-json-using-sed",
        "title": "How to edit value in json using sed"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1545327514,
                "creation_date": 1545327514,
                "answer_id": 53873604,
                "question_id": 53873159,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `select()` filter on the name and get the id value with the following filter\r\n\r\n    jq &#39;.HostedZones[] | select (.Name==&quot;internal.mydomain.com.&quot;).Id&#39;\r\n",
                "title": "Select object based on value of variable in json array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1545327514,
        "creation_date": 1545325603,
        "question_id": 53873159,
        "body_markdown": "I have the following json file:\r\n\r\n     {\r\n         &quot;HostedZones&quot;: [\r\n             {\r\n                 &quot;Id&quot;: &quot;Z3JX6LQV6IJO3E&quot;,\r\n                 &quot;Name&quot;: &quot;sandbox.mydomain.com.&quot;\r\n             },\r\n             {\r\n                 &quot;Id&quot;: &quot;Z13M9NFG2E4J5N&quot;,\r\n                 &quot;Name&quot;: &quot;internal.mydomain.com.&quot;\r\n             }\r\n         ]\r\n     }\r\n\r\nI am using jq and want to get the &quot;Id&quot; value of the object where &#39;Name&#39; is &#39;internal.mydomain.com.&#39;.\r\n",
        "link": "https://stackoverflow.com/questions/53873159/select-object-based-on-value-of-variable-in-json-array-using-jq",
        "title": "Select object based on value of variable in json array using jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "inplace-editing"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1545353945,
                "post_id": 53877887,
                "comment_id": 94603193,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1545354080,
                "post_id": 53877887,
                "comment_id": 94603214,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1545354541,
                "post_id": 53877887,
                "comment_id": 94603294,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1545353952,
                "creation_date": 1545353952,
                "answer_id": 53877958,
                "question_id": 53877887,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Doing in-place updates can be done with `|=`, and deciding whether to modify content in-place can be done with if/then/else. Thus:\r\n\r\n    jq &#39;.Rules[] |= (if .Filter.Prefix == &quot;to_me/&quot; then .Status=&quot;Disabled&quot; else . end)&#39;",
                "title": "in place edit, search for nested value and then replace another value"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1545358969,
                "last_edit_date": 1545358969,
                "creation_date": 1545355308,
                "answer_id": 53878089,
                "question_id": 53877887,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I prefer the idiom `ARRAY |= map(...)` over `ARRAY[] |= ...`, mainly because the former can be used reliably whether or not any of the substitutions evaluate to `empty`:\r\n\r\n    jq &#39;.Rules |= map(if .Filter.Prefix == &quot;to_me/&quot; \r\n                      then .Status=&quot;Disabled&quot; else . end)&#39;\r\n\r\nTo overwrite the input file, you might like to consider `sponge` from [moremutils][1].\r\n\r\n\r\n  [1]: https://packages.debian.org/stable/utils/moreutils",
                "title": "in place edit, search for nested value and then replace another value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1545394094,
        "creation_date": 1545353136,
        "last_edit_date": 1545394094,
        "question_id": 53877887,
        "body_markdown": "I have an input JSON document with roughly the following form (actual data has additional keys, which should be passed through unmodified; the whitespace is adjusted for human readability, and there&#39;s no expectation that it be maintained):\r\n\r\n    {\r\n        &quot;Rules&quot;: [\r\n            {&quot;Filter&quot;: { &quot;Prefix&quot;: &quot;to_me/&quot; },   &quot;Status&quot;: &quot;Enabled&quot; }, \r\n            {&quot;Filter&quot;: { &quot;Prefix&quot;: &quot;from_me/&quot; }, &quot;Status&quot;: &quot;Enabled&quot; }, \r\n            {&quot;Filter&quot;: { &quot;Prefix&quot;: &quot;__bg/&quot; },    &quot;Status&quot;: &quot;Enabled&quot; }\r\n        ]\r\n    }\r\n\r\nI need to match `.Rules[].Filter.Prefix==&quot;to_me/&quot;` and then change the associated `&quot;Status&quot;: &quot;Enabled&quot;` to `&quot;Disabled&quot;`. Since only the first rule above has a prefix of `to_me/`, status of that rule would be changed to `Disabled`, making correct output look like the following:\r\n\r\n    {\r\n        &quot;Rules&quot;: [\r\n            {&quot;Filter&quot;: { &quot;Prefix&quot;: &quot;to_me/&quot; },   &quot;Status&quot;: &quot;Disabled&quot; }, \r\n            {&quot;Filter&quot;: { &quot;Prefix&quot;: &quot;from_me/&quot; }, &quot;Status&quot;: &quot;Enabled&quot; }, \r\n            {&quot;Filter&quot;: { &quot;Prefix&quot;: &quot;__bg/&quot; },    &quot;Status&quot;: &quot;Enabled&quot; }\r\n        ]\r\n    }\r\n\r\n\r\nI&#39;ve tried several different combinations but can&#39;t seem to get it right.\r\n\r\nAnyone have ideas?  \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53877887/in-place-edit-search-for-nested-value-and-then-replace-another-value",
        "title": "in place edit, search for nested value and then replace another value"
    },
    {
        "tags": [
            "json",
            "select",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1545465990,
                "post_id": 53893946,
                "comment_id": 94634187,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4564440,
                    "reputation": 523,
                    "user_id": 4914701,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f9864d5fbc7ee617abd419c3d172f5ba?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Matt B",
                    "link": "https://stackoverflow.com/users/4914701/matt-b"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1545466192,
                "post_id": 53893946,
                "comment_id": 94634213,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1545467010,
                "post_id": 53893946,
                "comment_id": 94634337,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4564440,
                    "reputation": 523,
                    "user_id": 4914701,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f9864d5fbc7ee617abd419c3d172f5ba?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Matt B",
                    "link": "https://stackoverflow.com/users/4914701/matt-b"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1545468517,
                "post_id": 53893946,
                "comment_id": 94634579,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1545500327,
                "last_edit_date": 1545500327,
                "creation_date": 1545486717,
                "answer_id": 53896206,
                "question_id": 53893946,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; How do I write a query that returns &#39;https://www.example.org/simplecategory?_format=hal_json&#39;?\r\n\r\nIf you want to specify the top-level key explicitly, the follow-on query would be:\r\n\r\n    .[&quot;https://www.example.org/rest/relation/node/recording/revision_uid&quot;][]\r\n    | ._links.self.href\r\n\r\nThat is, the entire query would be:\r\n\r\n    ._embedded\r\n    | .[&quot;https://www.example.org/rest/relation/node/recording/revision_uid&quot;][]\r\n    | ._links.self.href\r\n\r\n\r\n&gt; And I&#39;d then want a similar query\r\n\r\nAn alternative to specifying the top-level key explicitly might be to select the href of interest from the array of all of them:\r\n\r\n     ._embedded\r\n     | [.[][]._links.self.href]\r\n\r\nThis would yield:\r\n\r\n    [\r\n      &quot;https://www.example.org/user/37?_format=hal_json&quot;,\r\n      &quot;https://www.example.org/user/37?_format=hal_json&quot;,\r\n      &quot;https://www.example.org/simplecategory?_format=hal_json&quot;,\r\n      &quot;https://www.example.org/by/speakername?_format=hal_json&quot;\r\n    ]\r\n\r\n",
                "title": "query when object name is a URL"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1545500327,
        "creation_date": 1545464933,
        "last_edit_date": 1545486745,
        "question_id": 53893946,
        "body_markdown": "I&#39;ve written a JQ search that outputs the following, but I cannot work out how to get into the detail and extract specific information from this.\r\n\r\n    {\r\n      &quot;https://www.example.org/rest/relation/node/recording/revision_uid&quot;: [\r\n        {\r\n          &quot;_links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;https://www.example.org/user/37?_format=hal_json&quot;\r\n            },\r\n            &quot;type&quot;: {\r\n              &quot;href&quot;: &quot;https://www.example.org/rest/type/user/user&quot;\r\n            }\r\n          },\r\n          &quot;uuid&quot;: [\r\n            {\r\n              &quot;value&quot;: &quot;d40684cf-2321-42d2-9194&quot;\r\n            }\r\n          ]\r\n        }\r\n      ],\r\n      &quot;https://www.example.org/rest/relation/node/recording/uid&quot;: [\r\n        {\r\n          &quot;_links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;https://www.example.org/user/37?_format=hal_json&quot;\r\n            },\r\n            &quot;type&quot;: {\r\n              &quot;href&quot;: &quot;https://www.example.org/rest/type/user/user&quot;\r\n            }\r\n          },\r\n          &quot;uuid&quot;: [\r\n            {\r\n              &quot;value&quot;: &quot;d40684cf-2321-42d2-9194&quot;\r\n            }\r\n          ],\r\n          &quot;lang&quot;: &quot;en&quot;\r\n        }\r\n      ],\r\n      &quot;https://www.example.org/rest/relation/node/recording/field_category&quot;: [\r\n        {\r\n          &quot;_links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;https://www.example.org/simplecategory?_format=hal_json&quot;\r\n            },\r\n            &quot;type&quot;: {\r\n              &quot;href&quot;: &quot;https://www.example.org/rest/type/taxonomy_term/tags&quot;\r\n            }\r\n          },\r\n          &quot;uuid&quot;: [\r\n            {\r\n              &quot;value&quot;: &quot;3fef93d5-926a-41aa-95cb&quot;\r\n            }\r\n          ]\r\n        }\r\n      ],\r\n      &quot;https://www.example.org/rest/relation/node/recording/field_part1_speaker&quot;: [\r\n        {\r\n          &quot;_links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;https://www.example.org/by/speakername?_format=hal_json&quot;\r\n            },\r\n            &quot;type&quot;: {\r\n              &quot;href&quot;: &quot;https://www.example.org/rest/type/taxonomy_term/author&quot;\r\n            }\r\n          },\r\n          &quot;uuid&quot;: [\r\n            {\r\n              &quot;value&quot;: &quot;fb6c806f-fa6a-4aa0-89ef&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nHow do I write a query that returns &#39;https://www.example.org/simplecategory?_format=hal_json&#39;?\r\n\r\nAnd I&#39;d then want a similar query that returns &#39;https://www.example.org/by/speakername?_format=hal_json&#39;\r\n\r\nSo `jq &#39;._embedded&#39;` gets me the data above.  \r\n\r\nI&#39;ve then tried various combinations to get to the value of  `https://www.example.org/rest/relation/node/recording/field_category`.  \r\n- `jq &#39;._embedded.https://www.example.org/rest/relation/node/recording/field_category` - but of course the URL has special characters in it.\r\n\r\n- `jq .[&quot;https://www.example.org/rest/relation/node/recording/field_category&quot;]`\r\n\r\n- `jq .&quot;https://www.example.org/rest/relation/node/recording/field_category$&quot;`\r\n\r\nI&#39;ve also messed around with some of JQs built in functions, like flatten and to_entries, from_entries.  I&#39;ve also tried regular expressions but my efforts return `Cannot iterate over null (null)`.",
        "link": "https://stackoverflow.com/questions/53893946/query-when-object-name-is-a-url",
        "title": "query when object name is a URL"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6774888,
                    "reputation": 410,
                    "user_id": 10549044,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/eb4ba565bc09a2b1d3915fc99a6d6099?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ma7555",
                    "link": "https://stackoverflow.com/users/10549044/ma7555"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1545493324,
                "post_id": 53896658,
                "comment_id": 94639622,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6774888,
                    "reputation": 410,
                    "user_id": 10549044,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/eb4ba565bc09a2b1d3915fc99a6d6099?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ma7555",
                    "link": "https://stackoverflow.com/users/10549044/ma7555"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1545498186,
                "post_id": 53896658,
                "comment_id": 94640816,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1545499670,
                "post_id": 53896658,
                "comment_id": 94641176,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6774888,
                    "reputation": 410,
                    "user_id": 10549044,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/eb4ba565bc09a2b1d3915fc99a6d6099?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ma7555",
                    "link": "https://stackoverflow.com/users/10549044/ma7555"
                },
                "reply_to_user": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1545500773,
                "post_id": 53896658,
                "comment_id": 94641415,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1545493083,
                "creation_date": 1545493083,
                "answer_id": 53897017,
                "question_id": 53896658,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m positive there are better ways to do this: I really just throw stuff at jq until something sticks to the wall ...\r\n\r\n    # 1. in the shell, construct a JSON object string from the array =&gt; {&quot;bbbb&quot;:1,&quot;cccc&quot;:1}\r\n    printf -v jsonobj &#39;{%s}&#39; &quot;$(printf &#39;&quot;%q&quot;:1\\n&#39; &quot;${array[@]}&quot; | paste -sd,)&quot;\r\n    \r\n    # 2. use that to test for non-membership in the jq select function\r\n    jq --argjson o &quot;$jsonobj&quot; &#39;.foofoo.barbar |= map(select((.bar|in($o)) == false))&#39; json.json\r\n\r\noutputs\r\n\r\n    {\r\n      &quot;foofoo&quot;: {\r\n        &quot;barbar&quot;: [\r\n          {\r\n            &quot;foo&quot;: &quot;0000&quot;,\r\n            &quot;bar&quot;: &quot;aaaa&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nYou don&#39;t actually show your desired output, so I assume this is what you want.\r\n",
                "title": "Modify a JSON array with inputs from a shell array in only a single pass"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1545502017,
                "last_edit_date": 1545502017,
                "creation_date": 1545496687,
                "answer_id": 53897455,
                "question_id": 53896658,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To improve the performance significantly use the following `jq` approach (without any *shell* loops):\r\n\r\n    arr=(&quot;1111&quot; &quot;2222&quot;)\r\n    jq &#39;($p | split(&quot; &quot;) | map(tonumber)) as $exclude \r\n        | .foofoo.barbar \r\n          |= map(select(.bar as $b \r\n                        | any($exclude[]; . == $b) | not))&#39; \\\r\n        --arg p &quot;${arr[*]}&quot; file.json | sponge file.json\r\n\r\nThe output:\r\n\r\n    {\r\n      &quot;foofoo&quot;: {\r\n        &quot;barbar&quot;: [\r\n          {\r\n            &quot;foo&quot;: &quot;aaaa&quot;,\r\n            &quot;bar&quot;: 0\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\n",
                "title": "Modify a JSON array with inputs from a shell array in only a single pass"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1545534873,
                "creation_date": 1545534873,
                "answer_id": 53900945,
                "question_id": 53896658,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Constructing a dictionary object opens the door to an efficient solution.  If your jq has `INDEX/2`, you could use the following invocation:\r\n\r\n    jq --arg p &quot;${arr[*]}&quot; &#39;\r\n      INDEX($p | split(&quot; &quot;)[]; .) as $dict\r\n      | .foofoo.barbar \r\n          |= map(select($dict[.bar|tostring] | not))&#39; \r\n\r\nIf your jq does not have `INDEX/2`, then now would be an excellent time to upgrade; otherwise, you could snarf its def by googling:\r\n`jq &quot;def INDEX&quot;`",
                "title": "Modify a JSON array with inputs from a shell array in only a single pass"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1548123346,
        "creation_date": 1545490376,
        "last_edit_date": 1545913454,
        "question_id": 53896658,
        "body_markdown": "Is it possible to filter an entire array of items in JQ in only one pass? Compare the following code, which runs `jq` over and over:\r\n\r\n    {\r\n          &quot;foofoo&quot;: {\r\n            &quot;barbar&quot;: [\r\n              {\r\n                &quot;foo&quot;: &quot;aaaa&quot;,\r\n                &quot;bar&quot;: 0000\r\n              },\r\n              {\r\n                &quot;foo&quot;: &quot;bbbb&quot;,\r\n                &quot;bar&quot;: 1111\r\n              },\r\n              {\r\n                &quot;foo&quot;: &quot;cccc&quot;,\r\n                &quot;bar&quot;: 2222\r\n              }\r\n              ]\r\n          }\r\n    }\r\n\r\nbash array:\r\n\r\n    array=(&quot;1111&quot; &quot;2222&quot;)\r\n\r\nmy code is working but not very efficient and uses a lot of resources considering the array size in reality:\r\n\r\n\tfor k in &quot;${array[@]}&quot;; do \r\n\t\tjq  --argjson k &quot;$k&quot;  &#39;.foofoo.barbar |= map(select(.bar != $k))&#39; json.json | sponge json.json \r\n\tdone\r\nIt keeps looping through the array, removing the unneeded entries and storing same file again by using sponge.\r\n\r\nany ideas how to achieve a similar behavior with a lighter code?\r\n\r\nDesired output:\r\n\r\n    {\r\n      &quot;foofoo&quot;: {\r\n        &quot;barbar&quot;: [\r\n          {\r\n            &quot;foo&quot;: &quot;aaaa&quot;,\r\n            &quot;bar&quot;: 0\r\n          }\r\n        ]\r\n      }\r\n    }",
        "link": "https://stackoverflow.com/questions/53896658/modify-a-json-array-with-inputs-from-a-shell-array-in-only-a-single-pass",
        "title": "Modify a JSON array with inputs from a shell array in only a single pass"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1545519585,
                "creation_date": 1545519585,
                "answer_id": 53899925,
                "question_id": 53899837,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `paths` makes the task simple.\r\n\r\n    paths as $p\r\n    | getpath($p) \r\n    | scalars\r\n    | $p + [.]\r\n    | join(&quot;.&quot;)\r\n\r\nproduces the stream:\r\n\r\n    &quot;key1.value1&quot;\r\n    &quot;key2.value2&quot;\r\n    &quot;key3.subKey1.value3&quot;\r\n    &quot;key3.subKey2.value4&quot;\r\n\r\nSo you&#39;ll want to enclose the filter above in square brackets to produce an array.\r\n",
                "title": "Convert JSON object to an array of strings with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1545520276,
                "creation_date": 1545520276,
                "answer_id": 53899978,
                "question_id": 53899837,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Short alternative:\r\n\r\n    jq &#39;[paths(scalars) as $p | $p + [getpath($p)] | join(&quot;.&quot;)]&#39; f.json\r\n\r\nThe expected output:\r\n\r\n    [\r\n      &quot;key1.value1&quot;,\r\n      &quot;key2.value2&quot;,\r\n      &quot;key3.subKey1.value3&quot;,\r\n      &quot;key3.subKey2.value4&quot;\r\n    ]\r\n\r\n",
                "title": "Convert JSON object to an array of strings with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1545520276,
        "creation_date": 1545518603,
        "question_id": 53899837,
        "body_markdown": "I have a JSON object, which contains only strings and other objects:\r\n\r\n    {\r\n      &quot;key1&quot;: &quot;value1&quot;,\r\n      &quot;key2&quot;: &quot;value2&quot;,\r\n      &quot;key3&quot;: {\r\n        &quot;subKey1&quot;:&quot;value3&quot;,\r\n        &quot;subKey2&quot;:&quot;value4&quot;\r\n      }\r\n    }\r\n\r\nI want to convert it to an array of strings by flattening the structure\r\n\r\n    [\r\n      &quot;key1.value1&quot;,\r\n      &quot;key2.value2&quot;,\r\n      &quot;key3.subKey1.value3&quot;,\r\n      &quot;key3.subKey2.value4&quot;,\r\n    ]\r\n\r\nI&#39;m rather new to jq syntax and so far I managed to achieve only this with help of\r\n\r\n    to_entries | map([.key, .value | if type == &quot;object&quot; then type else . end]|join(&quot;.&quot;))\r\n\r\nthen I obtain\r\n\r\n    [\r\n      &quot;key1.value1&quot;,\r\n      &quot;key2.value2&quot;,\r\n      &quot;key3.object&quot;\r\n    ]",
        "link": "https://stackoverflow.com/questions/53899837/convert-json-object-to-an-array-of-strings-with-jq",
        "title": "Convert JSON object to an array of strings with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "formatting",
            "jq",
            "numeric"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1545667623,
                "post_id": 53915068,
                "comment_id": 94674126,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1545670778,
                "post_id": 53915068,
                "comment_id": 94674866,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1545671689,
                "post_id": 53915068,
                "comment_id": 94675087,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7314480,
                    "reputation": 185,
                    "user_id": 5572614,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9f98267d0cdf497c1a39742b9cd376ad?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Victor Marrerp",
                    "link": "https://stackoverflow.com/users/5572614/victor-marrerp"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1545766079,
                "post_id": 53915068,
                "comment_id": 94691678,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1545666347,
                "creation_date": 1545666347,
                "answer_id": 53915378,
                "question_id": 53915068,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use this generic function:\r\n\r\n    def to_decimal:\r\n      def rpad(n): if (n &gt; length) then . + ((n - length) * &quot;0&quot;) else . end;\r\n      def lpad(n): if (n &gt; length) then ((n - length) * &quot;0&quot;) + . else . end;\r\n      tostring\r\n      | . as $s\r\n      | capture( &quot;(?&lt;sgn&gt;[+-]?)(?&lt;left&gt;[0-9]*)(?&lt;p&gt;\\\\.?)(?&lt;right&gt;[0-9]*)(?&lt;e&gt;[Ee]?)(?&lt;exp&gt;[+-]?[0-9]+)&quot; )\r\n      | if .e == &quot;&quot; then $s\r\n        else (.left|length) as $len\r\n        | (.exp | tonumber) as $exp\r\n        | if $exp &lt; 0 then .sgn + &quot;0.&quot; + (.left | lpad(1 - $exp - $len)) + .right\r\n          else .sgn + (.left | rpad($exp - $len)) + &quot;.&quot; + .right\r\n          end\r\n        end ;\r\n\r\nExample:\r\n\r\n    &quot;7.2e-07&quot;|to_decimal\r\n\r\nyields:\r\n\r\n    &quot;0.00000072&quot;",
                "title": "How do I use jq to output a decimal low in linux"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1548121959,
        "creation_date": 1545664274,
        "last_edit_date": 1545670080,
        "question_id": 53915068,
        "body_markdown": "Given the following jq command and Json:  (Only jq command)\r\n\r\n    echo &#39;{&quot;foo&quot;: {&quot;bar&quot;: 0.00000072}}&#39; | jq &#39;map_values( . + {&quot;bar&quot;: .bar|tostring} )&#39;\r\n    {\r\n      &quot;foo&quot;: {\r\n        &quot;bar&quot;: &quot;7.2e-07&quot;\r\n      }\r\n    }\r\n\r\n\r\nI&#39;m trying to format the output as:\r\n\r\n    {\r\n      &quot;foo&quot;: {\r\n        &quot;bar&quot;: &quot;0.00000072&quot;\r\n      }\r\n    }\r\n\r\nOR\r\n\r\n    {\r\n      &quot;foo&quot;: {\r\n        &quot;bar&quot;: 0.00000072\r\n      }\r\n    }\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53915068/how-do-i-use-jq-to-output-a-decimal-low-in-linux",
        "title": "How do I use jq to output a decimal low in linux"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "output",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1545743614,
                "creation_date": 1545743614,
                "answer_id": 53922705,
                "question_id": 53922588,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This seems to be a server side issue. \r\nYou might try to work it around by forcing HTTP 1.0 connection (to avoid chunked transfer which might cause this problem) with the --http1.0 option.",
                "title": "CURL json output cuts off"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1545745075,
                "creation_date": 1545745075,
                "answer_id": 53922881,
                "question_id": 53922588,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## CURLE_PARTIAL_FILE (18)\r\n\r\nA file transfer was shorter or larger than expected. This happens when the server first reports an expected transfer size, and then delivers data that doesn&#39;t match the previously given size.\r\n\r\nSource: https://curl.haxx.se/libcurl/c/libcurl-errors.html",
                "title": "CURL json output cuts off"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1545751415,
        "creation_date": 1545742640,
        "last_edit_date": 1545751415,
        "question_id": 53922588,
        "body_markdown": "I&#39;m working on centos 7 and has this json request : \r\n\r\n    curl  --output &#39;json.data.json&#39; -vvv -x &#39;&#39;  -X POST -H &quot;Content-Type: application/json&quot; -H &quot;Connection: keep-alive&quot; -d &#39;{&quot;jsonrpc&quot;:&quot;2.0&quot;,&quot;method&quot;:&quot;item.get&quot;,&quot;params&quot;:{&quot;output&quot;: [&quot;name&quot;,&quot;lastvalue&quot;,&quot;lastclock&quot;,&quot;hostid&quot;],&quot;groupids&quot;: [&quot;5&quot;],&quot;filter&quot;:{&quot;name&quot;:[&quot;LDT Security Flag&quot;]},&quot;sortfield&quot;: &quot;name&quot; },&quot;auth&quot;:&quot;c1cxxxxxxxxx&quot;,&quot;id&quot;:1}&#39; $CURLADDR \r\n\r\nNow, \r\nIn middle of results I see : \r\n\r\n    734247&quot;,&quot;lastvalue&quot;:&quot;0&quot;},{&quot;itemid&quot;:&quot;192890&quot;,&quot;name&quot;:&quot;LDT Fl* transfer closed with outstanding read data remaining\r\n    100 86797    0 86569  100   228  75094    197  0:00:01  0:00:01 --:--:-- 75146\r\n    * Closing connection 0\r\n    curl: (18) transfer closed with outstanding read data remaining\r\n\r\nAnd after that some more json results.\r\nBut I noticed that not matter how many times I run it and redirect output to .json file , file always at the same size : **88K like there some kind of limit** on info download size ?  what can i do ?\r\n\r\n**UPDATE:**\r\n\r\nSo i added it and now the error : curl: (18) transfer closed with outstanding Read data remaining is gone. but is still cuts at the middle with :  `* Closing Connection 0` and file is 88K – Batchen Regev 11 mins ago \r\n\r\nalso connection data :\r\n\r\n    &gt; POST /api_jsonrpc.php HTTP/1.0\r\n    &gt; User-Agent: curl/7.29.0\r\n    &gt; Host: XXXXXX:1080\r\n    &gt; Content-Type: application/json;charset=utf-8\r\n    &gt; Accept: application/json, text/plain, */*\r\n    &gt; Content-Length: 224\r\n    &gt;\r\n    } [data not shown]\r\n    * upload completely sent off: 224 out of 224 bytes\r\n    100   224    0     0  100   224      0    223  0:00:01  0:00:01 --:--:--   223&lt; HTTP/1.1 200 OK\r\n    &lt; Server: nginx\r\n    &lt; Date: Tue, 25 Dec 2018 15:21:07 GMT\r\n    &lt; Content-Type: application/json\r\n    &lt; Connection: close\r\n    &lt; Access-Control-Allow-Origin: *\r\n    &lt; Access-Control-Allow-Headers: Content-Type\r\n    &lt; Access-Control-Allow-Methods: POST\r\n    &lt; Access-Control-Max-Age: 1000\r\n    &lt;\r\n    { [data not shown]\r\n    100 86840    0 86616  100   224  77583    200  0:00:01  0:00:01 --:--:-- 77612\r\n    * Closing connection 0\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53922588/curl-json-output-cuts-off",
        "title": "CURL json output cuts off"
    },
    {
        "tags": [
            "json",
            "sorting",
            "parsing",
            "jq",
            "jsonlines"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1545908900,
                "last_edit_date": 1545908900,
                "creation_date": 1545859839,
                "answer_id": 53937382,
                "question_id": 53936117,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a reasonably efficient solution, presented in a way that hopefully makes it easy to understand and adapt:\r\n\r\n    def sorted:\r\n      if length &lt;= 1 then true\r\n      else map([.memberId, .memberCity, .lastTransaction])\r\n      | .[0] &lt;= .[1]\r\n      end;\r\n\r\n    def pairs(stream):\r\n      foreach stream as $i ([]; \r\n        .[-1:] + [$i]; \r\n        select(length==2));\r\n    \r\n   \r\n    all(pairs(inputs); sorted)\r\n\r\nInvocation:\r\n\r\n    jq -n -f sorted.jq input.json\r\n\r\n\r\n---\r\nIf the stars are aligned properly and you want a one-liner:\r\n\r\n    jq &#39;all(foreach [inputs[]] as $i ([[.[]]]; [.[-1],$i]); .[0]&lt;=.[1])&#39; input.json\r\n\r\nSeason to taste.\r\n\r\n\r\n",
                "title": "Validate JSON fields sort order"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1545902817,
                "creation_date": 1545902817,
                "answer_id": 53942672,
                "question_id": 53936117,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Any solution that requires using the -s command-line option has the drawback of requiring more memory than is needed. Similarly using `sort` is inadvisable in general, but if one wants a concise and simple solution, one could go with:\r\n\r\n    jq -s &#39;map([.memberId, .memberCity, .lastTransaction]) | . == sort&#39; \r\n\r\nor even in the specific case given:\r\n\r\n    jq -s &#39;map(.[]) | . == sort&#39; ",
                "title": "Validate JSON fields sort order"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1546001158,
        "creation_date": 1545851248,
        "last_edit_date": 1546001158,
        "question_id": 53936117,
        "body_markdown": "I have the following JSON records stored in a container\r\n\r\n    {&quot;memberId&quot;:123,&quot;memberCity&quot;:&quot;Chicago&quot;,&quot;lastTransaction&quot;:1504155600000}\r\n    {&quot;memberId&quot;:123,&quot;memberCity&quot;:&quot;Chigago&quot;,&quot;lastTransaction&quot;:150175600000}\r\n    {&quot;memberId&quot;:123,&quot;memberCity&quot;:&quot;New York&quot;,&quot;lastTransaction&quot;:150195600000}\r\n\r\nI am looking to validate that the sort order in which these records are stored are sorted by memberId ASC, memberCity ASC, lastTransaction ASC\r\n\r\nIs there a way via jq that I can assert (true/false) the sort order, taking multiple fields into account?",
        "link": "https://stackoverflow.com/questions/53936117/validate-json-fields-sort-order",
        "title": "Validate JSON fields sort order"
    },
    {
        "tags": [
            "module",
            "include",
            "require",
            "jq",
            "decodeuricomponent"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1545860088,
                "creation_date": 1545860088,
                "answer_id": 53937412,
                "question_id": 53937411,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq reads by default from a hidden folder in your root directory files marked with .jq file extension: ~/.jq ([&quot;~/.jq&quot;,  &quot;$ORIGIN/../lib/jq&quot;,  &quot;$ORIGIN/../lib&quot;])\r\n\r\nTo reference the module you can use the import function, then follow your normal jq command after a semicolon. The &quot;as lib&quot; below allows you to change the name of the namespace as well:\r\n\r\n     jq &#39;import &quot;urldecode&quot; as lib; .http.referrer | lib::url_decode&#39; file.json\r\n\r\nYou can override the location where the .jq file are stored w/ the -L option.",
                "title": "What is the format in jq for calling a custom module?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": -3,
                "last_activity_date": 1545866697,
                "creation_date": 1545866697,
                "answer_id": 53938185,
                "question_id": 53937411,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not sure how to do custom modules in JQ, but If you are using bash I would suggest piping to PERL for this. So far this is the easiest way I have found to quickly url-encode/decode HTML entities and I typically use this in conjunction with JQ\r\n\r\n`echo &#39;http://domain.tld/?fields=&amp;#123;fieldname_of_type_Tab&amp;#125&#39; |\r\n    perl -MHTML::Entities -pe &#39;decode_entities($_)&#39; `\r\n\r\n\r\nhttps://stackoverflow.com/questions/48998515/decode-url-unix-bash-command-line-without-sed\r\n",
                "title": "What is the format in jq for calling a custom module?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1587784389,
                "last_edit_date": 1587784389,
                "creation_date": 1545872254,
                "answer_id": 53938686,
                "question_id": 53937411,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In theory, with your setup, you should be able to invoke jq along the lines of\r\n\r\n    jq &#39;import &quot;urldecode&quot; as url_decode;\r\n      .http.referrer | url_decode::url_decode&#39; file.json\r\n\r\nor more simply:\r\n\r\n\r\n    jq &#39;include &quot;urldecode&quot;;\r\n      .http.referrer | url_decode&#39; file.json\r\n\r\nHowever, there are some circumstances in which theory does not quite apply.  In such cases, the following workarounds may be used with jq 1.5 and 1.6: \r\n\r\n(1) specify `-L $HOME` as a command-line parameter, and give the relative path name in the module specification.  Thus, in your case, the command line would look like:\r\n\r\n    jq -L $HOME &#39;import &quot;.jq/urldecode&quot; as url_decode; ...\r\n\r\nor: \r\n\r\n    jq -L $HOME &#39;include &quot;.jq/urldecode&quot;; ...\r\n   \r\n\r\n(2) Use the {search: _} feature, e.g.\r\n\r\n```\r\njq &#39;include &quot;urldecode&quot; {search: &quot;~/.jq&quot;} ; ...&#39; ...\r\n```\r\n\r\n```\r\njq &#39;import &quot;urldecode&quot; as url_decode {search: &quot;~/.jq&quot;} ; ...&#39; ...\r\n```\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "What is the format in jq for calling a custom module?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1587784389,
        "creation_date": 1545860088,
        "last_edit_date": 1545916908,
        "question_id": 53937411,
        "body_markdown": "I need to url decode a string in a json structure using jq. I have a custom module defined under ~/.jq/urldecode.jq but when calling it:\r\n\r\n    jq &#39;.http.referrer | url_decode::url_decode&#39; file.json\r\n\r\nI get the error message:\r\n\r\n    jq: 1 compile error\r\n\r\nThe module source is:\r\n\r\n    def url_decode:\r\n      # The helper function converts the input string written in the given\r\n      # &quot;base&quot; to an integer\r\n      def to_i(base):\r\n        explode\r\n        | reverse\r\n        | map(if 65 &lt;= . and . &lt;= 90 then . + 32  else . end)   # downcase\r\n        | map(if . &gt; 96  then . - 87 else . - 48 end)  # &quot;a&quot; ~ 97 =&gt; 10 ~ 87\r\n        | reduce .[] as $c\r\n            # base: [power, ans]\r\n            ([1,0]; (.[0] * base) as $b | [$b, .[1] + (.[0] * $c)]) | .[1];\r\n     \r\n      .  as $in\r\n      | length as $length\r\n      | [0, &quot;&quot;]  # i, answer\r\n      | until ( .[0] &gt;= $length;\r\n          .[0] as $i\r\n          |  if $in[$i:$i+1] == &quot;%&quot;\r\n             then [ $i + 3, .[1] + ([$in[$i+1:$i+3] | to_i(16)] | implode) ]\r\n             else [ $i + 1, .[1] + $in[$i:$i+1] ]\r\n             end)\r\n      | .[1];  # answer\r\n\r\n\r\n\r\nWhat is the proper syntax?\r\n",
        "link": "https://stackoverflow.com/questions/53937411/what-is-the-format-in-jq-for-calling-a-custom-module",
        "title": "What is the format in jq for calling a custom module?"
    },
    {
        "tags": [
            "bash",
            "stream",
            "sum",
            "jq",
            "reduce"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1545861905,
                "post_id": 53937609,
                "comment_id": 94715337,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1545862095,
                "post_id": 53937609,
                "comment_id": 94715385,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1545862181,
                "post_id": 53937609,
                "comment_id": 94715416,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1545861914,
                "creation_date": 1545861914,
                "answer_id": 53937660,
                "question_id": 53937609,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem is the way you&#39;re using `inputs`. According to the documentation, `inputs` &quot;outputs all remaining inputs, one by one&quot;. Fine, but note the &quot;remaining&quot; part. By the time your code is run, the *first* input has already been read into `.`, so `inputs` returns all of the records *except* that one. The simple fix is to use the `-n` option to jq, which runs the filter once, with the `null` value in `.`. This leaves *all* of the records available for reading by `inputs`, which makes your code work correctly.\r\n\r\n",
                "title": "JQ: Why does summing numbers from field in JSON stream not include first number in sum?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1545911971,
        "creation_date": 1545861503,
        "last_edit_date": 1545911971,
        "question_id": 53937609,
        "body_markdown": "I have a list of credit card transactions. I would like to sum the Amount from the stream of JSON transactions. Each object contains data for 1 transaction. I use JQ to process JSON. \r\n\r\n\r\n\r\nI have referenced this question: https://stackoverflow.com/questions/28484534/how-do-i-sum-the-values-in-an-array-of-maps-in-jq\r\n\r\nHowever after implementing the solution described in the question.\r\n\r\n&lt;!-- language: bash --&gt;\r\n\r\n    jq -n &#39;\r\n    reduce (inputs | to_entries[]) as {$key,$value} ({}; .[$key] += $value)\r\n    &#39; input.json\r\n\r\n I noticed that the first number is not included in the addition. Below find sample file, output of command, and expected result\r\n\r\nSample File CC Transactions &quot;jqAdditionSample.json&quot;\r\n-------------------------\r\n\r\n&lt;!-- language: json --&gt;\r\n\r\n    {\r\n      &quot;Originating Account Number&quot;: &quot;####-####-####-0000&quot;,\r\n      &quot;Cardholder Name&quot;: &quot;NAME ON CARD&quot;,\r\n      &quot;Merchant Name&quot;: &quot;VENDOR NAME&quot;,\r\n      &quot;Amount&quot;: 342.75,\r\n      &quot;MCC Description&quot;: &quot;Computer Software&quot;\r\n    }\r\n    {\r\n      &quot;Originating Account Number&quot;: &quot;####-####-####-0000&quot;,\r\n      &quot;Cardholder Name&quot;: &quot;NAME ON CARD&quot;,\r\n      &quot;Merchant Name&quot;: &quot;VENDOR NAME&quot;,\r\n      &quot;Amount&quot;: 492.71,\r\n      &quot;MCC Description&quot;: &quot;Computer Software&quot;\r\n    }\r\n    {\r\n      &quot;Originating Account Number&quot;: &quot;####-####-####-0000&quot;,\r\n      &quot;Cardholder Name&quot;: &quot;NAME ON CARD&quot;,\r\n      &quot;Merchant Name&quot;: &quot;VENDOR NAME&quot;,\r\n      &quot;Amount&quot;: 573,\r\n      &quot;MCC Description&quot;: &quot;Computer Software&quot;\r\n    }\r\n\r\nExpected Actual Total\r\n------------\r\nAdd the Amounts manually to find total 342.75+492.71+573=1408.46\r\n\r\nRun the command\r\n-------------\r\n\r\n&lt;!-- language: bash --&gt;\r\n\r\n    cat ~/Desktop/jqAdditionSample.json | \\\r\n      jq &#39;reduce (inputs | to_entries[]) as {$key,$value} ({}; .[$key] += $value)&#39;\r\n\r\nResult:\r\n\r\n&lt;!-- language: json --&gt;\r\n\r\n    {\r\n      &quot;Originating Account Number&quot;: &quot;####-####-####-0000####-####-####-0000&quot;,\r\n      &quot;Cardholder Name&quot;: &quot;NAME ON CARDNAME ON CARD&quot;,\r\n      &quot;Merchant Name&quot;: &quot;VENDOR NAMEVENDOR NAME&quot;,\r\n      &quot;Amount&quot;: 1065.71,\r\n      &quot;MCC Description&quot;: &quot;Computer SoftwareComputer Software&quot;\r\n    }\r\n\r\nNote Discrepancy\r\n-----------------\r\nThe output 1065.71 adds sums all numbers except the first number. We can verify by subtracting 342.75 from expected value 1408.46. I want it to sum all numbers\r\n\r\nIn fact, no data from the first object is included in the sum. \r\n\r\nWhere I need help\r\n-----------------\r\nIs there a way to make JQ sum all numbers from a field in a stream, am I doing something wrong? \r\n\r\nIs there an easier method to sum all numbers for a field in JSON stream where I am taking the hard route? \r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53937609/jq-why-does-summing-numbers-from-field-in-json-stream-not-include-first-number",
        "title": "JQ: Why does summing numbers from field in JSON stream not include first number in sum?"
    },
    {
        "tags": [
            "json",
            "regex",
            "shell",
            "sed",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1545924768,
                "creation_date": 1545924768,
                "answer_id": 53947389,
                "question_id": 53947130,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Usually it is not recommended to use unix command line tools for parsing HTML. But if you know your marker string `foo.bar.Processor.message`, then you may use this `sed + jq` solution:\r\n\r\n    sed -n &#39;s/foo\\.bar\\.Processor\\.message(\\([^)]*\\).*/\\1/p&#39; file.html |\r\n    jq -r &#39;.head.url | split(&quot;;&quot;)[1] | split(&quot;=&quot;)[1]&#39;\r\n\r\n&lt;p/&gt;\r\n\r\n    347EDAFA2B136D7825745B0A490DE32\r\n\r\nIn the absence of `jq`, you may use this `sed + gnu grep` solution:\r\n\r\n    sed -n &#39;s/foo\\.bar\\.Processor\\.message(\\([^)]*\\).*/\\1/p&#39; file.html |\r\n    grep -oP &#39;;barid=\\K\\w+&#39;",
                "title": "Get JSON string from within javascript on a html page using shell script"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1545945838,
                "last_edit_date": 1545945838,
                "creation_date": 1545937376,
                "answer_id": 53949682,
                "question_id": 53947130,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One option might be to use [tag:pup], at least for parsing the HTML:\r\n\r\n    &lt; input.html pup &#39;script:not(:empty) text{}&#39; |\r\n      grep foo.bar.Processor.message | grep -o &#39;{.*}&#39; |\r\n      jq -r &#39;.head.url\r\n             | split(&quot;;&quot;)[]\r\n             | select(test(&quot;barid=&quot;))\r\n             | sub(&quot;barid=&quot;;&quot;&quot;)&#39;\r\n\r\nWith your HTML (adjusted to ensure the JSON in the HTML is valid), this produces:\r\n\r\n    347EDAFA2B136D7825745B0A490DE32\r\n\r\nOf course there are many caveats.  YMMV.",
                "title": "Get JSON string from within javascript on a html page using shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1548348234,
        "creation_date": 1545923331,
        "last_edit_date": 1545930322,
        "question_id": 53947130,
        "body_markdown": "There&#39;s valid json in a javascript on a html page that I want to parse with a shell script.\r\nFirst of all I would like to get the entire json string from `{` to `}` and then I can parse it with `jq` for example.\r\n\r\nThis is basically how my html looks:\r\n\r\n    &lt;!DOCTYPE html&gt;\r\n    &lt;html&gt;\r\n      &lt;head&gt;\r\n        &lt;title&gt;foobar&lt;/title&gt;\r\n    \t    \r\n      &lt;/head&gt;\r\n      \r\n      &lt;body&gt;\r\n      \r\n      &lt;script type=&quot;text/javascript&quot; src=&quot;resources/script.js&quot; charset=&quot;UTF-8&quot;&gt;&lt;/script&gt;\r\n      &lt;script type=&quot;text/javascript&quot; src=&quot;resources/resources.js&quot; charset=&quot;UTF-8&quot;&gt;&lt;/script&gt;\r\n    \t\r\n    \t&lt;script type=&quot;text/javascript&quot;&gt;\r\n    \tif( foo.foobar.getInstance().isbar() ) \r\n    \t{\r\n    \t\tfoo.bar.Processor.message( {&quot;head&quot;:{&quot;url&quot;:&quot;anotherfoo;barid=347EDAFA2B136D7825745B0A490DE32&quot;},...});\r\n    \t}\r\n    \telse\r\n    \t{....}\r\n    \t&lt;/script&gt;\r\n      &lt;/body&gt;\r\n    &lt;/html&gt;\r\n\r\n\r\nIn the end  I want to get the ID that&#39;s at &quot;barid=...&quot;. \r\nI was playing around trying to use `grep foo.bar.Processor.message` and then `sed` or `cut` but I think there&#39;s better ways to do it.\r\nIf you could point me in the right direction that&#39;d be great! \r\nThank you!\r\n",
        "link": "https://stackoverflow.com/questions/53947130/get-json-string-from-within-javascript-on-a-html-page-using-shell-script",
        "title": "Get JSON string from within javascript on a html page using shell script"
    },
    {
        "tags": [
            "json",
            "linux",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1664623183,
                "last_edit_date": 1664623183,
                "creation_date": 1546002437,
                "answer_id": 53959091,
                "question_id": 53959049,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Do you have to do it with `jq` only? You could further process the output with `grep` and `cut`:\r\n\r\n    jq &#39;.head.url | split(&quot;;&quot;)[]&#39; | grep &#39;^myid=&#39; | cut -d= -f2\r\n\r\n******\r\n\r\nBut alas, it is easily possible by first building an object from the key value pairs and then look up the value for the key in question:\r\n\r\n```\r\n.head.url\r\n  | split(&quot;;&quot;)\r\n  | map(split(&quot;=&quot;) | { key: .[0], value: .[1] })\r\n  | from_entries\r\n  | .myid\r\n```\r\n\r\nequivalent to:\r\n\r\n```\r\n.head.url\r\n  | split(&quot;;&quot;)\r\n  | map(split(&quot;=&quot;) | { key: .[0], value: .[1] })\r\n  | from_entries[&quot;myid&quot;]\r\n```\r\n\r\nOr without building an object, simply by selecting the first array item with matching key, then outputting its value:\r\n\r\n```\r\n.head.url | split(&quot;;&quot;)[] | split(&quot;=&quot;) | select(first == &quot;myid&quot;)[1]\r\n```\r\n\r\nNB. `x | split(y)` can be expressed as `x/y`, e.g. `.head.url/&quot;@&quot;`.",
                "title": "Use jq to select specific item from array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1546011026,
                "last_edit_date": 1546011026,
                "creation_date": 1546010198,
                "answer_id": 53960612,
                "question_id": 53959049,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `jq`&#39;s `match()` with positive lookbehind to output what&#39;s after `myid=`:\r\n\r\n    $ jq -r &#39;.head.url | split(&quot;;&quot;)[] | match(&quot;(?&lt;=myid=).*;&quot;g&quot;).string&#39; file\r\n    E50DAA932C22739F92BB250C14365440\r\n\r\nor drop the `split()` and `match()` after `myid=` until the end or `;`:\r\n\r\n    $ jq -r &#39;.head.url | match(&quot;(?&lt;=myid=)[^;]*&quot;;&quot;g&quot;).string&#39; file\r\n    E50DAA932C22739F92BB250C14365440\r\n\r\n",
                "title": "Use jq to select specific item from array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1664623183,
        "creation_date": 1546002217,
        "last_edit_date": 1546010251,
        "question_id": 53959049,
        "body_markdown": "I have this json string :\r\n\r\n    {\r\n    \t&quot;head&quot;: {\r\n    \t\t&quot;url&quot;: &quot;foobar;myid=E50DAA932C22739F92BB250C14365440&quot;\r\n    \t}\r\n    }\r\n\r\nWith jq on the shell I get the content of `url` as an array:\r\n\r\n    jq -r &#39;.head.url | split(&quot;;&quot;)[] &#39;\r\n\r\nThis returns:\r\n\r\n    foobar\r\n    myid=E50DAA932C22739F92BB250C14365440\r\n\r\nMy goal is to get the id (E50DA...) after `=` only. I could simply use `[1]` to get the second element and then use a regex to get the part after the `=`.\r\nBut the order of elements is not safe and I&#39;m sure there&#39;s a better way with jq already that I dont know of. Maybe create a map of the elements and use `myid` as a key to get the value (E50...)?\r\n\r\nThank you for your input!\r\n",
        "link": "https://stackoverflow.com/questions/53959049/use-jq-to-select-specific-item-from-array",
        "title": "Use jq to select specific item from array"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1546024758,
                "creation_date": 1546024758,
                "answer_id": 53963332,
                "question_id": 53963083,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your data, the filter:\r\n\r\n    .amazon\r\n    | .activeitem as $id\r\n    | .items[]\r\n    | select(.id == $id)\r\n    | .name\r\n\r\nproduces:\r\n\r\n    &quot;adidas shoes&quot;\r\n\r\n(Use the -r command-line option if you want the raw string.)\r\n",
                "title": "How to filter an array of objects based on value of a element in the Json in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1546024758,
        "creation_date": 1546023119,
        "question_id": 53963083,
        "body_markdown": "I am trying to get a value from the Json using JQ.\r\n\r\nI have to get a ID from the inputJson , (activeItem) and use that ID to get the name of the element from list of items below.\r\n\r\nCan this be done in single query ?\r\n\r\n\r\n\r\n\r\n    {\r\n    &quot;amazon&quot;: {\r\n    &quot;activeitem&quot; : 2, \r\n    &quot;items&quot;: [\r\n      {\r\n        &quot;id&quot; : 1,\r\n        &quot;name&quot;: &quot;harry potter&quot;,\r\n        &quot;state&quot;: &quot;sold&quot;\r\n      },\r\n      {\r\n        &quot;id&quot; : 2,\r\n        &quot;name&quot;: &quot;adidas shoes&quot;,\r\n        &quot;state&quot;: &quot;in inventory&quot;\r\n      },\r\n      {\r\n        &quot;id&quot; : 3,\r\n        &quot;name&quot;: &quot;watch&quot;,\r\n        &quot;state&quot;: &quot;returned&quot;\r\n      }\r\n    ]\r\n    }\r\n    }\r\n\r\nNow i am getting the value first and the filtering, instead i want to do in single query.\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53963083/how-to-filter-an-array-of-objects-based-on-value-of-a-element-in-the-json-in-jq",
        "title": "How to filter an array of objects based on value of a element in the Json in JQ"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1546025964,
                "last_edit_date": 1546025964,
                "creation_date": 1546025489,
                "answer_id": 53963457,
                "question_id": 53963324,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your input, the invocation:\r\n\r\n    jq -r --arg name abc.com &#39;.[][][] | select(.name == $name).value&#39;\r\n\r\nproduces:\r\n\r\n    101.0.0.0\r\n\r\n----\r\n\r\nYou might also like to consider alternatives such as:\r\n\r\n\r\n    jq -r --arg name abc.com &#39;.. | objects | select(.ips) | .ips[] | select(.name == $name).value&#39;\r\n\r\nor, throwing caution to the wind:\r\n\r\n    jq -r --arg name abc.com &#39;.. | objects | select(.name == $name).value&#39;\r\n\r\n",
                "title": "How to extract the specific field value from the json using jq by passing the input key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1546025964,
        "creation_date": 1546024716,
        "last_edit_date": 1546025770,
        "question_id": 53963324,
        "body_markdown": "I have the below JSON and would like to get the ip value if the name value matches with the passed input value. \r\n\r\ni.e pass the input as abc.com and return the value as 101.0.0.0. How can I achieve this using jq?\r\n\r\n    [  \r\n      {  \r\n         &quot;ips&quot;:[  \r\n            {  \r\n               &quot;name&quot;:&quot;google.com&quot;,\r\n               &quot;value&quot;:&quot;172.217.164.110&quot;\r\n            }\r\n         ]\r\n       },\r\n       {\r\n         &quot;ips&quot;:[  \r\n            {  \r\n               &quot;name&quot;:&quot;abc.com&quot;,\r\n               &quot;value&quot;:&quot;101.0.0.0&quot;\r\n            }\r\n          ]\r\n        }\r\n    ]\r\n\r\n\r\nI want to retrieve the value of the field only if the value passed from outside is matched with the other field in the same array. \r\n\r\ni.e \r\nWhen I pass key as abc.com which should return the value 101.0.0.0\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53963324/how-to-extract-the-specific-field-value-from-the-json-using-jq-by-passing-the-in",
        "title": "How to extract the specific field value from the json using jq by passing the input key"
    },
    {
        "tags": [
            "bash",
            "jq",
            "git-bash"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1546169442,
                "post_id": 53967693,
                "comment_id": 94791973,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2708071,
                    "reputation": 5082,
                    "user_id": 2337243,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://www.gravatar.com/avatar/a8e587c57417b7bb83e45f5b8ab891f5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Souad",
                    "link": "https://stackoverflow.com/users/2337243/souad"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569577439,
                "post_id": 53967693,
                "comment_id": 102650843,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 95,
                "is_accepted": true,
                "score": 94,
                "last_activity_date": 1546161295,
                "last_edit_date": 1546161295,
                "creation_date": 1546071756,
                "answer_id": 53967916,
                "question_id": 53967693,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `jq-win64.exe` from [`github.com/stedolan/jq/releases`][1], I get\r\n\r\n    vonc@voncav MINGW64 /d/prgs/dl\r\n    $ ./jq-win64.exe --version\r\n    jq-1.6\r\n    \r\n    vonc@voncav MINGW64 /d/prgs/dl\r\n    $ echo &#39;{&quot;foo&quot;: 0}&#39; | ./jq-win64.exe .\r\n    {\r\n      &quot;foo&quot;: 0\r\n    }\r\n\r\nSo it does work, but it then depends on the json document you are parsing with it.  \r\nIf that json document is not well-formed, that would generate the error you see.\r\n\r\nIn your bash session, you can define (or add to your `~/.bashrc`) an alias:\r\n\r\n    alias jq=/path/to/jq-win64.exe\r\n\r\nThat way, you don&#39;t need to use `./jq`, but directly `jq`.\r\n\r\n    $ echo &#39;{&quot;foo&quot;: 0}&#39; | jq\r\n\r\nIn my case:\r\n\r\n    vonc@voncav:/$ alias jq=/mnt/d/dwnl/jq-win64.exe\r\n    vonc@voncav:/$ echo &#39;{&quot;foo&quot;: 0}&#39; | jq\r\n    {\r\n      &quot;foo&quot;: 0\r\n    }\r\n\r\n  [1]: https://github.com/stedolan/jq/releases\r\n\r\n\r\n",
                "title": "How to run jq from gitbash in windows?"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1680780092,
                "last_edit_date": 1680780092,
                "creation_date": 1565896026,
                "answer_id": 57514888,
                "question_id": 53967693,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I just downloaded the binary to `%HOMEPATH%/bin/jq-win64` and it worked right away via `jq`\r\n\r\n```\r\n$ mkdir -p $HOMEPATH/bin\r\n$ curl -L -o $HOMEPATH/bin/jq.exe https://github.com/stedolan/jq/releases/latest/download/jq-win64.exe\r\n```\r\n\r\ntest\r\n```\r\n$ jq --version\r\njq-1.6\r\n```\r\n\r\n",
                "title": "How to run jq from gitbash in windows?"
            },
            {
                "up_vote_count": 76,
                "is_accepted": false,
                "score": 74,
                "last_activity_date": 1590078467,
                "creation_date": 1590078467,
                "answer_id": 61939199,
                "question_id": 53967693,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I hate answers that say you need another to use another tool to download, but using https://chocolatey.org/ made this incredibly simple for me.\r\n\r\nFrom an elevated command-prompt, run:\r\n```\r\nchoco install jq\r\n```\r\n\r\n```jq``` magically works from bash going forward.\r\n\r\n",
                "title": "How to run jq from gitbash in windows?"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1593178017,
                "creation_date": 1593178017,
                "answer_id": 62595763,
                "question_id": 53967693,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of using [chocolatey](https://chocolatey.org/packages/jq) (with elevated rights) you could also use [scoop.sh](https://scoop.sh/):\r\n\r\n```bash\r\nscoop install jq\r\n```",
                "title": "How to run jq from gitbash in windows?"
            },
            {
                "up_vote_count": 212,
                "is_accepted": false,
                "score": 211,
                "last_activity_date": 1723666965,
                "last_edit_date": 1723666965,
                "creation_date": 1604050831,
                "answer_id": 64605901,
                "question_id": 53967693,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**Easiest solution and always latest version:**\r\n\r\n____\r\nrun this curl in your gitbash:\r\n\r\n    curl -L -o /usr/bin/jq.exe https://github.com/jqlang/jq/releases/latest/download/jq-win64.exe\r\n\r\n\r\nor manually save the `jq-win64.exe` in link above as `jq.exe` to your `/usr/bin` (which is in your git bash installation folder)\r\n\r\n(if you are behind a proxy add the `-x proxyhost:port`)\r\n\r\n[![enter image description here][1]][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/cCRCz.png",
                "title": "How to run jq from gitbash in windows?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1639416714,
                "creation_date": 1639416714,
                "answer_id": 70338666,
                "question_id": 53967693,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Below steps worked for me in git bash on windows 10\r\n\r\n```\r\ncurl -L -o jq-win64.exe https://github.com/stedolan/jq/releases/latest/download/jq-win64.exe\r\n\r\nexport PATH=$PATH:&quot;/C/Users/devops/Downloads/jq-win64.exe\r\n\r\njq --version\r\n\r\njq-1.6\r\n\r\n```",
                "title": "How to run jq from gitbash in windows?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1657853827,
                "last_edit_date": 1657853827,
                "creation_date": 1657358011,
                "answer_id": 72920207,
                "question_id": 53967693,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In my case, I have fixed it in Windows10 while practicing a scenario of &quot;Techworld with Nana&quot; course, as per the below steps:\r\n\r\n**1)** open &quot;cmd&quot; prompt (Run as administrator)\r\n\r\n**2)** `curl -L -o /usr/bin/jq-win64.exe`\r\n[Download it here][1]\r\n\r\n**3)** You can add `C:\\Program Files\\Git\\usr\\bin` path to your environment variables. *If you follow this step, ignore the below steps.*\r\n\r\n**[OR]**\r\n\r\n**3)** Go to the directory where jq is downloaded: `C:\\Program Files\\Git\\usr\\bin` and copy the file to `C:\\` drive\r\n\r\n**4)** Add the path `C:\\` to &quot;path&quot; environment variable. This `PC--&gt;Properties--&gt;Advanced` system `settings --&gt; Environment Variables --&gt;Edit--&gt;New`. Then add the path (where you copied jq.exe, i.e., C:\\) and Save it.\r\n\r\n**5)** Now open a new &quot;cmd&quot; prompt, jq --version\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/releases/latest/download/jq-win64.exe",
                "title": "How to run jq from gitbash in windows?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1662698173,
                "creation_date": 1662698173,
                "answer_id": 73657377,
                "question_id": 53967693,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For windows Powershell &amp;&amp; cmd \r\n\r\n[Download executable][1] -&gt; jq 1+ executables for 64-bit\r\n\r\nCreate folder in Program Files -&gt; JQ\r\n\r\nCopy .exe into program folder\r\n\r\nSet environment variable to that folder\r\n\r\nRestart terminal \r\n\r\nSet alias \r\n\r\n     Set-Alias -Name jq -Value .\\jq-win64.exe\r\n\r\nRun command\r\n\r\n     echo &#39;{&quot;foo&quot;: 0}&#39; | jq \r\n\r\nOutput\r\n\r\n     {\r\n        &quot;foo&quot;: 0\r\n     }\r\n\r\nenjoy!\r\n\r\n  [1]: https://stedolan.github.io/jq/download/",
                "title": "How to run jq from gitbash in windows?"
            },
            {
                "up_vote_count": 11,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1695975867,
                "creation_date": 1695975867,
                "answer_id": 77200430,
                "question_id": 53967693,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": " 1. In windows open PowerShell as a administrator and run below command:\r\n\r\n    `winget install jqlang.jq`\r\n\r\n 2. Once it was installed, now powershell added the .exe to the path environment variable and ask you to re-start the powershell. I would recommend you to restart you windows and then open your powershell / windows command line /  git bash cli and run below command to check the jq is properly installed or not.\r\n\r\n    `jq --version`\r\n\r\n 3. if installed it provide the jq version.\r\n\r\n    `$ jq --version`\r\n     \r\n     `jq-1.7-dirty`\r\n\r\nOfficial installation documentation guide.\r\nhttps://jqlang.github.io/jq/download/#windows:~:text=winget%20install%20jqlang.jq",
                "title": "How to run jq from gitbash in windows?"
            }
        ],
        "is_answered": true,
        "answer_count": 9,
        "score": 145,
        "last_activity_date": 1723666965,
        "creation_date": 1546069408,
        "last_edit_date": 1546072163,
        "question_id": 53967693,
        "body_markdown": "I have `gitbash` in Windows. I am trying to run `jq` but its giving me error.\r\n\r\n    $ ./jq-win64.exe \r\n    jq \r\n    parse error: Invalid numeric literal at line 2, column 0\r\n\r\n*Intention*: I want to use `jq` to parse json.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53967693/how-to-run-jq-from-gitbash-in-windows",
        "title": "How to run jq from gitbash in windows?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1546178452,
                "post_id": 53978065,
                "comment_id": 94793894,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 135548,
                    "reputation": 6658,
                    "user_id": 338476,
                    "user_type": "registered",
                    "accept_rate": 49,
                    "profile_image": "https://www.gravatar.com/avatar/c28b92ae5611083c82d6cde165ab29c0?s=256&d=identicon&r=PG",
                    "display_name": "tzippy",
                    "link": "https://stackoverflow.com/users/338476/tzippy"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1546178724,
                "post_id": 53978065,
                "comment_id": 94793966,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1546179133,
                "post_id": 53978065,
                "comment_id": 94794072,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 135548,
                    "reputation": 6658,
                    "user_id": 338476,
                    "user_type": "registered",
                    "accept_rate": 49,
                    "profile_image": "https://www.gravatar.com/avatar/c28b92ae5611083c82d6cde165ab29c0?s=256&d=identicon&r=PG",
                    "display_name": "tzippy",
                    "link": "https://stackoverflow.com/users/338476/tzippy"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1546179221,
                "post_id": 53978065,
                "comment_id": 94794099,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1546179387,
                "post_id": 53978065,
                "comment_id": 94794138,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 135548,
                    "reputation": 6658,
                    "user_id": 338476,
                    "user_type": "registered",
                    "accept_rate": 49,
                    "profile_image": "https://www.gravatar.com/avatar/c28b92ae5611083c82d6cde165ab29c0?s=256&d=identicon&r=PG",
                    "display_name": "tzippy",
                    "link": "https://stackoverflow.com/users/338476/tzippy"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1546190629,
                "post_id": 53978065,
                "comment_id": 94796868,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 11,
                "is_accepted": true,
                "score": 11,
                "last_activity_date": 1546224101,
                "last_edit_date": 1546224101,
                "creation_date": 1546223715,
                "answer_id": 53983064,
                "question_id": 53978065,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you use jq version 1.4 or later, the following should produce the desired output:\r\n\r\n    .operations[]\r\n    | select( index(&quot;w51&quot;) )\r\n\r\n\r\n## Alternatives\r\n\r\nThere are many alternatives, depending on which version of jq you have.  If your jq has `any/0`, the following is an efficient option:\r\n\r\n    .operations[] | select( any(. == &quot;w51&quot; ) )\r\n\r\n",
                "title": "Use jq to find array element by containing string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1546224101,
        "creation_date": 1546177049,
        "last_edit_date": 1546178304,
        "question_id": 53978065,
        "body_markdown": "I have an array &quot;operations&quot; from which I would like to return all the elements that contain a  matching string like `&quot;w51&quot;`. Until now, all the samples I have found dealt with key value pairs. I am using `jq &#39;.operations[]&#39; &lt; file` to retrieve the elements.\r\n \r\n\r\n    {\r\n      &quot;operations&quot;: [\r\n        [\r\n          &quot;create&quot;,\r\n          &quot;w51&quot;,\r\n          &quot;rwt.widgets.Label&quot;,\r\n          {\r\n            &quot;parent&quot;: &quot;w41&quot;,\r\n            &quot;style&quot;: [\r\n              &quot;NONE&quot;\r\n            ],\r\n            &quot;bounds&quot;: [\r\n              101,\r\n              0,\r\n              49,\r\n              42\r\n            ],\r\n            &quot;tabIndex&quot;: -1,\r\n            &quot;customVariant&quot;: &quot;variant_pufferLabelLogout&quot;\r\n          }\r\n        ],\r\n        [\r\n          &quot;create&quot;,\r\n          &quot;w39&quot;,\r\n          &quot;rwt.widgets.Composite&quot;,\r\n          {\r\n            &quot;parent&quot;: &quot;w34&quot;,\r\n            &quot;style&quot;: [\r\n              &quot;NONE&quot;\r\n            ],\r\n            &quot;children&quot;: [\r\n              &quot;w52&quot;\r\n            ],\r\n            &quot;bounds&quot;: [\r\n              0,\r\n              42,\r\n              762,\r\n              868\r\n            ],\r\n            &quot;tabIndex&quot;: -1,\r\n            &quot;clientArea&quot;: [\r\n              0,\r\n              0,\r\n              762,\r\n              868\r\n            ]\r\n          }\r\n        ]\r\n      ]\r\n    }\r\n\r\nMy expected output when searching for an array element that contains &quot;w51&quot; would be this:\r\n\r\n    [\r\n          &quot;create&quot;,\r\n          &quot;w51&quot;,\r\n          &quot;rwt.widgets.Label&quot;,\r\n          {\r\n            &quot;parent&quot;: &quot;w41&quot;,\r\n            &quot;style&quot;: [\r\n              &quot;NONE&quot;\r\n            ],\r\n            &quot;bounds&quot;: [\r\n              101,\r\n              0,\r\n              49,\r\n              42\r\n            ],\r\n            &quot;tabIndex&quot;: -1,\r\n            &quot;customVariant&quot;: &quot;variant_pufferLabelLogout&quot;\r\n          }\r\n    ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53978065/use-jq-to-find-array-element-by-containing-string",
        "title": "Use jq to find array element by containing string"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 11,
                "is_accepted": true,
                "score": 11,
                "last_activity_date": 1546253506,
                "creation_date": 1546253506,
                "answer_id": 53986579,
                "question_id": 53986312,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can first convert the elements in the array to entries, this way both the key and the value are present in the output:\r\n\r\n    jq &#39;.arr | to_entries&#39;\r\n\r\nGive the result where the `key` is present in the output:\r\n\r\n    [\r\n      {\r\n        &quot;key&quot;: 0,\r\n        &quot;value&quot;: [\r\n          &quot;create&quot;,\r\n          &quot;w71&quot;,\r\n          &quot;rwt.widgets.Label&quot;,\r\n          {\r\n            &quot;parent&quot;: &quot;w68&quot;,\r\n            &quot;style&quot;: &quot;1&quot;,\r\n            &quot;bounds&quot;: &quot;2&quot;,\r\n            &quot;tabIndex&quot;: -1,\r\n            &quot;background&quot;: &quot;ww&quot;,\r\n            &quot;font&quot;: &quot;test&quot;,\r\n            &quot;text&quot;: &quot;FooBar&quot;,\r\n            &quot;alignment&quot;: &quot;right&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;key&quot;: 1,\r\n        &quot;value&quot;: [\r\n          &quot;create&quot;,\r\n          &quot;w72&quot;,\r\n          &quot;rwt.widgets.Label&quot;,\r\n          {\r\n            &quot;parent&quot;: &quot;w68&quot;,\r\n            &quot;style&quot;: &quot;22&quot;,\r\n            &quot;bounds&quot;: &quot;1&quot;,\r\n            &quot;tabIndex&quot;: -1,\r\n            &quot;foreground&quot;: &quot;null&quot;,\r\n            &quot;background&quot;: &quot;1&quot;,\r\n            &quot;font&quot;: &quot;2&quot;,\r\n            &quot;text&quot;: &quot;55&quot;,\r\n            &quot;alignment&quot;: &quot;right&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nPerforming your filtering and returning the index then becomes fairly trivial:\r\n\r\n    jq &#39;.arr | to_entries | .[] | select(.value[3].text | contains(&quot;FooBar&quot;)) | .key&#39; &lt;test.json",
                "title": "Have jq return the index number of an element in an array"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1546272942,
                "creation_date": 1546272942,
                "answer_id": 53989407,
                "question_id": 53986312,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution that does not depend on the assumption that the object of interest has a fixed position within the array:\r\n\r\n    .arr\r\n    | map( .[] | objects | .text ) \r\n    | index(&quot;FooBar&quot;)\r\n\r\n\r\nMore robustly:\r\n\r\n    .arr \r\n    | map( first(.[] | objects) // null | .text )\r\n    | index(&quot;FooBar&quot;)\r\n",
                "title": "Have jq return the index number of an element in an array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1546272942,
        "creation_date": 1546251895,
        "question_id": 53986312,
        "body_markdown": "I want jq to return the index of an alement in an array based on a search.\r\n\r\nUsing the below array I call jq to find the value `&quot;FooBar&quot;` of a key `&quot;text&quot;`:\r\n\r\n    jq &#39;.arr[] | .[3].text | tostring | select(contains(&quot;FooBar&quot;) )&#39; &lt; file.json\r\n\r\nThe result is:\r\n\r\n    &quot;FooBar&quot;\r\n\r\nBut what I actually want is the index of the most outer array `&quot;arr&quot;` that this `text:FooBar` pair is nested in, which is 0 in this case.\r\n\r\nCan this e achieved in jq?\r\n\r\n    {\r\n    &quot;arr&quot;: [\r\n        [\r\n          &quot;create&quot;,\r\n          &quot;w71&quot;,\r\n          &quot;rwt.widgets.Label&quot;,\r\n          {\r\n            &quot;parent&quot;: &quot;w68&quot;,\r\n            &quot;style&quot;: &quot;1&quot;,\r\n            &quot;bounds&quot;: &quot;2&quot;,\r\n            &quot;tabIndex&quot;: -1,\r\n            &quot;background&quot;: &quot;ww&quot;,\r\n            &quot;font&quot;: &quot;test&quot;,\r\n            &quot;text&quot;: &quot;FooBar&quot;,\r\n            &quot;alignment&quot;: &quot;right&quot;\r\n          }\r\n        ],\r\n        [\r\n              &quot;create&quot;,\r\n              &quot;w72&quot;,\r\n              &quot;rwt.widgets.Label&quot;,\r\n              {\r\n                &quot;parent&quot;: &quot;w68&quot;,\r\n                &quot;style&quot;: &quot;22&quot;,\r\n                &quot;bounds&quot;: &quot;1&quot;,\r\n                &quot;tabIndex&quot;: -1,\r\n                &quot;foreground&quot;: &quot;null&quot;,\r\n                &quot;background&quot;: &quot;1&quot;,\r\n                &quot;font&quot;: &quot;2&quot;,\r\n                &quot;text&quot;: &quot;55&quot;,\r\n                &quot;alignment&quot;: &quot;right&quot;\r\n              }\r\n            ]\r\n      ]\r\n    }\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53986312/have-jq-return-the-index-number-of-an-element-in-an-array",
        "title": "Have jq return the index number of an element in an array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1546352596,
                "last_edit_date": 1546352596,
                "creation_date": 1546268338,
                "answer_id": 53988791,
                "question_id": 53987713,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can always embed a stream of (zero or more) JSON entities within some other JSON structure by decorating the stream, that is, in the present case, by wrapping the STREAM as follows:\r\n\r\n    { arr: [ STREAM ] }\r\n\r\nIn the present case, however, we can also take the view that we are simply editing the original document, and accordingly use a variation of the `map(select(...))` idiom:\r\n\r\n    .arr |= map( select(index(&quot;FooItem&quot;)) | .[3].texts) \r\n\r\nThis latter approach ensures that the context of the &quot;arr&quot; key is preserved.\r\n\r\n\r\n## Addendum\r\n\r\nTo filter out the empty strings, simply add another `map(select(...))`:\r\n\r\n    .arr |= map( select(index(&quot;FooItem&quot;))\r\n                 | .[3].texts | map(select(length&gt;0)))\r\n\r\n    \r\n\r\n",
                "title": "Create a new json string from jq output elements"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1546352596,
        "creation_date": 1546260500,
        "last_edit_date": 1546340947,
        "question_id": 53987713,
        "body_markdown": "My jq command returns objects in brackets but without comma separators. But I would like to create a new json string from it.\r\n\r\nThis call finds all elements of `arr` that have a `FooItem` in them and then returns `texts` from the nested array at index `3`:\r\n\r\n    jq &#39;.arr[] | select(index(&quot;FooItem&quot;)) | .[3].texts&#39; \r\n\r\non this json (The original has more elements ):\r\n\r\n   \r\n\r\n     {\r\n          &quot;arr&quot;: [\r\n            [\r\n              &quot;create&quot;,\r\n              &quot;w199&quot;,\r\n              &quot;FooItem&quot;,\r\n              {\r\n                &quot;index&quot;: 0,\r\n                &quot;texts&quot;: [\r\n                  &quot;aBarfoo&quot;,\r\n                  &quot;avalue&quot;\r\n                ]\r\n              }\r\n            ],\r\n            [\r\n              &quot;create&quot;,\r\n              &quot;w200&quot;,\r\n              &quot;NoItem&quot;,\r\n              {\r\n                &quot;index&quot;: 1,\r\n                &quot;val&quot;: 5,\r\n                &quot;hearts&quot;: 5\r\n              }\r\n            ],\r\n            [\r\n              &quot;create&quot;,\r\n              &quot;w200&quot;,\r\n              &quot;FooItem&quot;,\r\n              {\r\n                &quot;index&quot;: 1,\r\n                &quot;texts&quot;: [\r\n                  &quot;mybarfoo&quot;,\r\n                  &quot;bValue&quot;\r\n                ]\r\n              }\r\n            ]\r\n        ]\r\n        }\r\n\r\nreturns this output:\r\n\r\n\r\n    [\r\n      &quot;aBarfoo&quot;,\r\n      &quot;avalue&quot;\r\n    ]\r\n    [\r\n      &quot;mybarfoo&quot;,\r\n      &quot;bValue&quot;\r\n    ]\r\n\r\n\r\nBut I&#39;d like to create a new json from these objects that looks like this:\r\n\r\n    {\r\n    \t&quot;arr&quot;: [\r\n    \t\t[\r\n    \t\t\t&quot;aBarfoo&quot;,\r\n    \t\t\t&quot;avalue&quot;\r\n    \t\t],\r\n    \t\t[\r\n    \t\t\t&quot;mybarfoo&quot;,\r\n    \t\t\t&quot;bValue&quot;\r\n    \t\t]\r\n    \t]\r\n    }\r\n\r\nCan jq do this?\r\n\r\n\r\n**EDIT**\r\n\r\nOne more addition: Considering that texts also has strings of zero length, how would you delete those/not have them in the result?\r\n\r\n    &quot;texts&quot;: [&quot;&quot;,\r\n              &quot;mybarfoo&quot;,\r\n              &quot;bValue&quot;,\r\n              &quot;&quot;\r\n              ]\r\n",
        "link": "https://stackoverflow.com/questions/53987713/create-a-new-json-string-from-jq-output-elements",
        "title": "Create a new json string from jq output elements"
    },
    {
        "tags": [
            "json",
            "parsing",
            "duplicates",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7193959,
                    "reputation": 880,
                    "user_id": 5493355,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/MXYDI.png?s=256",
                    "display_name": "Thelouras",
                    "link": "https://stackoverflow.com/users/5493355/thelouras"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1546271574,
                "post_id": 53989197,
                "comment_id": 94815914,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1546273035,
                "post_id": 53989197,
                "comment_id": 94816354,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 141904,
                    "reputation": 2321,
                    "user_id": 349268,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/nPuwD.jpg?s=256",
                    "display_name": "rs79",
                    "link": "https://stackoverflow.com/users/349268/rs79"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1546273762,
                "post_id": 53989197,
                "comment_id": 94816558,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1546291479,
                "last_edit_date": 1546291479,
                "creation_date": 1546273706,
                "answer_id": 53989494,
                "question_id": 53989197,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an efficient approach using `inputs`. It requires invoking jq with the -n command-line option.  The idea is to create a dictionary that keeps count of each memberId string value.  \r\n\r\nThe dictionary can be created as follows:\r\n\r\n    reduce (inputs|.memberId|tostring) as $id ({}; .[$id] += 1)\r\n\r\nThus, to produce a true/false indicator, followed by the duplicates if any, you could write:\r\n\r\n    reduce (inputs|.memberId|tostring) as $id ({}; .[$id] += 1)\r\n    | to_entries\r\n    | map(select(.value &gt; 1))\r\n    | (length &gt; 0), .[].key\r\n\r\n(If all the .memberId values are known to be strings, then of course the call to `tostring` can be dropped.  Conversely, if .memberId is both string and integer-valued, then the above program won&#39;t differentiate between occurrences of `1` and `&quot;1&quot;`, for example.)\r\n\r\n## bow\r\n\r\nThe aforementioned dictionary is sometimes called a &quot;bag of words&quot; (https://en.wikipedia.org/wiki/Bag-of-words_model).  This leads to the generic function:\r\n\r\n    def bow(stream): \r\n      reduce stream as $word ({}; .[($word|tostring)] += 1);\r\n\r\nThe solution can now be written more concisely:\r\n\r\n\r\n    bow(inputs.memberId)\r\n    | to_entries\r\n    | map(select(.value &gt; 1))\r\n    | (length &gt; 0), .[].key\r\n\r\nFor just the values which have duplicates, one could write the more efficient query:\r\n\r\n\r\n    bow(inputs.memberId)\r\n    | keys_unsorted[] as $k\r\n    | select(.[$k] &gt; 1)\r\n    | $k\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "Check for duplicate values for a specific JSON key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1546291479,
        "creation_date": 1546271475,
        "last_edit_date": 1546289772,
        "question_id": 53989197,
        "body_markdown": "I have the following JSON records stored in a container\r\n\r\n    \r\n        {&quot;memberId&quot;:&quot;123&quot;,&quot;city&quot;:&quot;New York&quot;}\r\n        {&quot;memberId&quot;:&quot;234&quot;,&quot;city&quot;:&quot;Chicago&quot;}\r\n        {&quot;memberId&quot;:&quot;345&quot;,&quot;city&quot;:&quot;San Francisco&quot;}\r\n        {&quot;memberId&quot;:&quot;123&quot;,&quot;city&quot;:&quot;New York&quot;}\r\n        {&quot;memberId&quot;:&quot;345&quot;,&quot;city&quot;:&quot;San Francisco&quot;}\r\n\r\nI am looking to check if there is any duplication of the memberId - ideally return a true/false and then also return the duplicated values.\r\n\r\nDesired Output:\r\n\r\n    true\r\n    123\r\n    345",
        "link": "https://stackoverflow.com/questions/53989197/check-for-duplicate-values-for-a-specific-json-key",
        "title": "Check for duplicate values for a specific JSON key"
    },
    {
        "tags": [
            "json",
            "string",
            "select",
            "jq",
            "any"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1546284933,
                "post_id": 53990847,
                "comment_id": 94819431,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18538,
                    "reputation": 1604,
                    "user_id": 42552,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://www.gravatar.com/avatar/d3d8778bfd7699f34e9346683b4458db?s=256&d=identicon&r=PG",
                    "display_name": "JosephDoggie",
                    "link": "https://stackoverflow.com/users/42552/josephdoggie"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1546284937,
                "post_id": 53990847,
                "comment_id": 94819432,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 141904,
                    "reputation": 2321,
                    "user_id": 349268,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/nPuwD.jpg?s=256",
                    "display_name": "rs79",
                    "link": "https://stackoverflow.com/users/349268/rs79"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1546434155,
                "post_id": 53990847,
                "comment_id": 94850251,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1546538275,
                "last_edit_date": 1546538275,
                "creation_date": 1546297790,
                "answer_id": 53992054,
                "question_id": 53990847,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your query won&#39;t detect empty strings, and will possibly emit the same string more than once.  It would be easier to use `test`, e.g.:\r\n\r\n    select( length==0 or test(&quot;[-_ ]&quot;) )\r\n\r\nNote also that the preliminary &#39;.&#39; in your query is unnecessary.\r\n\r\n## Addendum\r\n\r\nFrom one of the comments, it awould appear that you will want to specify &quot;[^a-zA-Z0-9]&quot; or similar as the argument of `test`.",
                "title": "Select JSON values with special characters"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1546538275,
        "creation_date": 1546284726,
        "last_edit_date": 1546335925,
        "question_id": 53990847,
        "body_markdown": "I am looking to detect anomalies in my JSON values. \r\nHere&#39;s an example of the data queries via jq\r\n\r\n    &quot;2014-03-26 01:58:00&quot;\r\n    &quot;9019549360&quot;\r\n    &quot;109092812_20150626&quot;\r\n    &quot;134670164&quot;\r\n    &quot;&quot;\r\n    &quot;97695498&quot;\r\n    &quot;680561513&quot;\r\n\r\nI would like to display all the values that contain a `-` or a `_` or is `blank`.\r\n\r\nIn other words, I&#39;d like to display the following output\r\n\r\n    &quot;2014-03-26 01:58:00&quot;\r\n    &quot;109092812_20150626&quot;\r\n    &quot;&quot;\r\n\r\nNow, I have tried the following:\r\n\r\n    select (. | contains(&quot;-&quot;,&quot;_&quot;,&quot; &quot;))&#39;\r\n\r\nThis appears to work, but in order to make it more robust, I&#39;d like to expand this to include all special characters.",
        "link": "https://stackoverflow.com/questions/53990847/select-json-values-with-special-characters",
        "title": "Select JSON values with special characters"
    },
    {
        "tags": [
            "json",
            "ansible",
            "jq",
            "idempotent"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1546406316,
                "creation_date": 1546406316,
                "answer_id": 54001550,
                "question_id": 54001333,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Is this the code that you&#39;re looking for?\r\n\r\n        - set_fact:\r\n            doc1: &quot;{{ lookup(&#39;file&#39;, &#39;config.json&#39;) }}&quot;\r\n            doc2: &quot;{{ lookup(&#39;file&#39;, &#39;credHelper.json&#39;) }}&quot;\r\n        - debug: msg=&quot;{{ doc1 | combine(doc2) }}&quot;\r\n\r\n\r\n\r\n    TASK [debug] **********************************************************\r\n    ok: [localhost] =&gt; {\r\n        &quot;msg&quot;: {\r\n            &quot;HttpHeaders&quot;: {\r\n                &quot;User-Agent&quot;: &quot;Docker-Client/18.03.0-ce (windows)&quot;\r\n            }, \r\n            &quot;auths&quot;: {\r\n                &quot;https://index.docker.io/v1/&quot;: {\r\n                    &quot;auth&quot;: &quot;supercalifragilistic&quot;\r\n                }\r\n             }, \r\n             &quot;credHelpers&quot;: {\r\n                &quot;111111111111.dkr.ecr.us-east-1.amazonaws.com&quot;: &quot;ecr-login&quot;\r\n             }\r\n        }\r\n    }\r\n",
                "title": "Merge two JSON documents together"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1546419267,
                "last_edit_date": 1546419267,
                "creation_date": 1546415889,
                "answer_id": 54002999,
                "question_id": 54001333,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just to complete the picture, this is also possible with `jq`, simply `add` two json files:\r\n\r\n    jq -s &#39;add&#39; credHelpers.json config.json\r\n\r\nThe `add` filter takes as input an array, and produces as output the elements of the array added together, as the `jq` [documentation says](https://stedolan.github.io/jq/manual/). In addition you need the `--slurp/-s` command line option, which turns the entire input stream into a large array and runs the filter just once.\r\n",
                "title": "Merge two JSON documents together"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1546422251,
        "creation_date": 1546404547,
        "last_edit_date": 1546404858,
        "question_id": 54001333,
        "body_markdown": "I am trying append some JSON to existing `~/.docker/config.json` document using Ansible.\r\n\r\nDocument 1 `~/.docker/config.json`\r\n\r\n    {\r\n            &quot;auths&quot;: {\r\n                    &quot;https://index.docker.io/v1/&quot;: {\r\n                            &quot;auth&quot;: &quot;supercalifragilistic&quot;\r\n                    }\r\n            },\r\n            &quot;HttpHeaders&quot;: {\r\n                    &quot;User-Agent&quot;: &quot;Docker-Client/18.03.0-ce (windows)&quot;\r\n            }\r\n    }\r\n\r\n\r\nDocument 2 `credHelper.json`\r\n\r\n    {\r\n        &quot;credHelpers&quot;: {\r\n            &quot;111111111111.dkr.ecr.us-east-1.amazonaws.com&quot; : &quot;ecr-login&quot;\r\n        }\r\n    }\r\n\r\nI have been spending some time with `jq` but cannot get it to work. This is the result of jq.\r\n\r\n```jq -s &#39;.&#39; credHelpers.json config.json```\r\n\r\n    [\r\n      {\r\n        &quot;credHelpers&quot;: {\r\n          &quot;111111111111.dkr.ecr.us-east-1.amazonaws.com&quot;: &quot;ecr-login&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;auths&quot;: {\r\n          &quot;https://index.docker.io/v1/&quot;: {\r\n            &quot;auth&quot;: &quot;supercalifragilistic&quot;\r\n          }\r\n        },\r\n        &quot;HttpHeaders&quot;: {\r\n          &quot;User-Agent&quot;: &quot;Docker-Client/18.03.0-ce (windows)&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\nWhat I want is this:\r\n\r\n    {\r\n        &quot;auths&quot;: {\r\n                &quot;https://index.docker.io/v1/&quot;: {\r\n                        &quot;auth&quot;: &quot;supercalifragilistic&quot;\r\n                }\r\n        },\r\n        &quot;HttpHeaders&quot;: {\r\n                &quot;User-Agent&quot;: &quot;Docker-Client/18.03.0-ce (windows)&quot;\r\n        },\r\n        &quot;credHelpers&quot;: {\r\n                &quot;111111111111.dkr.ecr.us-east-1.amazonaws.com&quot;: &quot;ecr-login&quot;\r\n        }\r\n    }\r\n\r\nI Hope I can make this idempotent, too, so the merging/joining doesn&#39;t keep happening recursively each time playbook is run.",
        "link": "https://stackoverflow.com/questions/54001333/merge-two-json-documents-together",
        "title": "Merge two JSON documents together"
    },
    {
        "tags": [
            "json",
            "jq",
            "datetime-format"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1546599230,
                "last_edit_date": 1546599230,
                "creation_date": 1546446931,
                "answer_id": 54009919,
                "question_id": 54006570,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following is more generic than actually needed here:\r\n\r\n    def to24h:\r\n        (capture(&quot;(?&lt;pre&gt;.*)(?&lt;h&gt;[01][0-9])(?&lt;m&gt;:[0-5][0-9]) *(?&lt;midi&gt;[aApP])[mM](?&lt;post&gt;.*)&quot;) //\r\n         capture(&quot;(?&lt;pre&gt;.*)(?&lt;h&gt;[0-9])(?&lt;m&gt;:[0-5][0-9]) *(?&lt;midi&gt;[aApP])[mM](?&lt;post&gt;.*)&quot;))\r\n\r\n      | (.midi|ascii_upcase) as $midi\r\n      | .pre + (if $midi == &quot;A&quot; then .h else &quot;\\(12+(.h|tonumber))&quot; end) + .m + .post ;\r\n\r\nWith this def, you could transform the given input using the filter:\r\n\r\n    .times |= map( map(to24h // .) )\r\n\r\nor if you want all strings to be checked:\r\n\r\n    walk( if type==&quot;string&quot; then to24h // . else . end)\r\n\r\n",
                "title": "Format 12h time values to 24h in jq output"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1546528168,
                "last_edit_date": 1546528168,
                "creation_date": 1546459054,
                "answer_id": 54012393,
                "question_id": 54006570,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Could we use jq&#39;s date functions?\r\n\r\n    jq &#39;(.times[] | .[])\r\n        |= ( if test(&quot;^\\\\d{1,2}:\\\\d{1,2} [AP]M$&quot;; &quot;i&quot;)\r\n             then ( strptime(&quot;%H:%M %p&quot;) | strftime(&quot;%k:%M&quot;) | sub(&quot;^ &quot;; &quot;&quot;) )\r\n             else . end ) &#39;\r\n",
                "title": "Format 12h time values to 24h in jq output"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1546532739,
                "last_edit_date": 1546532739,
                "creation_date": 1546532351,
                "answer_id": 54026077,
                "question_id": 54006570,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `strptime` and `strftime` to parse and reformat each time.\r\n\r\n    % jq -c &#39;.times[][0] |= (strptime(&quot;%H:%M %p&quot;) | strftime(&quot;%H:%M&quot;))&#39;\r\n    { &quot;times&quot;: [ [ &quot;8:16 AM&quot;, &quot;EventA&quot; ], [ &quot;3:19 PM&quot;, &quot;EventB&quot; ] ]}\r\n    {&quot;times&quot;:[[&quot;08:16&quot;,&quot;EventA&quot;],[&quot;15:19&quot;,&quot;EventB&quot;]]}\r\n    ^C\r\n\r\n`strptime` produces a list where the hour matched by `%H` is adjusted to 24-hour time based on the modifier matched by `%p`; `strftime` then simply outputs whatever hour it gets.\r\n\r\nThe hard part isn&#39;t the conversion; it&#39;s determining which values the conversion should be applied *to*. Here, we&#39;re assuming that each time is the first element of the arrays in the array value of the `times` key.",
                "title": "Format 12h time values to 24h in jq output"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1546599230,
        "creation_date": 1546432811,
        "question_id": 54006570,
        "body_markdown": "I have values of the format &quot;h:mm AM&quot;/&quot;h:mm PM&quot; in my json that I get from jq.\r\nIs there a way to parse these 12h formatted values and convert them to 24h ones?\r\n\r\n\r\nSample Input:\r\n\r\n    { &quot;times&quot;: [ [ &quot;8:16 AM&quot;, &quot;EventA&quot; ], [ &quot;3:19 PM&quot;, &quot;EventB&quot; ] ]}\r\n\r\nDesired Output:\r\n\r\n    { &quot;times&quot;: [ [ &quot;8:16&quot;, &quot;EventA&quot; ], [ &quot;15:19&quot;, &quot;EventB&quot; ] ]}",
        "link": "https://stackoverflow.com/questions/54006570/format-12h-time-values-to-24h-in-jq-output",
        "title": "Format 12h time values to 24h in jq output"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "lookup-tables",
            "rsyslog"
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1663588977,
        "creation_date": 1546518848,
        "last_edit_date": 1663588977,
        "question_id": 54022393,
        "body_markdown": "There is a list of IPs (their quantity is changing every few minutes) stored in a log-file. The logfile only contains unique IPs (sort -u):\r\n\r\n    IP-Pool.log [Example]:\r\n    192.168.1.1\r\n    192.168.1.2\r\n    10.1.1.0\r\n    .\r\n    .\r\n\r\nI would like to filter occuring connection events with rsyslog and sort them by:\r\n\r\n - Events where $msg contains one IP of Array[IP-Pool-List]\r\n - Events where $msg doesn&#39;t contain any IP of Array[IP-Pool-List] \r\n\r\nTherefore I would have to put the IPs into an array so they can be compared but I haven&#39;t found a way to do so.\r\n\r\n    if $msg contains &#39;connection-event-id&#39; then {\r\n    \r\n      if $msg contains &#39;Array[IP-Pool-List] then {\r\n        -/var/log/event_contains_ip.log      \r\n        STOP\r\n      }\r\n      else{\r\n       -/var/log/event_doesnt_contain_ip.log\r\n       STOP\r\n      }\r\n    \r\n    }\r\n\r\nWould I also have to restart the rsyslogd service in order to refresh the array [IP-Pool-List], since the file is changing every few minutes ?\r\n\r\nIs there a way to solve this with rsyslog, or is there an easier/better way to do this ?\r\n\r\n__EDIT__\r\n\r\nI used crontab and inotifywait to keep the IP-Pool-File up to date.\r\n\r\n    @reboot inotifywait -q -m -e modify /var/log/client-ips.log | \r\n    while read -r filename events; do sort -u /var/log/client-ips.log \r\n    -o /var/log/ips-unique.log ;done\r\n\r\nI also asked this question via mail to the &quot;rsyslog-community&quot; their contact mail is listed at the bottom of the rsyslog documentation (https://lists.adiscon.net/mailman/listinfo/rsyslog)\r\nThey gave me the advise to use &quot;Lookup-Tables&quot; to solve this. Currently reading how to use them correctly. Since I am a slow learner, this should take a while.\r\n\r\n\r\n__EDIT 2__\r\n\r\nA new plan is starting to form:\r\n\r\n - To get Lookup-Table going, I need to create a JSON-File, which\r\n   contains the values I am going to build my filter with\r\n - Update the JSON File with &quot;reload_lookup_table&quot; or &quot;JQ&quot;, whenever a new IP is added to the\r\n   IP-Pool-List.\r\n - Use RSYSLOG Lookup-Table to filter for the given IPs and split the\r\n   results into two seperate log files | Match.log | NoMatch.log",
        "link": "https://stackoverflow.com/questions/54022393/compare-array-of-ips-with-rsyslog",
        "title": "Compare Array of IPs with rsyslog"
    },
    {
        "tags": [
            "json",
            "shell",
            "command-line",
            "edit",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1546613488,
                "creation_date": 1546613488,
                "answer_id": 54041253,
                "question_id": 54039268,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It is enough to assign to the path, if you are using `|=`, e.g.\r\n\r\n    jq &#39;\r\n      (.taskDefinition.containerDefinitions[0].environment[] | \r\n       select(.name==&quot;DB_USERNAME&quot;) | .value) |= &quot;new&quot;\r\n    &#39; infile.json\r\n\r\nOutput:\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    {\r\n      &quot;taskDefinition&quot;: {\r\n        &quot;containerDefinitions&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;web&quot;,\r\n            &quot;image&quot;: &quot;my-image&quot;,\r\n            &quot;environment&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;DB_HOST&quot;,\r\n                &quot;value&quot;: &quot;localhost&quot;\r\n              },\r\n              {\r\n                &quot;name&quot;: &quot;DB_USERNAME&quot;,\r\n                &quot;value&quot;: &quot;new&quot;\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\n",
                "title": "Modifying array of key value in JSON jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1546614347,
                "creation_date": 1546614347,
                "answer_id": 54041492,
                "question_id": 54039268,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You might like to consider this alternative to using `|=`:\r\n\r\n    walk( if type==&quot;object&quot; and .name==&quot;DB_USERNAME&quot; \r\n          then .value=&quot;new&quot; else . end)",
                "title": "Modifying array of key value in JSON jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1546615213,
                "creation_date": 1546615213,
                "answer_id": 54041706,
                "question_id": 54039268,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a select-free solution using `|=`:\r\n\r\n    .taskDefinition.containerDefinitions[0].environment |=\r\n      map(if .name==&quot;DB_USERNAME&quot; then .value = &quot;new&quot;\r\n          else . end)\r\n\r\nAvoiding `select` within the expression on the LHS of `|=` makes the solution more robust w.r.t. the version of jq being used.",
                "title": "Modifying array of key value in JSON jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 8,
        "last_activity_date": 1546728226,
        "creation_date": 1546606013,
        "last_edit_date": 1546694720,
        "question_id": 54039268,
        "body_markdown": "In case, I have an original json look like the following:\r\n\r\n    {\r\n      &quot;taskDefinition&quot;: {\r\n        &quot;containerDefinitions&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;web&quot;,\r\n            &quot;image&quot;: &quot;my-image&quot;,\r\n            &quot;environment&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;DB_HOST&quot;,\r\n                &quot;value&quot;: &quot;localhost&quot;\r\n              },\r\n              {\r\n                &quot;name&quot;: &quot;DB_USERNAME&quot;,\r\n                &quot;value&quot;: &quot;user&quot;\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\n\r\nAnd I would like to inplace modify the value for the matched key like so:\r\n\r\n`jq &#39;.taskDefinition.containerDefinitions[0].environment[] | select(.name==&quot;DB_USERNAME&quot;) | .value=&quot;new&quot;&#39; json`\r\n\r\nI got the output\r\n\r\n    {\r\n      &quot;name&quot;: &quot;DB_USERNAME&quot;,\r\n      &quot;value&quot;: &quot;new&quot;\r\n    }\r\n\r\nBut I want more like in-place modify or the whole json from the original with new value modified, like this:\r\n\r\n\r\n    {\r\n          &quot;taskDefinition&quot;: {\r\n            &quot;containerDefinitions&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;web&quot;,\r\n                &quot;image&quot;: &quot;my-image&quot;,\r\n                &quot;environment&quot;: [\r\n                  {\r\n                    &quot;name&quot;: &quot;DB_HOST&quot;,\r\n                    &quot;value&quot;: &quot;localhost&quot;\r\n                  },\r\n                  {\r\n                    &quot;name&quot;: &quot;DB_USERNAME&quot;,\r\n                    &quot;value&quot;: &quot;new&quot;\r\n                  }\r\n                ]\r\n              }\r\n            ]\r\n          }\r\n        }\r\n\r\nIs it possible to do with `jq` or any known workaround?\r\n\r\nThank you.\r\n\r\n\r\n**Updated**\r\n\r\nFor anyone looking for editing multi-values,\r\nhere is the approach I use\r\n\r\n    JQ=&quot;&quot;\r\n    for e in DB_HOST=rds DB_USERNAME=xxx; do\r\n        k=${e%=*}\r\n        v=${e##*=}\r\n        JQ+=&quot;(.taskDefinition.containerDefinitions[0].environment[] | select(.name==\\&quot;$k\\&quot;) | .value) |= \\&quot;$v\\&quot; | &quot;\r\n    done\r\n    \r\n    jq &#39;${JQ%??}&#39; json\r\n\r\nI think there should be more concise way, but this seems working fine.",
        "link": "https://stackoverflow.com/questions/54039268/modifying-array-of-key-value-in-json-jq",
        "title": "Modifying array of key value in JSON jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "edit",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1546693210,
                "post_id": 54050996,
                "comment_id": 94938783,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15062935,
                    "reputation": 31,
                    "user_id": 10871046,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/94729c53ba1ef6a4db686460a4696bfd?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "FFreddy",
                    "link": "https://stackoverflow.com/users/10871046/ffreddy"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1546809215,
                "post_id": 54050996,
                "comment_id": 94965177,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1546693442,
                "last_edit_date": 1546693442,
                "creation_date": 1546692894,
                "answer_id": 54052201,
                "question_id": 54050996,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The key to a simple solution is `|=`. Using the expected output as a guide to the intended requirements, one could write:\r\n\r\n    .tmp.compare.files as $f\r\n    | .tmp.folders \r\n      |= map( if .cand_name==&quot;folderA&quot; \r\n              then .files = $f else . end)",
                "title": "How to update a multiple objects in an array with jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1546809160,
        "creation_date": 1546683461,
        "last_edit_date": 1546809160,
        "question_id": 54050996,
        "body_markdown": "Using jq I would like to conditionally update the objects in the `&quot;folders&quot;` array. \r\nFor each object which contains `&quot;cand_name&quot;:&quot;folderA&quot;` a new attribute `&quot;files&quot;` which has the value of `compare.files` should be added\r\n\r\n    {\r\n      &quot;tmp&quot;:{\r\n        &quot;folders&quot;:[\r\n          {\r\n            &quot;ref_name&quot;:&quot;folderB&quot;,\r\n            &quot;cand_name&quot;:&quot;folderA&quot;\r\n          },\r\n          {\r\n            &quot;ref_name&quot;:&quot;folderC&quot;,\r\n            &quot;cand_name&quot;:&quot;folderA&quot;\r\n          },\r\n          {\r\n            &quot;ref_name&quot;:&quot;folderC&quot;,\r\n            &quot;cand_name&quot;:&quot;folderE&quot;\r\n          }\r\n        ],\r\n        &quot;compare&quot;:{\r\n          &quot;files&quot;:[\r\n            {\r\n              &quot;candidate&quot;:&quot;Z3S1&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }\r\n\r\nFor the above input the expected output should be \r\n\r\n    {\r\n      &quot;tmp&quot;:{\r\n        &quot;folders&quot;:[\r\n          {\r\n            &quot;ref_name&quot;:&quot;folderB&quot;,\r\n            &quot;cand_name&quot;:&quot;folderA&quot;\r\n            &quot;files&quot;:[\r\n              {\r\n                &quot;candidate&quot;:&quot;Z3S1&quot;\r\n              }\r\n            ]\r\n          },\r\n          {\r\n            &quot;ref_name&quot;:&quot;folderC&quot;,\r\n            &quot;cand_name&quot;:&quot;folderA&quot;\r\n            &quot;files&quot;:[\r\n              {\r\n                &quot;candidate&quot;:&quot;Z3S1&quot;\r\n              }\r\n            ]\r\n          },\r\n          {\r\n            &quot;ref_name&quot;:&quot;folderC&quot;,\r\n            &quot;cand_name&quot;:&quot;folderE&quot;\r\n          }\r\n        ],\r\n        &quot;compare&quot;:{\r\n          &quot;files&quot;:[\r\n            {\r\n              &quot;candidate&quot;:&quot;Z3S1&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n     }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54050996/how-to-update-a-multiple-objects-in-an-array-with-jq",
        "title": "How to update a multiple objects in an array with jq"
    },
    {
        "tags": [
            "json",
            "stream",
            "edit",
            "jq",
            "deluge"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 86477,
                    "reputation": 199201,
                    "user_id": 240443,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/495d675e3bc42ed1dee469e2ce701f1b?s=256&d=identicon&r=PG",
                    "display_name": "Amadan",
                    "link": "https://stackoverflow.com/users/240443/amadan"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1546816007,
                "post_id": 54066590,
                "comment_id": 94966793,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1787152,
                    "reputation": 2235,
                    "user_id": 1628377,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/955b38a1dd07918ac76741dff3c82cc9?s=256&d=identicon&r=PG",
                    "display_name": "vane",
                    "link": "https://stackoverflow.com/users/1628377/vane"
                },
                "reply_to_user": {
                    "account_id": 86477,
                    "reputation": 199201,
                    "user_id": 240443,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/495d675e3bc42ed1dee469e2ce701f1b?s=256&d=identicon&r=PG",
                    "display_name": "Amadan",
                    "link": "https://stackoverflow.com/users/240443/amadan"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1546823044,
                "post_id": 54066590,
                "comment_id": 94967980,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1546817660,
                "last_edit_date": 1546817660,
                "creation_date": 1546816004,
                "answer_id": 54066740,
                "question_id": 54066590,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The web.conf you show is a stream of JSON entities. Fortunately for you, jq is stream-oriented, and it appears from your example that you could simply write:\r\n\r\n    jq &#39;if .pwd_sha1 then .pwd_sha1 = &quot;NEW HASH&quot; else . end&#39; web.conf\r\n\r\nIn general, though, it might be more appropriate to write something with a more stringent test, e.g.\r\n\r\n    jq &#39;if type == &quot;object&quot; and has(&quot;pwd_sha1&quot;) \r\n      then .pwd_sha1 = &quot;NEW HASH&quot; else . end&#39; web.conf\r\n\r\n## &quot;changing the second top level element&#39;s value&quot;\r\n\r\nTo edit the second top-level item only, you could use `foreach inputs` with the -n command-line option:\r\n\r\n    foreach inputs as $in (0; .+1; \r\n      if . == 2 then $in | .pwd_sha1 = &quot;NEW_HASH&quot; \r\n      else $in end)",
                "title": "Handling multiple top level elements with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1546822586,
        "creation_date": 1546814453,
        "last_edit_date": 1546822586,
        "question_id": 54066590,
        "body_markdown": "I&#39;m trying to modify the `deluge` `web.conf` file with `jq` and I&#39;m having some issues. The deluge web config seems to be invalid json\r\n\r\n    {\r\n      &quot;file&quot;: 1,\r\n      &quot;format&quot;: 1\r\n    }\r\n    {\r\n      &quot;sidebar_show_zero&quot;: false,\r\n      &quot;show_session_speed&quot;: false,\r\n      &quot;pwd_sha1&quot;: &quot;CHANGEME&quot;,\r\n      &quot;show_sidebar&quot;: true,\r\n      &quot;sessions&quot;: {},\r\n      &quot;enabled_plugins&quot;: [],\r\n      &quot;base&quot;: &quot;/&quot;,\r\n      &quot;first_login&quot;: true,\r\n      &quot;theme&quot;: &quot;gray&quot;,\r\n      &quot;pkey&quot;: &quot;ssl/daemon.pkey&quot;,\r\n      &quot;default_daemon&quot;: &quot;&quot;,\r\n      &quot;cert&quot;: &quot;test&quot;,\r\n      &quot;session_timeout&quot;: 3600,\r\n      &quot;https&quot;: false,\r\n      &quot;interface&quot;: &quot;0.0.0.0&quot;,\r\n      &quot;sidebar_multiple_filters&quot;: true,\r\n      &quot;pwd_salt&quot;: &quot;salt&quot;,\r\n      &quot;port&quot;: 8112\r\n    }\r\n\r\nIt has multiple top level elements which aren&#39;t separated by a comma so if I try to edit the file with `jq` using something like this `jq &#39;.pwd_sha1 = &quot;NEW HASH&quot;&#39; web.conf` I get the following\r\n\r\n    {\r\n      &quot;file&quot;: 1,\r\n      &quot;format&quot;: 1,\r\n      &quot;pwd_sha1&quot;: &quot;NEW HASH&quot;\r\n    }\r\n    {\r\n      &quot;sidebar_show_zero&quot;: false,\r\n      &quot;show_session_speed&quot;: false,\r\n      &quot;pwd_sha1&quot;: &quot;NEW HASH&quot;,\r\n      &quot;show_sidebar&quot;: true,\r\n      &quot;sessions&quot;: {},\r\n      &quot;enabled_plugins&quot;: [],\r\n      &quot;base&quot;: &quot;/&quot;,\r\n      &quot;first_login&quot;: true,\r\n      &quot;theme&quot;: &quot;gray&quot;,\r\n      &quot;pkey&quot;: &quot;ssl/daemon.pkey&quot;,\r\n      &quot;default_daemon&quot;: &quot;&quot;,\r\n      &quot;cert&quot;: &quot;test&quot;,\r\n      &quot;session_timeout&quot;: 3600,\r\n      &quot;https&quot;: false,\r\n      &quot;interface&quot;: &quot;0.0.0.0&quot;,\r\n      &quot;sidebar_multiple_filters&quot;: true,\r\n      &quot;pwd_salt&quot;: &quot;salt&quot;,\r\n      &quot;port&quot;: 8112\r\n    }\r\n\r\n`jq` is adding a new element to the first top level object and changing the second top level element&#39;s value. How can I get this to only change the existing item in the second top level element?",
        "link": "https://stackoverflow.com/questions/54066590/handling-multiple-top-level-elements-with-jq",
        "title": "Handling multiple top level elements with jq"
    },
    {
        "tags": [
            "arrays",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 51201,
                    "reputation": 243376,
                    "user_id": 152948,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/194ef8f807c34a9d7aab0e11a8674768?s=256&d=identicon&r=PG",
                    "display_name": "hobbs",
                    "link": "https://stackoverflow.com/users/152948/hobbs"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1546934916,
                "post_id": 54087481,
                "comment_id": 95007603,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13438358,
                    "reputation": 303,
                    "user_id": 9696176,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-rcLSdYjuTZA/AAAAAAAAAAI/AAAAAAAAASw/NrjaQdhlEgU/s256-rj/photo.jpg",
                    "display_name": "İlker Demirci",
                    "link": "https://stackoverflow.com/users/9696176/%c4%b0lker-demirci"
                },
                "reply_to_user": {
                    "account_id": 51201,
                    "reputation": 243376,
                    "user_id": 152948,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/194ef8f807c34a9d7aab0e11a8674768?s=256&d=identicon&r=PG",
                    "display_name": "hobbs",
                    "link": "https://stackoverflow.com/users/152948/hobbs"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1546935178,
                "post_id": 54087481,
                "comment_id": 95007685,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1546935417,
                "last_edit_date": 1592644375,
                "creation_date": 1546935417,
                "answer_id": 54087685,
                "question_id": 54087481,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `jq -r` to output a string &quot;raw&quot;, without JSON formatting, and use the `@sh` formatter to format your results as a string for shell consumption. Per the jq docs:\n\n&gt; @sh:\n&gt;\n&gt; The  input  is  escaped  suitable  for  use in a command-line for a POSIX shell. If the input is an array, the output will be a series of space-separated strings.\n\nSo can do e.g.\n\n    msgids=($(&lt;test.json jq -r &#39;.logs[]._id | @sh&#39;))\n\nand get the result you want.",
                "title": "Assigning an Array Parsed With jq to Bash Script Array"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1546943071,
                "creation_date": 1546943071,
                "answer_id": 54089767,
                "question_id": 54087481,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From the jq FAQ (https://github.com/stedolan/jq/wiki/FAQ):\r\n\r\n&#119928;: How can a stream of JSON texts produced by jq be converted into a bash array of corresponding values?\r\n\r\nA: One option would be to use mapfile (aka readarray), for example:\r\n\r\n    mapfile -t array &lt;&lt;&lt; $(jq -c &#39;.[]&#39; input.json)\r\n\r\nAn alternative that might be indicative of what to do in other shells is to use read -r within a while loop. The following bash script populates an array, x, with JSON texts. The key points are the use of the -c option, and the use of the bash idiom `while read -r value; do ... done &lt; &lt;(jq .......)`:\r\n\r\n    #!/bin/bash\r\n    x=()\r\n    while read -r value\r\n    do\r\n      x+=(&quot;$value&quot;)\r\n    done &lt; &lt;(jq -c &#39;.[]&#39; input.json)",
                "title": "Assigning an Array Parsed With jq to Bash Script Array"
            },
            {
                "up_vote_count": 35,
                "is_accepted": false,
                "score": 33,
                "last_activity_date": 1587270551,
                "creation_date": 1587270551,
                "answer_id": 61299548,
                "question_id": 54087481,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "We can solve this problem by two ways. They are:\r\n\r\n**Input string:**\r\n```\r\n// test.json\r\n{\r\n    &quot;keys&quot;: [&quot;key1&quot;,&quot;key2&quot;,&quot;key3&quot;]\r\n}\r\n```\r\n\r\n**Approach 1:**\r\n\r\n1) Use `jq -r` (output raw strings, not JSON texts) .\r\n```\r\nKEYS=$(jq -r &#39;.keys&#39; test.json)\r\necho $KEYS\r\n# Output: [ &quot;key1&quot;, &quot;key2&quot;, &quot;key3&quot; ]\r\n```\r\n\r\n2) Use `@sh` (Converts input string to a series of space-separated strings). It removes square brackets[], comma(,) from the string.\r\n```\r\nKEYS=$(&lt;test.json jq -r &#39;.keys | @sh&#39;)\r\necho $KEYS\r\n# Output: &#39;key1&#39; &#39;key2&#39; &#39;key3&#39;\r\n```\r\n\r\n3) Using `tr` to remove single quotes from the string output. To delete specific characters use the -d option in `tr`.\r\n```\r\nKEYS=$((&lt;test.json jq -r &#39;.keys | @sh&#39;)| tr -d \\&#39;) \r\necho $KEYS\r\n# Output: key1 key2 key3\r\n```\r\n\r\n4) We can convert the comma-separated string to the array by placing our string output in a round bracket().\r\nIt also called compound Assignment, where we declare the array with a bunch of values.\r\n```\r\nARRAYNAME=(value1 value2  .... valueN)\r\n```\r\n\r\n```\r\n#!/bin/bash\r\nKEYS=($((&lt;test.json jq -r &#39;.keys | @sh&#39;) | tr -d \\&#39;\\&quot;))\r\n\r\necho &quot;Array size: &quot; ${#KEYS[@]}\r\necho &quot;Array elements: &quot;${KEYS[@]}\r\n\r\n# Output: \r\n# Array size:  3\r\n# Array elements: key1 key2 key3\r\n```\r\n\r\n\r\n**Approach 2:**\r\n\r\n1) Use `jq -r` to get the string output, then use `tr` to delete characters like square brackets, double quotes and comma.\r\n```\r\n#!/bin/bash\r\nKEYS=$(jq -r &#39;.keys&#39; test.json  | tr -d &#39;[],&quot;&#39;)\r\necho $KEYS\r\n\r\n# Output: key1 key2 key3\r\n```\r\n\r\n2) Then we can convert the comma-separated string to the array by placing our string output in a round bracket().\r\n\r\n```\r\n#!/bin/bash\r\nKEYS=($(jq -r &#39;.keys&#39; test.json  | tr -d &#39;[],&quot; &#39;))\r\n\r\necho &quot;Array size: &quot; ${#KEYS[@]}\r\necho &quot;Array elements: &quot;${KEYS[@]}\r\n\r\n# Output:\r\n# Array size:  3\r\n# Array elements: key1 key2 key3\r\n```\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "Assigning an Array Parsed With jq to Bash Script Array"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1627885563,
                "creation_date": 1627885563,
                "answer_id": 68617206,
                "question_id": 54087481,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "++ To resolve this, we can use a very simple approach:\r\n\r\n++ Since I am not aware of you input file, I am creating a file input.json with the following contents:\r\n\r\ninput.json:\r\n\r\n    {\r\n        &quot;keys&quot;: [&quot;key1&quot;,&quot;key2&quot;,&quot;key3&quot;]\r\n    }\r\n\r\n++ Use jq to get the value from the above file input.json:\r\n\r\nCommand: `cat input.json | jq -r &#39;.keys | @sh&#39;`\r\n\r\nOutput: &#39;key1&#39; &#39;key2&#39; &#39;key3&#39;\r\n\r\nExplanation: | @sh removes [ and &quot;\r\n\r\n++ To remove &#39; &#39; as well we use tr\r\n\r\ncommand: `cat input.json | jq -r &#39;.keys | @sh&#39; | tr -d \\&#39;`\r\n\r\nExplanation: use tr delete -d to remove &#39; \r\n\r\n++ To store this in a bash array we use () with `` and print it:\r\n\r\ncommand: \r\n\r\n    KEYS=(`cat input.json | jq -r &#39;.keys | @sh&#39; | tr -d \\&#39;`)\r\n\r\nTo print all the entries of the array: `echo &quot;${KEYS[*]}&quot;`\r\n\r\n",
                "title": "Assigning an Array Parsed With jq to Bash Script Array"
            },
            {
                "up_vote_count": 16,
                "is_accepted": false,
                "score": 16,
                "last_activity_date": 1746042027,
                "last_edit_date": 1746042027,
                "creation_date": 1632079536,
                "answer_id": 69246438,
                "question_id": 54087481,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To correctly parse values that may have newlines (and any other arbitrary (non-NUL) characters) use jq&#39;s &lt;a href=&quot;https://jqlang.github.io/jq/manual/#format-strings-and-escaping:~:text=%40sh&quot;&gt;`@sh`&lt;/a&gt; filter to generate space-separated quoted strings, and Bash&#39;s `declare -a` to parse the quoted strings as array elements. (No pre-processing required)\r\n\r\n`foo.json`:\r\n```json\r\n{&quot;data&quot;: [&quot;$0&quot;, &quot; \\t\\n&quot;, &quot;*&quot;, &quot;\\&quot;&quot;, &quot;&quot;]}\r\n```\r\n\r\n```bash\r\nstr=$(jq -r &#39;.data | @sh&#39; foo.json)\r\ndeclare -a arr=&quot;($str)&quot;   # must be quoted like this\r\n```\r\n\r\n```bash\r\ndeclare -p arr\r\n# declare -a arr=([0]=&quot;\\$0&quot; [1]=$&#39; \\t\\n&#39; [2]=&quot;*&quot; [3]=&quot;\\&quot;&quot; [4]=&quot;&quot;)\r\n```\r\n\r\n## Update: `jq` 1.7 (2023-09) ##\r\nAs of version [1.7](https://github.com/jqlang/jq/releases/tag/jq-1.7), `jq` has a `--raw-output0` option, enabling it to output null-terminated strings which can be read into an array as usual:\r\n\r\n```bash\r\nmapfile -d &#39;&#39; arr &lt; &lt;(jq --raw-output0 &#39;.data[]&#39; foo.json)\r\nwait &quot;$!&quot;  # use in bash-4.4+ to get exit status of the process substitution\r\n```\r\n\r\n## Note on NUL characters in JSON strings ##\r\nJSON strings may contain NUL characters while shell variables cannot. If your JSON input may contain NUL&#39;s, you may need to add some special handling.\r\n\r\n* When using the `@sh` filter, NUL characters from JSON strings will be silently replaced with the sequence `\\0`. Note that this makes the JSON strings `&quot;\\\\0&quot;` and `&quot;\\u0000&quot;` indistinguishable.\r\n\r\n* When using the `--raw-output0` option, NUL characters will trigger an error and `jq` will terminate with an exit status of 5.\r\n\r\n## Reading multiple/nested arrays ##\r\nThe `@sh` filter can be combined with `--raw-output0` to reliably read multiple arrays at once (or a single nested array) as it will produce a NUL-separated list of space-separated quoted strings.\r\n\r\n```bash\r\njson=&#39;[[1,2],[3,4]]&#39; i=0\r\nwhile read -r -d &#39;&#39;; do\r\n    declare -a &quot;arr$((i++))=($REPLY)&quot;\r\ndone &lt; &lt;(jq --raw-output0 &#39;.[]|@sh&#39; &lt;&lt;&lt;$json)\r\n```\r\n```bash\r\nfor ((n=0; n&lt;i; n++)); { declare -p &quot;arr$n&quot;; }\r\n# declare -a arr0=([0]=&quot;1&quot; [1]=&quot;2&quot;)\r\n# declare -a arr1=([0]=&quot;3&quot; [1]=&quot;4&quot;)\r\n```",
                "title": "Assigning an Array Parsed With jq to Bash Script Array"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 22,
        "last_activity_date": 1746042027,
        "creation_date": 1546934516,
        "last_edit_date": 1585364370,
        "question_id": 54087481,
        "body_markdown": "I parsed a json file with jq like this : \r\n```\r\n# cat test.json | jq &#39;.logs&#39; | jq &#39;.[]&#39; | jq &#39;._id&#39; | jq -s\r\n```\r\nIt returns an array like this : `[34,235,436,546,.....]`\r\n\r\nUsing bash script i described an array : \r\n```\r\n# declare -a msgIds = ...\r\n```\r\nThis array uses `()` instead of `[]` so when I pass the array given above to this array it won&#39;t work.\r\n\r\n`([324,32,45..])` this causes problem. If i remove the `jq -s`, an array forms with only 1 member in it. \r\n\r\nIs there a way to solve this issue?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54087481/assigning-an-array-parsed-with-jq-to-bash-script-array",
        "title": "Assigning an Array Parsed With jq to Bash Script Array"
    },
    {
        "tags": [
            "json",
            "shell",
            "try-catch",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1546936650,
                "creation_date": 1546936650,
                "answer_id": 54087993,
                "question_id": 54087732,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is more than one way to achieve this with jq. You could use conditionals and branching but I think the simplest way is using `try-catch` without the `catch` to just silence any error. The documentation is at the end of [Conditionals and Comparisons][1]\r\n\r\nHere is [an example][2] that will simply omit the error and only print the UUIDs if there is no error for that object:\r\n\r\n`.entries[] | select(.icon | try contains(&quot;BBC&quot;)) | .uuid`\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/v1.6/#ConditionalsandComparisons\r\n  [2]: https://jqplay.org/s/nA2ez_Y8l3",
                "title": "Use JQ &quot;contains&quot; and suppress errors when key not found"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1546952922,
                "last_edit_date": 1546952922,
                "creation_date": 1546947323,
                "answer_id": 54090988,
                "question_id": 54087732,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can preselect only objects that have the `icon` key with `has(&quot;icon&quot;)`.\r\n\r\nFrom the [jq 1.5 Manual](https://stedolan.github.io/jq/manual/v1.5/#has(key)):\r\n\r\n&gt; `has(key)` \r\n&gt; \r\n&gt; The builtin function `has` returns whether the input object\r\n&gt; has the given key, or the input array has an element at the given\r\n&gt; index.\r\n\r\n\r\n    jq &#39;.entries[] | select(has(&quot;icon&quot;)) | select(.icon | contains(&quot;BBC&quot;)).uuid&#39; file\r\n\r\nHowever, it will output an error if your object has `&quot;icon&quot;:null` in which case you could use:\r\n\r\n    jq &#39;.entries[] | select(.icon != null) | select(.icon | contains(&quot;BBC&quot;)).uuid&#39; file\r\n\r\n\r\n",
                "title": "Use JQ &quot;contains&quot; and suppress errors when key not found"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 7,
        "last_activity_date": 1546990211,
        "creation_date": 1546935608,
        "last_edit_date": 1546990211,
        "question_id": 54087732,
        "body_markdown": "I am trying to get the value based on the &quot;contains&quot; value of another key in the same object\r\n\r\nI have already tried a code and it works and outputs the result that I want, but some objects in the JSON do not have this key as such I get:\r\n\r\n`jq: error (at &lt;stdin&gt;:1): null (null) and string (&quot;BBC&quot;) cannot have their containment checked`\r\n\r\nor the reason for this error are the arrays in other keys, I am not sure\r\n\r\nUsing:\r\n\r\n`jq &#39;.entries[] | select(.icon | contains(&quot;BBC&quot;)) | .uuid&#39;`\r\n\r\n*I want the UUID of the found result with no errors and store it as a variable in shell*\r\n\r\n`&quot;174501xxxxxxxxxxxxxe6342a03&quot;` \r\n\r\nInput file that is piped\r\n\r\n    {  \r\n       &quot;entries&quot;:[  \r\n          {  \r\n             &quot;uuid&quot;:&quot;174501xxxxxxxxxxxxxe6342a03&quot;,\r\n             &quot;enabled&quot;:true,\r\n             &quot;autoname&quot;:true,\r\n             &quot;name&quot;:&quot;BBC&quot;,\r\n             &quot;number&quot;:0,\r\n             &quot;icon&quot;:&quot;file:///logos/BBC.png&quot;,\r\n             &quot;icon_public_url&quot;:&quot;imagecache/1097&quot;,\r\n             &quot;epgauto&quot;:true,\r\n             &quot;epggrab&quot;:[  ],\r\n             &quot;dvr_pre_time&quot;:0,\r\n             &quot;dvr_pst_time&quot;:0,\r\n             &quot;epg_running&quot;:-1,\r\n             &quot;services&quot;:[  ],\r\n             &quot;tags&quot;:[  ],\r\n             &quot;bouquet&quot;:&quot;&quot;\r\n          },\r\n          {  \r\n             &quot;uuid&quot;:&quot;174501xxxxxxxxxxxxxe6342a04&quot;,\r\n             &quot;enabled&quot;:true,\r\n             &quot;autoname&quot;:true,\r\n             &quot;name&quot;:&quot;ABC&quot;,\r\n             &quot;number&quot;:0,\r\n             &quot;icon_public_url&quot;:&quot;imagecache/1098&quot;,\r\n             &quot;epgauto&quot;:true,\r\n             &quot;epggrab&quot;:[  ],\r\n             &quot;dvr_pre_time&quot;:0,\r\n             &quot;dvr_pst_time&quot;:0,\r\n             &quot;epg_running&quot;:-1,\r\n             &quot;services&quot;:[  ],\r\n             &quot;tags&quot;:[  ],\r\n             &quot;bouquet&quot;:&quot;&quot;\r\n          }...\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54087732/use-jq-contains-and-suppress-errors-when-key-not-found",
        "title": "Use JQ &quot;contains&quot; and suppress errors when key not found"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1546955775,
                "creation_date": 1546955775,
                "answer_id": 54093362,
                "question_id": 54092267,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way to accomplish the task - first create an object with the fields of interest, and then update `.tags`:\r\n\r\n    .entries[]\r\n    | select(.uuid==&quot;4a05&quot;) \r\n    | {tags, uuid, number: &quot;mynew##&quot;}\r\n    | .tags += [&quot;MYNEWVALUE&quot;]",
                "title": "Stripping JSON element and adding a new one to it"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1546955775,
        "creation_date": 1546952104,
        "question_id": 54092267,
        "body_markdown": "I am trying to take an existing JSON element and create a new one with an added value for a key. \r\n\r\nI know I can use a multitude of other tools to do this but I am wondering if this is possible with jq alone\r\n\r\ninput json file:\r\n\r\n    {\r\n      &quot;entries&quot;: [\r\n        {\r\n          &quot;uuid&quot;: &quot;1a03&quot;,\r\n          &quot;enabled&quot;: true,\r\n          &quot;autoname&quot;: true,\r\n          &quot;name&quot;: &quot;LBC&quot;,\r\n          &quot;number&quot;: 0,\r\n          &quot;epgauto&quot;: true,\r\n          &quot;epggrab&quot;: [],\r\n          &quot;dvr_pre_time&quot;: 0,\r\n          &quot;dvr_pst_time&quot;: 0,\r\n          &quot;epg_running&quot;: -1,\r\n          &quot;services&quot;: [\r\n            &quot;ea8&quot;\r\n          ],\r\n          &quot;tags&quot;: [\r\n            &quot;0a7&quot;\r\n          ],\r\n          &quot;bouquet&quot;: &quot;&quot;\r\n        },\r\n        {\r\n          &quot;uuid&quot;: &quot;4a05&quot;,\r\n          &quot;enabled&quot;: true,\r\n          &quot;autoname&quot;: true,\r\n          &quot;name&quot;: &quot;Radio X&quot;,\r\n          &quot;number&quot;: 0,\r\n          &quot;epgauto&quot;: true,\r\n          &quot;epggrab&quot;: [],\r\n          &quot;dvr_pre_time&quot;: 0,\r\n          &quot;dvr_pst_time&quot;: 0,\r\n          &quot;epg_running&quot;: -1,\r\n          &quot;services&quot;: [\r\n            &quot;9d36&quot;\r\n          ],\r\n          &quot;tags&quot;: [\r\n            &quot;08fa7&quot;\r\n          ],\r\n          &quot;bouquet&quot;: &quot;&quot;\r\n        },...]\r\n    }\r\n\r\nI then filter this for the object that I want which then returns a single object.\r\n\r\nI have unsuccessfully tried using map &quot;+&quot; operator to add values I think my syntax might be wrong\r\n\r\n\r\nI am using this to filter on the object I want\r\n\r\n`.entries[] | select(.uuid==&quot;4a05&quot;)`\r\n\r\nI want to create the following output if I ended up filtering on `uuid=4a05`\r\n\r\n`[{&quot;tags&quot;:[&quot;08fa7&quot;,&quot;MYNEWVALUE&quot;],&quot;number&quot;:mynew##,&quot;uuid&quot;:&quot;4a05&quot;}]`\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54092267/stripping-json-element-and-adding-a-new-one-to-it",
        "title": "Stripping JSON element and adding a new one to it"
    },
    {
        "tags": [
            "bash",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11381172,
                    "reputation": 26772,
                    "user_id": 8344060,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/1UbPk.png?s=256",
                    "display_name": "kvantour",
                    "link": "https://stackoverflow.com/users/8344060/kvantour"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1546955211,
                "post_id": 54092824,
                "comment_id": 95018269,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1965184,
                    "reputation": 72175,
                    "user_id": 1765658,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f2dcfe3194de7a9e1a1cdaa81933b307?s=256&d=identicon&r=PG",
                    "display_name": "F. Hauri  - Give Up GitHub",
                    "link": "https://stackoverflow.com/users/1765658/f-hauri-give-up-github"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1546955673,
                "post_id": 54092824,
                "comment_id": 95018551,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547010554,
                "post_id": 54092824,
                "comment_id": 95039603,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1546956624,
                "last_edit_date": 1546956624,
                "creation_date": 1546955413,
                "answer_id": 54093255,
                "question_id": 54092824,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are better ways to pass variables to `jq`:\r\n\r\n    $ cat data.test\r\n    {\r\n      &quot;foo&quot;: &quot;noooo&quot;\r\n    }\r\n    $ new=bar\r\n    $ jq --arg new_foo &quot;$new&quot; &#39;.foo |= $new_foo&#39; data.test\r\n    {\r\n      &quot;foo&quot;: &quot;bar&quot;\r\n    }\r\n\r\n",
                "title": "string variable interpolation"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1546957902,
        "creation_date": 1546953940,
        "last_edit_date": 1546957902,
        "question_id": 54092824,
        "body_markdown": "I&#39;ve coded this script:\r\n\r\n    for i in `seq 1 $1`; do\r\n            timestamp=$(uuidgen)\r\n            cat $2.json | jq &#39;.transactionId = &quot;$timestamp&quot;&#39; &gt; $3/$timestamp.json\r\n    done\r\n\r\nMy issue is on `jq &#39;.transactionId = &quot;$timestamp&quot;&#39;` since the content of file is:\r\n\r\n    {\r\n      &quot;transactionId&quot;: &quot;$timestamp&quot;\r\n    }\r\n\r\nAny ideas?\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54092824/string-variable-interpolation",
        "title": "string variable interpolation"
    },
    {
        "tags": [
            "json",
            "select",
            "key",
            "extract",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1546981618,
                "creation_date": 1546981618,
                "answer_id": 54099719,
                "question_id": 54099498,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `to_entries` allows a fundamentally simple solution:\r\n\r\n    .Parameters\r\n    | to_entries[]\r\n    | select(.value | has(&quot;Default&quot;))\r\n    | .key\r\n\r\nBut your approach can also be made to work:\r\n\r\n    .Parameters\r\n    | map_values(has(&quot;Default&quot;))\r\n    | keys_unsorted[] as $k\r\n    | select(.[$k])\r\n    | $k\r\n\r\n",
                "title": "JQ: Getting element id if it contains a key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1546989711,
        "creation_date": 1546980681,
        "last_edit_date": 1546989711,
        "question_id": 54099498,
        "body_markdown": "I am trying to get a list of elements in &quot;Parameters&quot; that have a &quot;Default&quot; key:\r\n\r\n    {\r\n\t&quot;Parameters&quot; : {\r\n\t\t&quot;Ecosystem&quot;: {\r\n\t\t\t&quot;Type&quot;: &quot;String&quot;,\r\n\t\t\t&quot;Description&quot;: &quot;Ecosystem to deploy the resources in to&quot;,\r\n\t\t\t&quot;MinLength&quot;: &quot;1&quot;\r\n\t\t},\r\n\t\t&quot;InstanceTenancy&quot;: {\r\n\t\t\t&quot;Type&quot;: &quot;String&quot;,\r\n\t\t\t&quot;Description&quot;: &quot;EC2 Instance Tenancy&quot;,\r\n\t\t\t&quot;Default&quot;: &quot;default&quot;,\r\n\t\t\t&quot;AllowedValues&quot;: [\r\n\t\t\t\t&quot;default&quot;, &quot;dedicated&quot;\r\n\t\t\t]\r\n\t\t},\r\n\t\t&quot;InstanceSecurityGroups&quot;: {\r\n\t\t\t&quot;Type&quot;: &quot;List&lt;AWS::EC2::SecurityGroup::Id&gt;&quot;,\r\n\t\t\t&quot;Description&quot;: &quot;EC2 Instance Security Groups&quot;,\r\n\t\t\t&quot;MinLength&quot;: &quot;1&quot;\r\n\t\t},\r\n\t\t&quot;InstanceAmi&quot;: {\r\n\t\t\t&quot;Type&quot;: &quot;AWS::EC2::Image::Id&quot;,\r\n\t\t\t&quot;Description&quot;: &quot;AMI to deploy to the EC2 instances&quot;,\r\n\t\t\t&quot;Default&quot;: &quot;ami-11223344&quot;\r\n\t\t}\r\n\t}\r\n}\r\n\r\nThe closest I am getting is `jq &#39;.Parameters | map_values(has(&quot;Default&quot;))&#39;`                                                          \r\n\r\n    {\r\n      &quot;Ecosystem&quot;: false,\r\n      &quot;InstanceTenancy&quot;: true,\r\n      &quot;InstanceSecurityGroups&quot;: false,\r\n      &quot;InstanceAmi&quot;: true\r\n    }\r\n\r\nIs there a way I can get just a list of keys which match this filter? e.g.\r\n\r\n    &quot;InstanceTenancy&quot;\r\n    &quot;InstanceAmi&quot;\r\n\r\n \r\n",
        "link": "https://stackoverflow.com/questions/54099498/jq-getting-element-id-if-it-contains-a-key",
        "title": "JQ: Getting element id if it contains a key"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "flatten"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1546984170,
                "creation_date": 1546984170,
                "answer_id": 54100233,
                "question_id": 54099851,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As it happens, your .list is exactly suited to jq&#39;s `from_entries`, so you can simply write:\r\n\r\n    {a} + (.list|from_entries)\r\n\r\nYour approach, however, can easily be made to work:\r\n\r\n    {a} +  (.list | map({(.Key): .Value}) | add)",
                "title": "Collapse JSON object with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1546988640,
        "creation_date": 1546982244,
        "last_edit_date": 1546988640,
        "question_id": 54099851,
        "body_markdown": "I&#39;m having trouble completing the last piece of this puzzle. I want to flatten a JSON that contains an array with jq. Current Progress: https://jqplay.org/s/fwjTN1CnFc\r\n\r\n\r\nInput:\r\n\r\n    {\r\n        &quot;a&quot;: &quot;1&quot;,\r\n        &quot;list&quot;: \r\n        [\r\n            {\r\n                &quot;Key&quot;: &quot;b&quot;,\r\n                &quot;Value&quot;: &quot;2&quot;\r\n            },\r\n            {\r\n                &quot;Key&quot;: &quot;c&quot;,\r\n                &quot;Value&quot;: &quot;3&quot;\r\n            },\r\n            {\r\n                &quot;Key&quot;: &quot;d&quot;,\r\n                &quot;Value&quot;: &quot;4&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nExpected Output:\r\n\r\n    {\r\n      &quot;a&quot;: &quot;1&quot;,\r\n      &quot;b&quot;: &quot;2&quot;,\r\n      &quot;c&quot;: &quot;3&quot;,\r\n      &quot;d&quot;: &quot;4&quot;\r\n    }\r\n\r\nHere is a link to my current progress. https://jqplay.org/s/fwjTN1CnFc\r\n\r\nI am currently using this query `{a: .a},  (.list | map({(.Key): .Value}) | add) `\r\n\r\nAnd here are my currently incorrect results that I can&#39;t quite get right:\r\n\r\n    {\r\n      &quot;a&quot;: &quot;1&quot;\r\n    }\r\n    {\r\n      &quot;b&quot;: &quot;2&quot;,\r\n      &quot;c&quot;: &quot;3&quot;,\r\n      &quot;d&quot;: &quot;4&quot;\r\n    }\r\nAny help would be awesome!\r\n",
        "link": "https://stackoverflow.com/questions/54099851/collapse-json-object-with-jq",
        "title": "Collapse JSON object with jq"
    },
    {
        "tags": [
            "json",
            "datetime",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1546987994,
                "last_edit_date": 1546987994,
                "creation_date": 1546987509,
                "answer_id": 54100801,
                "question_id": 54100199,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here are two alternatives for solving the problem on a Windows 10 machine:\r\n\r\n### Install Linux for Windows\r\n\r\nThen, once jq has been installed (e.g. using [tag:linuxbrew]), you could use this filter:\r\n\r\n    &quot;2009-12-20 08:00:00&quot;\r\n    | strptime(&quot;%Y-%m-%d %T&quot;)\r\n    | strftime(&quot;%a&quot;)\r\n\r\nIt yields &quot;Sun&quot; (which is correct :-)\r\n\r\n\r\n### Use Zeller&#39;s congruence\r\n\r\n    # Use Zeller&#39;s Congruence to determine the day of the week, given\r\n    # year, month and day as integers in the conventional way.\r\n    # Emit 0 for Saturday, 1 for Sunday, etc.\r\n    #\r\n    def day_of_week($year; $month; $day):\r\n      if $month == 1 or $month == 2 then\r\n        [$month + 12, $year - 1]\r\n      else\r\n        [$month, $year]\r\n      end \r\n      | $day + (13*(.[0] + 1)/5|floor)\r\n        +  (.[1]%100)       + ((.[1]%100)/4|floor)\r\n        +  (.[1]/400|floor) - 2*(.[1]/100|floor) \r\n      | . % 7 ;\r\n    \r\n    \r\n    &quot;2009-12-20 08:00:00&quot;\r\n    | capture(&quot;(?&lt;Y&gt;\\\\d+)-(?&lt;m&gt;\\\\d+)-(?&lt;d&gt;\\\\d+)&quot;)\r\n    | map_values(tonumber)\r\n    | day_of_week(.Y; .m; .d) \r\n\r\nThis yields 1, signifying Sunday.\r\n\r\n",
                "title": "jq &quot;strptime/1 is not implemented on this platform&quot; when trying to use &#39;fromdate&#39;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1546987994,
        "creation_date": 1546983991,
        "question_id": 54100199,
        "body_markdown": "i run jq v1.6 on Windows 10, \r\n\r\nmy input is &quot;2009-12-20 08:00:00&quot; and i want to get the Day of Week.\r\n\r\nmy test filter is `(&quot;2009-12-20 08:00:00&quot; | sub(&quot; &quot;; &quot;T&quot;) + &quot;Z&quot; | fromdate | gmtime)`\r\nbut all i get is an error: \r\n&gt; jq: error: strptime/1 not implemented on this platform\r\n\r\nTried so many things, but nothing worked.\r\n\r\n`builtins` returns the relevant functions:\r\n\r\n&lt;pre&gt;\r\n[\r\n  &quot;input_line_number/0&quot;,\r\n  &quot;input_filename/0&quot;,\r\n  &quot;now/0&quot;,\r\n  &quot;localtime/0&quot;,\r\n  &quot;gmtime/0&quot;,\r\n  &quot;mktime/0&quot;,\r\n  &quot;strflocaltime/1&quot;,\r\n  &quot;strftime/1&quot;,\r\n  &quot;strptime/1&quot;,\r\n  &quot;stderr/0&quot;,\r\n  &quot;debug/0&quot;,\r\n  &quot;modulemeta/0&quot;,\r\n  &quot;get_jq_origin/0&quot;,\r\n  &quot;get_prog_origin/0&quot;,\r\n  &quot;get_search_list/0&quot;,\r\n  &quot;halt_error/1&quot;,\r\n  &quot;halt/0&quot;,\r\n  &quot;env/0&quot;,\r\n  &quot;format/1&quot;,\r\n  &quot;error/1&quot;,\r\n  &quot;max/0&quot;,\r\n  &quot;min/0&quot;,\r\n  &quot;sort/0&quot;,\r\n  &quot;nan/0&quot;,\r\n  &quot;infinite/0&quot;,\r\n  &quot;isnormal/0&quot;,\r\n  &quot;isnan/0&quot;,\r\n  &quot;isinfinite/0&quot;,\r\n  &quot;type/0&quot;,\r\n  &quot;utf8bytelength/0&quot;,\r\n  &quot;length/0&quot;,\r\n  &quot;contains/1&quot;,\r\n  &quot;has/1&quot;,\r\n  &quot;delpaths/1&quot;,\r\n  &quot;getpath/1&quot;,\r\n  &quot;setpath/2&quot;,\r\n  &quot;implode/0&quot;,\r\n  &quot;explode/0&quot;,\r\n  &quot;split/1&quot;,\r\n  &quot;rtrimstr/1&quot;,\r\n  &quot;ltrimstr/1&quot;,\r\n  &quot;endswith/1&quot;,\r\n  &quot;startswith/1&quot;,\r\n  &quot;keys_unsorted/0&quot;,\r\n  &quot;keys/0&quot;,\r\n  &quot;tostring/0&quot;,\r\n  &quot;tonumber/0&quot;,\r\n  &quot;fromjson/0&quot;,\r\n  &quot;tojson/0&quot;,\r\n  &quot;modf/0&quot;,\r\n  &quot;frexp/0&quot;,\r\n  &quot;ldexp/2&quot;,\r\n  &quot;trunc/0&quot;,\r\n  &quot;scalbln/2&quot;,\r\n  &quot;round/0&quot;,\r\n  &quot;rint/0&quot;,\r\n  &quot;nexttoward/2&quot;,\r\n  &quot;nextafter/2&quot;,\r\n  &quot;nearbyint/0&quot;,\r\n  &quot;logb/0&quot;,\r\n  &quot;log1p/0&quot;,\r\n  &quot;lgamma/0&quot;,\r\n  &quot;fmod/2&quot;,\r\n  &quot;fmin/2&quot;,\r\n  &quot;fmax/2&quot;,\r\n  &quot;fma/3&quot;,\r\n  &quot;fdim/2&quot;,\r\n  &quot;fabs/0&quot;,\r\n  &quot;expm1/0&quot;,\r\n  &quot;erfc/0&quot;,\r\n  &quot;erf/0&quot;,\r\n  &quot;copysign/2&quot;,\r\n  &quot;ceil/0&quot;,\r\n  &quot;yn/2&quot;,\r\n  &quot;jn/2&quot;,\r\n  &quot;y1/0&quot;,\r\n  &quot;y0/0&quot;,\r\n  &quot;tgamma/0&quot;,\r\n  &quot;tanh/0&quot;,\r\n  &quot;tan/0&quot;,\r\n  &quot;sqrt/0&quot;,\r\n  &quot;sinh/0&quot;,\r\n  &quot;sin/0&quot;,\r\n  &quot;remainder/2&quot;,\r\n  &quot;pow/2&quot;,\r\n  &quot;log2/0&quot;,\r\n  &quot;log10/0&quot;,\r\n  &quot;log/0&quot;,\r\n  &quot;j1/0&quot;,\r\n  &quot;j0/0&quot;,\r\n  &quot;hypot/2&quot;,\r\n  &quot;floor/0&quot;,\r\n  &quot;exp2/0&quot;,\r\n  &quot;exp/0&quot;,\r\n  &quot;cosh/0&quot;,\r\n  &quot;cos/0&quot;,\r\n  &quot;cbrt/0&quot;,\r\n  &quot;atanh/0&quot;,\r\n  &quot;atan2/2&quot;,\r\n  &quot;atan/0&quot;,\r\n  &quot;asinh/0&quot;,\r\n  &quot;asin/0&quot;,\r\n  &quot;acosh/0&quot;,\r\n  &quot;acos/0&quot;,\r\n  &quot;empty/0&quot;,\r\n  &quot;not/0&quot;,\r\n  &quot;path/1&quot;,\r\n  &quot;range/2&quot;,\r\n  &quot;halt_error/0&quot;,\r\n  &quot;error/0&quot;,\r\n  &quot;map/1&quot;,\r\n  &quot;select/1&quot;,\r\n  &quot;sort_by/1&quot;,\r\n  &quot;group_by/1&quot;,\r\n  &quot;unique/0&quot;,\r\n  &quot;unique_by/1&quot;,\r\n  &quot;max_by/1&quot;,\r\n  &quot;min_by/1&quot;,\r\n  &quot;add/0&quot;,\r\n  &quot;del/1&quot;,\r\n  &quot;map_values/1&quot;,\r\n  &quot;recurse/1&quot;,\r\n  &quot;recurse/2&quot;,\r\n  &quot;recurse/0&quot;,\r\n  &quot;recurse_down/0&quot;,\r\n  &quot;to_entries/0&quot;,\r\n  &quot;from_entries/0&quot;,\r\n  &quot;with_entries/1&quot;,\r\n  &quot;reverse/0&quot;,\r\n  &quot;indices/1&quot;,\r\n  &quot;index/1&quot;,\r\n  &quot;rindex/1&quot;,\r\n  &quot;paths/0&quot;,\r\n  &quot;paths/1&quot;,\r\n  &quot;any/2&quot;,\r\n  &quot;any/1&quot;,\r\n  &quot;any/0&quot;,\r\n  &quot;all/2&quot;,\r\n  &quot;all/1&quot;,\r\n  &quot;all/0&quot;,\r\n  &quot;isfinite/0&quot;,\r\n  &quot;arrays/0&quot;,\r\n  &quot;objects/0&quot;,\r\n  &quot;iterables/0&quot;,\r\n  &quot;booleans/0&quot;,\r\n  &quot;numbers/0&quot;,\r\n  &quot;normals/0&quot;,\r\n  &quot;finites/0&quot;,\r\n  &quot;strings/0&quot;,\r\n  &quot;nulls/0&quot;,\r\n  &quot;values/0&quot;,\r\n  &quot;scalars/0&quot;,\r\n  &quot;scalars_or_empty/0&quot;,\r\n  &quot;leaf_paths/0&quot;,\r\n  &quot;join/1&quot;,\r\n  &quot;flatten/1&quot;,\r\n  &quot;flatten/0&quot;,\r\n  &quot;range/1&quot;,\r\n  &quot;fromdateiso8601/0&quot;,\r\n  &quot;todateiso8601/0&quot;,\r\n  &quot;fromdate/0&quot;,\r\n  &quot;todate/0&quot;,\r\n  &quot;match/2&quot;,\r\n  &quot;match/1&quot;,\r\n  &quot;test/2&quot;,\r\n  &quot;test/1&quot;,\r\n  &quot;capture/2&quot;,\r\n  &quot;capture/1&quot;,\r\n  &quot;scan/1&quot;,\r\n  &quot;splits/2&quot;,\r\n  &quot;splits/1&quot;,\r\n  &quot;split/2&quot;,\r\n  &quot;sub/2&quot;,\r\n  &quot;sub/3&quot;,\r\n  &quot;gsub/3&quot;,\r\n  &quot;gsub/2&quot;,\r\n  &quot;range/3&quot;,\r\n  &quot;while/2&quot;,\r\n  &quot;until/2&quot;,\r\n  &quot;limit/2&quot;,\r\n  &quot;isempty/1&quot;,\r\n  &quot;first/1&quot;,\r\n  &quot;last/1&quot;,\r\n  &quot;nth/2&quot;,\r\n  &quot;first/0&quot;,\r\n  &quot;last/0&quot;,\r\n  &quot;nth/1&quot;,\r\n  &quot;combinations/0&quot;,\r\n  &quot;combinations/1&quot;,\r\n  &quot;transpose/0&quot;,\r\n  &quot;in/1&quot;,\r\n  &quot;inside/1&quot;,\r\n  &quot;input/0&quot;,\r\n  &quot;repeat/1&quot;,\r\n  &quot;inputs/0&quot;,\r\n  &quot;ascii_downcase/0&quot;,\r\n  &quot;ascii_upcase/0&quot;,\r\n  &quot;truncate_stream/1&quot;,\r\n  &quot;fromstream/1&quot;,\r\n  &quot;tostream/0&quot;,\r\n  &quot;bsearch/1&quot;,\r\n  &quot;walk/1&quot;,\r\n  &quot;INDEX/2&quot;,\r\n  &quot;INDEX/1&quot;,\r\n  &quot;JOIN/2&quot;,\r\n  &quot;JOIN/3&quot;,\r\n  &quot;JOIN/4&quot;,\r\n  &quot;IN/1&quot;,\r\n  &quot;IN/2&quot;,\r\n  &quot;drem/2&quot;,\r\n  &quot;exp10/0&quot;,\r\n  &quot;gamma/0&quot;,\r\n  &quot;pow10/0&quot;,\r\n  &quot;scalb/2&quot;,\r\n  &quot;significand/0&quot;,\r\n  &quot;lgamma_r/0&quot;,\r\n  &quot;builtins/0&quot;\r\n]\r\n\r\n&lt;/pre&gt;",
        "link": "https://stackoverflow.com/questions/54100199/jq-strptime-1-is-not-implemented-on-this-platform-when-trying-to-use-fromdate",
        "title": "jq &quot;strptime/1 is not implemented on this platform&quot; when trying to use &#39;fromdate&#39;"
    },
    {
        "tags": [
            "json",
            "xml",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 26013,
                    "reputation": 109709,
                    "user_id": 67392,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/95e28ac250c4604a6f9d7e34705c3259?s=256&d=identicon&r=PG",
                    "display_name": "Richard",
                    "link": "https://stackoverflow.com/users/67392/richard"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1547026382,
                "post_id": 54106880,
                "comment_id": 95046047,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 47525,
                    "reputation": 5271,
                    "user_id": 140823,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://www.gravatar.com/avatar/f3dc06f587d1ff4c7366b102bfda9204?s=256&d=identicon&r=PG",
                    "display_name": "monch1962",
                    "link": "https://stackoverflow.com/users/140823/monch1962"
                },
                "reply_to_user": {
                    "account_id": 26013,
                    "reputation": 109709,
                    "user_id": 67392,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/95e28ac250c4604a6f9d7e34705c3259?s=256&d=identicon&r=PG",
                    "display_name": "Richard",
                    "link": "https://stackoverflow.com/users/67392/richard"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547026501,
                "post_id": 54106880,
                "comment_id": 95046114,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10162,
                    "reputation": 947146,
                    "user_id": 19068,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1d2d3229ed1961d2bd81853242493247?s=256&d=identicon&r=PG",
                    "display_name": "Quentin",
                    "link": "https://stackoverflow.com/users/19068/quentin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547026986,
                "post_id": 54106880,
                "comment_id": 95046413,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 47525,
                    "reputation": 5271,
                    "user_id": 140823,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://www.gravatar.com/avatar/f3dc06f587d1ff4c7366b102bfda9204?s=256&d=identicon&r=PG",
                    "display_name": "monch1962",
                    "link": "https://stackoverflow.com/users/140823/monch1962"
                },
                "reply_to_user": {
                    "account_id": 10162,
                    "reputation": 947146,
                    "user_id": 19068,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1d2d3229ed1961d2bd81853242493247?s=256&d=identicon&r=PG",
                    "display_name": "Quentin",
                    "link": "https://stackoverflow.com/users/19068/quentin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547027712,
                "post_id": 54106880,
                "comment_id": 95046886,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26013,
                    "reputation": 109709,
                    "user_id": 67392,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/95e28ac250c4604a6f9d7e34705c3259?s=256&d=identicon&r=PG",
                    "display_name": "Richard",
                    "link": "https://stackoverflow.com/users/67392/richard"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547027796,
                "post_id": 54106880,
                "comment_id": 95046940,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1547029339,
                "last_edit_date": 1547029339,
                "creation_date": 1547027199,
                "answer_id": 54107187,
                "question_id": 54106880,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `--arg` to define a variable; you can use `&quot;$(&lt;...)&quot;` to read a file and provide the argument.\r\n\r\n    echo &quot;$JSON_STRING&quot; | jq --arg xml &quot;$(&lt;&quot;$XML_FILENAME&quot;)&quot; &#39;.xml=($xml | @html)&#39;\r\n\r\nHowever, you likely don&#39;t need XML escaping, as noted in comments; leaving that out gives you\r\n\r\n    echo &quot;$JSON_STRING&quot; | jq --arg xml &quot;$(&lt;&quot;$XML_FILENAME&quot;)&quot; &#39;.xml=$xml&#39;\r\n\r\nEDIT: Typo in the second command.",
                "title": "How can I escape an XML string and insert it as a value in JSON via jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1547028963,
                "last_edit_date": 1547028963,
                "creation_date": 1547027226,
                "answer_id": 54107196,
                "question_id": 54106880,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `-R` for reading XML content as raw text, and provide JSON string as an argument to jq.\r\n\r\n    jq -R --argjson jstr &quot;$JSON_STRING&quot; &#39;$jstr + { &quot;xml&quot; : @html }&#39; &quot;$XML_FILENAME&quot;\r\n\r\n`@html` is a shorthand for `. | @html`.",
                "title": "How can I escape an XML string and insert it as a value in JSON via jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1666590619,
        "creation_date": 1547026237,
        "last_edit_date": 1666590619,
        "question_id": 54106880,
        "body_markdown": "I&#39;ve got content in an XML file that looks like:\r\n\r\n    &lt;blah abc=&quot;def&quot;&gt;123&lt;/blah&gt;\r\n\r\nand a JSON string that looks like:\r\n\r\n    {\r\n      &quot;thj&quot;: &quot;abc&quot;\r\n    }\r\nand I want to merge the XML into the JSON using jq to get something like\r\n\r\n    {\r\n      &quot;thj&quot;: &quot;abc&quot;, \r\n      &quot;xml&quot;: &quot;&amp;lt;blah abc=\\&quot;def\\&quot;&amp;gt;123&amp;lt;/blah&amp;gt;&quot;\r\n    }\r\n(hopefully I&#39;ve got that XML escaping correct...)\r\n\r\n\r\nI&#39;m trying commands like\r\n\r\n    echo $JSON_STRING | jq --slurpfile XML_CONTENT $XML_FILENAME --raw-input &#39;@html&#39; &#39;.xml = &quot;($XML_CONTENT)&quot;&#39;\r\nand\r\n\r\n    echo $JSON_STRING | jq @html &#39;.xml&#39; &lt;&lt;&lt; $XML_FILE_CONTENT\r\nand\r\n\r\n    echo $JSON_STRING | jq --raw-input --slurpfile XML_CONTENT $XML_FILENAME &#39;.xml = ($XML_CONTENT[0] | @html)\r\nbut I keep getting jq errors\r\n\r\nI think I&#39;m close to having the right answer... Help!",
        "link": "https://stackoverflow.com/questions/54106880/how-can-i-escape-an-xml-string-and-insert-it-as-a-value-in-json-via-jq",
        "title": "How can I escape an XML string and insert it as a value in JSON via jq?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "flatten"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1547040128,
                "creation_date": 1547040128,
                "answer_id": 54111155,
                "question_id": 54110870,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq -c &#39;[.[] | range(.children|length) as $i | [.parent, $i, .children[$i]]]&#39; file\r\nyields:\r\n\r\n    [[&quot;x&quot;,0,&quot;a&quot;],[&quot;x&quot;,1,&quot;b&quot;],[&quot;y&quot;,0,&quot;c&quot;],[&quot;y&quot;,1,&quot;d&quot;],[&quot;y&quot;,2,&quot;e&quot;]]",
                "title": "How to map json item value to sibling array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1547041020,
        "creation_date": 1547039227,
        "last_edit_date": 1547041020,
        "question_id": 54110870,
        "body_markdown": "Having json like\r\n\r\n    [\r\n      {\r\n        &quot;parent&quot;: &quot;x&quot;,\r\n        &quot;children&quot;: [&quot;a&quot;, &quot;b&quot;]\r\n      },\r\n      {\r\n        &quot;parent&quot;: &quot;y&quot;,\r\n        &quot;children&quot;: [&quot;c&quot;, &quot;d&quot;, &quot;e&quot;]\r\n      }\r\n    ]\r\n\r\nhow to transform it with jq to the array of &quot;[parent, child_order_number, child]&quot; items like\r\n\r\n    [\r\n      [&quot;x&quot;, 0, &quot;a&quot;],\r\n      [&quot;x&quot;, 1, &quot;b&quot;],\r\n      [&quot;y&quot;, 0, &quot;c&quot;],\r\n      [&quot;y&quot;, 1, &quot;d&quot;],\r\n      [&quot;y&quot;, 2, &quot;e&quot;]\r\n    ]\r\n\r\n?",
        "link": "https://stackoverflow.com/questions/54110870/how-to-map-json-item-value-to-sibling-array-with-jq",
        "title": "How to map json item value to sibling array with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "date",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1547119019,
                "last_edit_date": 1547119019,
                "creation_date": 1547050314,
                "answer_id": 54114172,
                "question_id": 54112485,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an only-jq solution that only calls jq once.\r\nPlease note, though, that it may need tweaking to take into account time zone considerations, error-handling, and potentially other complications:\r\n\r\n    def mins: split(&quot;:&quot;) | map(tonumber) | .[0] * 60 + .[1];\r\n    \r\n    def diff: (.[1] - .[0]) | if . &gt;= 0 then . else 24*60 + . end;\r\n    \r\n    def now_mins: now | gmtime | .[3] * 60 + .[4];\r\n    \r\n    def pairs:\r\n      range(0; length; 2) as $i | [.[$i], .[$i+1] ];\r\n    \r\n    def sigma(s): reduce s as $s (0; . + $s);\r\n    \r\n    .times\r\n    | map( .[0] |= mins )\r\n    | if .[-1][1] == &quot;IN&quot; then . + [ [now_mins, &quot;OUT&quot;] ] else . end\r\n    | sigma(pairs | map(.[0]) | diff)\r\n\r\n",
                "title": "Calculate accumulated times from json with bash script"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1547052917,
                "creation_date": 1547052917,
                "answer_id": 54114953,
                "question_id": 54112485,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you measure times up to the minute, it is enough to compute minutes without messing up with the command `date`. I have an `awk` solution:\r\n\r\n    awk -F: -vIRS=&quot; &quot; -vfmt=&quot;From %5s to %5s: %4u minutes\\n&quot; \\\r\n      &#39;{this=$1*60+$2}a{printf(fmt,at,$0,this-a);a=0;next}{a=this;at=$0}\\\r\n      END{if(a){$0=strftime(&quot;%H:%M&quot;);printf(fmt,at,$0,$1*60+$2-a)}}&#39; &lt;&lt;&lt;&quot;$ALL_TIMES&quot;\r\n\r\nwhich works by defining a colon as field separator and a space as record separator. In this way we get a separate record with two fields for each time. Then\r\n\r\n* `{this=$1*60+$2}` : We compute how many minutes there are in the current record and put them in the variable `this`.\r\n* `a{printf(fmt,at,$0,this-a);a=0;next}` : If the (initially empty) variable `a` is not null nor zero, we are reading an `OUT` entry, so we print what we want, set `a` to zero because the next field will be an `IN` entry, and we continue to the next record.\r\n* `{a=this;at=$0}` : Otherwise, we are reading an `IN` entry, and set `a` to its minutes and `at` to its string representation (needed we will print it, as per previous case).\r\n* `END{if(a){$0=strftime(&quot;%H:%M&quot;);printf(fmt,at,$0,$1*60+$2-a)}}` : at the end, if we still have some dangling `IN` data, we set `$0` to be the properly formatted current time and print what we want.\r\n\r\nAll done.\r\n",
                "title": "Calculate accumulated times from json with bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1547389942,
        "creation_date": 1547044559,
        "question_id": 54112485,
        "body_markdown": "I have data in json format that logs timestamps (hh:mm in 24h format) with an event (In/Out). My goal is to add up all the time differences between an &quot;IN&quot; event and the next &quot;OUT&quot; event.\r\n\r\n\r\nFor simplification I assume that there are no inconsistencies (The first element is always an &quot;IN&quot; and each &quot;IN&quot; is followed by an &quot;OUT&quot;). Exception: If the last element is an &quot;IN&quot;, the calculation has to be done between the current time and the timestamp from the last &quot;IN&quot; event.\r\n\r\nThis is my script so far, which calculates all the timespans, also between an OUT and an IN event. But I need only those that are inbetween an IN and OUT event.\r\n\r\nAny tips what might be more useful here are welcome !\r\n\r\n\r\n    #!/bin/bash\r\n    \r\n    JSON=&#39;{ &quot;times&quot;: [ [ &quot;7:43&quot;, &quot;IN&quot; ], [ &quot;8:26&quot;, &quot;OUT&quot; ], [ &quot;8:27&quot;, &quot;IN&quot; ], [ &quot;9:12&quot;, &quot;OUT&quot; ], [ &quot;9:14&quot;, &quot;IN&quot; ], [ &quot;9:22&quot;, &quot;OUT&quot; ], [ &quot;9:23&quot;, &quot;IN &quot; ], [ &quot;12:12&quot;, &quot;OUT&quot; ], [ &quot;13:12&quot;, &quot;IN&quot; ] ]}&#39;\r\n    IN_TIMES=$(jq &#39;.times | to_entries | .[] | select(.value[1]| tostring | contains(&quot;IN&quot;)) | .value[0]&#39; &lt;&lt;&lt; &quot;$JSON&quot;)\r\n    OUT_TIMES=$(jq &#39;.times | to_entries | .[] | select(.value[1]| tostring | contains(&quot;OUT&quot;)) | .value[0]&#39; &lt;&lt;&lt; &quot;$JSON&quot;)\r\n    ALL_TIMES=$(jq -r &#39;.times| to_entries | .[] | .value[0]&#39; &lt;&lt;&lt; &quot;$JSON&quot;)\r\n    \r\n    prevtime=0\r\n    count=0\r\n    for i in $(echo $ALL_TIMES | sed &quot;s/ / /g&quot;)\r\n    do\r\n        if [[ &quot;$count&quot; -eq 0 ]]; then\r\n    \t (( count++ ))\r\n    \t prevtime=$i\r\n    \t continue\r\n    \telse\r\n    \t (( count++ ))\r\n    \tfi\r\n    \t\t\r\n    \ttime1=`date +%s -d ${prevtime}`\r\n    \ttime2=`date +%s -d ${i}`\r\n    \tdiffsec=`expr ${time2} - ${time1}`\r\n    \t\r\n    \techo From $prevtime to $i: `date +%H:%M -ud @${diffsec}`\r\n    \tprevtime=$i\r\n    \t\r\n    done\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54112485/calculate-accumulated-times-from-json-with-bash-script",
        "title": "Calculate accumulated times from json with bash script"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4552562,
                    "reputation": 5799,
                    "user_id": 3697264,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/5adc5afbd7a1145fdd762d872b4b43bb?s=256&d=identicon&r=PG",
                    "display_name": "SPlatten",
                    "link": "https://stackoverflow.com/users/3697264/splatten"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547114349,
                "post_id": 54125850,
                "comment_id": 95083457,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547119666,
                "post_id": 54125850,
                "comment_id": 95086591,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1547114550,
                "creation_date": 1547114550,
                "answer_id": 54126170,
                "question_id": 54125850,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I suppose you are trying to get the `.info` field inside `.Event` which should have been written as below. Use `-r` for without quotes\r\n\r\n    jq &#39;.Event.info&#39;\r\n",
                "title": "How to extract a specific value from JSON file?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1547138021,
        "creation_date": 1547113502,
        "last_edit_date": 1547114354,
        "question_id": 54125850,
        "body_markdown": "I&#39;m trying to extract a specific value from JSON file.\r\n\r\nthe key value is: &quot;info&quot;: &quot;this is an example&quot; (The key is unique)\r\n\r\nI want to extract only the value: &quot;this is an example&quot;\r\n\r\nMy code: \r\n\r\n    cat 9.json | jq &#39;.info&#39;\r\n\r\nresult:\r\n\r\n    null  \r\n\r\nJSON file example: \r\n\r\n    {\r\n     \t&quot;Event&quot;: {\r\n     \t\t&quot;id&quot;: &quot;13&quot;,\r\n     \t\t&quot;orgc_id&quot;: &quot;1&quot;,\r\n     \t\t&quot;org_id&quot;: &quot;1&quot;,\r\n     \t\t&quot;date&quot;: &quot;2019-01-09&quot;,\r\n     \t\t&quot;threat_level_id&quot;: &quot;3&quot;,\r\n     \t\t&quot;info&quot;: &quot;test9&quot;,\r\n     \t\t&quot;published&quot;: false,\r\n     \t\t&quot;uuid&quot;: &quot;5c35d180&quot;,\r\n     \t\t&quot;attribute_count&quot;: &quot;2&quot;,\r\n     \t\t&quot;analysis&quot;: &quot;0&quot;,\r\n     \t\t&quot;timestamp&quot;: &quot;1547044733&quot;,\r\n     \t\t&quot;distribution&quot;: &quot;1&quot;,\r\n     \t\t&quot;proposal_email_lock&quot;: false,\r\n     \t\t&quot;locked&quot;: false,\r\n     \t\t&quot;publish_timestamp&quot;: &quot;1547034089&quot;,\r\n     \t\t&quot;sharing_group_id&quot;: &quot;0&quot;,\r\n     \t\t&quot;disable_correlation&quot;: false,\r\n     \t\t&quot;extends_uuid&quot;: &quot;&quot;,\r\n     \t\t&quot;event_creator_email&quot;: &quot;o@cyhgfnt.com&quot;,\r\n     \t\t&quot;Org&quot;: {\r\n     \t\t\t&quot;id&quot;: &quot;1&quot;,\r\n     \t\t\t&quot;name&quot;: &quot;Cygfdgfdnt&quot;,\r\n     \t\t\t&quot;uuid&quot;: &quot;5b9f938d-e3a0-4ecb-83b3-0bdeac1b41bc&quot;\r\n     \t\t},\r\n     \t\t&quot;Orgc&quot;: {\r\n     \t\t\t&quot;id&quot;: &quot;1&quot;,\r\n     \t\t\t&quot;name&quot;: &quot;Cyhgfgft&quot;,\r\n     \t\t\t&quot;uuid&quot;: &quot;5b9f938d-e3a0-4ecb-83b3-0bdeac1b41bc&quot;\r\n     \t\t},\r\n     \t\t&quot;Attribute&quot;: [{\r\n     \t\t\t&quot;id&quot;: &quot;292630&quot;,\r\n     \t\t\t&quot;type&quot;: &quot;domain&quot;,\r\n     \t\t\t&quot;category&quot;: &quot;Network activity&quot;,\r\n     \t\t\t&quot;to_ids&quot;: true,\r\n     \t\t\t&quot;uuid&quot;: &quot;5c35dd94-cccc-4086-b386-682823717aa5&quot;,\r\n     \t\t\t&quot;event_id&quot;: &quot;1357&quot;,\r\n     \t\t\t&quot;distribution&quot;: &quot;5&quot;,\r\n     \t\t\t&quot;timestamp&quot;: &quot;1547034584&quot;,\r\n     \t\t\t&quot;comment&quot;: &quot;This is a comment&quot;,\r\n     \t\t\t&quot;sharing_group_id&quot;: &quot;0&quot;,\r\n     \t\t\t&quot;deleted&quot;: false,\r\n     \t\t\t&quot;disable_correlation&quot;: false,\r\n     \t\t\t&quot;object_id&quot;: &quot;0&quot;,\r\n     \t\t\t&quot;object_relation&quot;: null,\r\n     \t\t\t&quot;value&quot;: &quot;dodskj.com&quot;,\r\n     \t\t\t&quot;Galaxy&quot;: [],\r\n     \t\t\t&quot;ShadowAttribute&quot;: [],\r\n     \t\t\t&quot;Tag&quot;: [{\r\n     \t\t\t\t&quot;id&quot;: &quot;223&quot;,\r\n     \t\t\t\t&quot;name&quot;: &quot;kill-chain:Exploitation&quot;,\r\n     \t\t\t\t&quot;colour&quot;: &quot;#a80079&quot;,\r\n     \t\t\t\t&quot;exportable&quot;: true,\r\n     \t\t\t\t&quot;user_id&quot;: &quot;0&quot;,\r\n     \t\t\t\t&quot;hide_tag&quot;: false,\r\n     \t\t\t\t&quot;numerical_value&quot;: null\r\n     \t\t\t}]\r\n     \t\t}, {\r\n     \t\t\t&quot;id&quot;: &quot;292631&quot;,\r\n     \t\t\t&quot;type&quot;: &quot;ip-dst&quot;,\r\n     \t\t\t&quot;category&quot;: &quot;Network activity&quot;,\r\n     \t\t\t&quot;to_ids&quot;: true,\r\n     \t\t\t&quot;uuid&quot;: &quot;5c35dd94-fe90-4ef6-b3a9-682823717aa5&quot;,\r\n     \t\t\t&quot;event_id&quot;: &quot;1357&quot;,\r\n     \t\t\t&quot;distribution&quot;: &quot;5&quot;,\r\n     \t\t\t&quot;timestamp&quot;: &quot;1547044733&quot;,\r\n     \t\t\t&quot;comment&quot;: &quot;comment example&quot;,\r\n     \t\t\t&quot;sharing_group_id&quot;: &quot;0&quot;,\r\n     \t\t\t&quot;deleted&quot;: false,\r\n     \t\t\t&quot;disable_correlation&quot;: false,\r\n     \t\t\t&quot;object_id&quot;: &quot;0&quot;,\r\n     \t\t\t&quot;object_relation&quot;: null,\r\n     \t\t\t&quot;value&quot;: &quot;8.8.6.6&quot;,\r\n     \t\t\t&quot;Galaxy&quot;: [],\r\n     \t\t\t&quot;ShadowAttribute&quot;: [],\r\n     \t\t\t&quot;Tag&quot;: [{\r\n     \t\t\t\t&quot;id&quot;: &quot;247&quot;,\r\n     \t\t\t\t&quot;name&quot;: &quot;maec-malware-capabilities:maec-malware-capability=\\&quot;anti-removal\\&quot;&quot;,\r\n     \t\t\t\t&quot;colour&quot;: &quot;#3f0004&quot;,\r\n     \t\t\t\t&quot;exportable&quot;: true,\r\n     \t\t\t\t&quot;user_id&quot;: &quot;0&quot;,\r\n     \t\t\t\t&quot;hide_tag&quot;: false,\r\n     \t\t\t\t&quot;numerical_value&quot;: null\r\n     \t\t\t}, {\r\n     \t\t\t\t&quot;id&quot;: &quot;465&quot;,\r\n     \t\t\t\t&quot;name&quot;: &quot;osint:lifetime=\\&quot;perpetual\\&quot;&quot;,\r\n     \t\t\t\t&quot;colour&quot;: &quot;#006ebe&quot;,\r\n     \t\t\t\t&quot;exportable&quot;: true,\r\n     \t\t\t\t&quot;user_id&quot;: &quot;0&quot;,\r\n     \t\t\t\t&quot;hide_tag&quot;: false,\r\n     \t\t\t\t&quot;numerical_value&quot;: null\r\n     \t\t\t}]\r\n     \t\t}],\r\n     \t\t&quot;ShadowAttribute&quot;: [],\r\n     \t\t&quot;RelatedEvent&quot;: [],\r\n     \t\t&quot;Galaxy&quot;: [{\r\n     \t\t\t&quot;id&quot;: &quot;3&quot;,\r\n     \t\t\t&quot;uuid&quot;: &quot;698774c7-8022-42c4-917f-8d6e4f06ada3&quot;,\r\n     \t\t\t&quot;name&quot;: &quot;Threat Actor&quot;,\r\n     \t\t\t&quot;type&quot;: &quot;threat-actor&quot;,\r\n     \t\t\t&quot;description&quot;: &quot;Threat actors are characteristics of malicious actors (or adversaries) representing a cyber attack threat including presumed intent and historically observed behaviour.&quot;,\r\n     \t\t\t&quot;version&quot;: &quot;3&quot;,\r\n     \t\t\t&quot;icon&quot;: &quot;user-secret&quot;,\r\n     \t\t\t&quot;namespace&quot;: &quot;misp&quot;,\r\n     \t\t\t&quot;GalaxyCluster&quot;: [{\r\n     \t\t\t\t&quot;id&quot;: &quot;6397&quot;,\r\n     \t\t\t\t&quot;collection_uuid&quot;: &quot;7cdff317-a673-4474-84ec-4f1754947823&quot;,\r\n     \t\t\t\t&quot;type&quot;: &quot;threat-actor&quot;,\r\n     \t\t\t\t&quot;value&quot;: &quot;Sofacy&quot;,\r\n     \t\t\t\t&quot;tag_name&quot;: &quot;misp-galaxy:threat-actor=\\&quot;Sofacy\\&quot;&quot;,\r\n     \t\t\t\t&quot;description&quot;: &quot;The Sofacy Group (also known as APT28, Pawn Storm, Fancy Bear and Sednit) is a cyber espionage group believed to have ties to the Russian government. Likely operating since 2007, the group is known to target government, military, and security organizations. It has been characterized as an advanced persistent threat.&quot;,\r\n     \t\t\t\t&quot;galaxy_id&quot;: &quot;3&quot;,\r\n     \t\t\t\t&quot;source&quot;: &quot;MISP Project&quot;,\r\n     \t\t\t\t&quot;authors&quot;: [&quot;Alexandre Dulaunoy&quot;, &quot;Florian Roth&quot;, &quot;Thomas Schreck&quot;, &quot;Timo Steffens&quot;, &quot;Various&quot;],\r\n     \t\t\t\t&quot;version&quot;: &quot;82&quot;,\r\n     \t\t\t\t&quot;uuid&quot;: &quot;5b4ee3ea-eee3-4c8e-8323-85ae32658754&quot;,\r\n     \t\t\t\t&quot;tag_id&quot;: &quot;608&quot;,\r\n     \t\t\t\t&quot;meta&quot;: {\r\n     \t\t\t\t\t&quot;cfr-suspected-state-sponsor&quot;: [&quot;Russian Federation&quot;],\r\n     \t\t\t\t\t&quot;cfr-suspected-victims&quot;: [&quot;Georgia&quot;, &quot;France&quot;, &quot;Jordan&quot;, &quot;United States&quot;, &quot;Hungary&quot;, &quot;World Anti-Doping Agency&quot;, &quot;Armenia&quot;, &quot;Tajikistan&quot;, &quot;Japan&quot;, &quot;NATO&quot;, &quot;Ukraine&quot;, &quot;Belgium&quot;, &quot;Pakistan&quot;, &quot;Asia Pacific Economic Cooperation&quot;, &quot;International Association of Athletics Federations&quot;, &quot;Turkey&quot;, &quot;Mongolia&quot;, &quot;OSCE&quot;, &quot;United Kingdom&quot;, &quot;Germany&quot;, &quot;Poland&quot;, &quot;European Commission&quot;, &quot;Afghanistan&quot;, &quot;Kazakhstan&quot;, &quot;China&quot;],\r\n     \t\t\t\t\t&quot;cfr-target-category&quot;: [&quot;Government&quot;, &quot;Military&quot;],\r\n     \t\t\t\t\t&quot;cfr-type-of-incident&quot;: [&quot;Espionage&quot;],\r\n     \t\t\t\t\t&quot;country&quot;: [&quot;RU&quot;],\r\n     \t\t\t\t\t&quot;refs&quot;: [&quot;https:\\/\\/en.wikipedia.org\\/wiki\\/Sofacy_Group&quot;, &quot;https:\\/\\/aptnotes.malwareconfig.com\\/web\\/viewer.html?file=..\\/APTnotes\\/2014\\/apt28.pdf&quot;, &quot;http:\\/\\/www.trendmicro.com\\/cloud-content\\/us\\/pdfs\\/security-intelligence\\/white-papers\\/wp-operation-pawn-storm.pdf&quot;, &quot;https:\\/\\/www2.fireeye.com\\/rs\\/848-DID-242\\/images\\/wp-mandiant-matryoshka-mining.pdf&quot;, &quot;https:\\/\\/www.crowdstrike.com\\/blog\\/bears-midst-intrusion-democratic-national-committee\\/&quot;, &quot;http:\\/\\/researchcenter.paloaltonetworks.com\\/2016\\/06\\/unit42-new-sofacy-attacks-against-us-government-agency\\/&quot;, &quot;https:\\/\\/www.cfr.org\\/interactive\\/cyber-operations\\/apt-28&quot;, &quot;https:\\/\\/blogs.microsoft.com\\/on-the-issues\\/2018\\/08\\/20\\/we-are-taking-new-steps-against-broadening-threats-to-democracy\\/&quot;, &quot;https:\\/\\/www.bleepingcomputer.com\\/news\\/security\\/microsoft-disrupts-apt28-hacking-campaign-aimed-at-us-midterm-elections\\/&quot;, &quot;https:\\/\\/www.bleepingcomputer.com\\/news\\/security\\/apt28-uses-lojax-first-uefi-rootkit-seen-in-the-wild\\/&quot;],\r\n     \t\t\t\t\t&quot;synonyms&quot;: [&quot;APT 28&quot;, &quot;APT28&quot;, &quot;Pawn Storm&quot;, &quot;PawnStorm&quot;, &quot;Fancy Bear&quot;, &quot;Sednit&quot;, &quot;TsarTeam&quot;, &quot;Tsar Team&quot;, &quot;TG-4127&quot;, &quot;Group-4127&quot;, &quot;STRONTIUM&quot;, &quot;TAG_0700&quot;, &quot;Swallowtail&quot;, &quot;IRON TWILIGHT&quot;, &quot;Group 74&quot;]\r\n     \t\t\t\t}\r\n     \t\t\t}]\r\n     \t\t}],\r\n     \t\t&quot;Object&quot;: [],\r\n     \t\t&quot;Tag&quot;: [{\r\n     \t\t\t&quot;id&quot;: &quot;608&quot;,\r\n     \t\t\t&quot;name&quot;: &quot;misp-galaxy:threat-actor=\\&quot;Sofacy\\&quot;&quot;,\r\n     \t\t\t&quot;colour&quot;: &quot;#12e000&quot;,\r\n     \t\t\t&quot;exportable&quot;: true,\r\n     \t\t\t&quot;user_id&quot;: &quot;0&quot;,\r\n     \t\t\t&quot;hide_tag&quot;: false,\r\n     \t\t\t&quot;numerical_value&quot;: null\r\n     \t\t}, {\r\n     \t\t\t&quot;id&quot;: &quot;118&quot;,\r\n     \t\t\t&quot;name&quot;: &quot;gdpr:special-categories=\\&quot;health\\&quot;&quot;,\r\n     \t\t\t&quot;colour&quot;: &quot;#3ce600&quot;,\r\n     \t\t\t&quot;exportable&quot;: true,\r\n     \t\t\t&quot;user_id&quot;: &quot;0&quot;,\r\n     \t\t\t&quot;hide_tag&quot;: false,\r\n     \t\t\t&quot;numerical_value&quot;: null\r\n     \t\t}]\r\n     \t}\r\n     }",
        "link": "https://stackoverflow.com/questions/54125850/how-to-extract-a-specific-value-from-json-file",
        "title": "How to extract a specific value from JSON file?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1547125905,
                "creation_date": 1547125905,
                "answer_id": 54129475,
                "question_id": 54129474,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is a shorthand notation for that:\r\n\r\n```\r\njq &#39;.[] | {field_1,field_2}&#39;\r\n```",
                "title": "Shorter construct for filtering object keys in json data using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1547146422,
                "creation_date": 1547146422,
                "answer_id": 54135183,
                "question_id": 54129474,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Depending on your situation, you might want to only include fields that exist in the objects so you&#39;ll have to do some path filtering. You could then just pass in a list of fields to be included. Or even do pattern based filtering.\r\n\r\n    $ jq --arg fields &#39;field_1,field_2&#39; &#39;\r\n    map(with_entries(select(. as {$key} | any($fields|split(&quot;,&quot;)[]; $key == .))))\r\n    &#39; input.json\r\n\r\nAnd as with any filter, they can be made into functions and saved to your `~/.jq` file to be globally available with something like this:\r\n\r\n    def filter_keys($keys):\r\n        with_entries(select(. as {$key} | any($keys[]; $key == .)));\r\n\r\nAnd using it:\r\n\r\n    $ jq --arg fields &#39;field_1,field_2&#39; &#39;map(filter_keys($fields|split(&quot;,&quot;)))&#39;",
                "title": "Shorter construct for filtering object keys in json data using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1547146422,
        "creation_date": 1547125905,
        "question_id": 54129474,
        "body_markdown": "My data is a list of objects with many keys. To explore the data, I only want to look at a restricted set of keys.\r\n\r\n```\r\ninput:\r\n[\r\n    {\r\n        &quot;field_1&quot;:123,\r\n        &quot;field_2&quot;:123,\r\n        &quot;field_3&quot;:123,\r\n        &quot;field_4&quot;:123,\r\n        &quot;field_5&quot;:123,\r\n        ...and so on...\r\n    },\r\n    {\r\n        &quot;field_1&quot;:123,\r\n        &quot;field_2&quot;:123,\r\n        &quot;field_3&quot;:123,\r\n        &quot;field_4&quot;:123,\r\n        &quot;field_5&quot;:123,\r\n        ...and so on...\r\n    },\r\n    ...many objects like this...\r\n]\r\n```\r\nI want a result like:\r\n\r\n```\r\n[\r\n    {\r\n        &quot;field_1&quot;:123,\r\n        &quot;field_2&quot;:123,\r\n    },\r\n    {\r\n        &quot;field_1&quot;:123,\r\n        &quot;field_2&quot;:123,\r\n    },\r\n    ...all objects like this...\r\n]\r\n```\r\n\r\nI know I can do:\r\n\r\n`jq &#39;.[] | {field_1:.field_1,field_2:.field_2}&#39;`\r\n\r\nBut it gets repetitive for data exploration on the command line. Is there a shortcut function available like:\r\n\r\n`jq &#39;.[] | filter_keys(&quot;field_1&quot;,&quot;field_2&quot;)&#39;`\r\n",
        "link": "https://stackoverflow.com/questions/54129474/shorter-construct-for-filtering-object-keys-in-json-data-using-jq",
        "title": "Shorter construct for filtering object keys in json data using jq"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1547151390,
                "post_id": 54136250,
                "comment_id": 95104080,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1547153044,
                "post_id": 54136250,
                "comment_id": 95104739,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1547153322,
                "post_id": 54136250,
                "comment_id": 95104876,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12951928,
                    "reputation": 2404,
                    "user_id": 9363929,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/pSPa8.png?s=256",
                    "display_name": "miqrc",
                    "link": "https://stackoverflow.com/users/9363929/miqrc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547156296,
                "post_id": 54136250,
                "comment_id": 95106090,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1547153148,
        "creation_date": 1547151116,
        "question_id": 54136250,
        "body_markdown": "I would like to rename my package.json &quot;name&quot; value like this:\r\n\r\n    PROJECT_NAME=&quot;MyProject&quot;\r\n    jq &#39;.name = &quot;$PROJECT_NAME&quot;&#39; package.json &gt; tmp.$$.json &amp;&amp; mv tmp.$$.json package.json\r\n\r\nBut it doesn&#39;t work. \r\nWithout the variable works as expected:\r\n\r\n    jq &#39;.name = &quot;MyProject&quot;&#39; package.json &gt; tmp.$$.json &amp;&amp; mv tmp.$$.json package.json\r\n\r\nWhat I am doing wrong?",
        "link": "https://stackoverflow.com/questions/54136250/using-variable-when-editing-a-key-value-pair-with-jq-in-bash",
        "title": "Using variable when editing a key-value pair with jq in bash"
    },
    {
        "tags": [
            "json",
            "select",
            "jq",
            "negation"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1547168703,
                "creation_date": 1547168703,
                "answer_id": 54139051,
                "question_id": 54138923,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using [`contains`][1], like this:\r\n\r\n    jq -r &#39;.Stacks[]|select(.Tags|contains([{&quot;Key&quot;: &quot;Joe Shmo&quot;}])|not).StackName&#39;\r\n\r\nNote: `-r` removes the quotes from output, otherwise `jq` would print `&quot;hello-man&quot;` (within double quotes)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#contains(element)",
                "title": "How can I filter for entries that do NOT contain a key-value pair within a nested array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1547174187,
                "last_edit_date": 1547174187,
                "creation_date": 1547169669,
                "answer_id": 54139155,
                "question_id": 54138923,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    .Stacks[]\r\n    | select( any(.Tags[]; .Key == &quot;Joe Shmo&quot; ) | not)\r\n    | .StackName\r\n\r\nThis checks for equality efficiently (`any` has short-circuit semantics), whereas `contains` would check for containment.",
                "title": "How can I filter for entries that do NOT contain a key-value pair within a nested array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1547178189,
        "creation_date": 1547167586,
        "last_edit_date": 1547178189,
        "question_id": 54138923,
        "body_markdown": "Let&#39;s say I have the following JSON output:\r\n\r\n    {\r\n     &quot;Stacks&quot;: [\r\n            {\r\n                &quot;StackName&quot;: &quot;hello-world&quot;,\r\n                &quot;Tags&quot;: [\r\n                    {\r\n                        &quot;Key&quot;: &quot;environment&quot;,\r\n                        &quot;Value&quot;: &quot;sandbox&quot;\r\n                    },\r\n                    {\r\n                        &quot;Key&quot;: &quot;Joe Shmo&quot;,\r\n                        &quot;Value&quot;: &quot;Dev&quot;\r\n                    }\r\n                ]\r\n            },\r\n            {\r\n    \t        &quot;StackName&quot;: &quot;hello-man&quot;,\r\n                &quot;Tags&quot;: [\r\n                    {\r\n                        &quot;Key&quot;: &quot;environment&quot;,\r\n                        &quot;Value&quot;: &quot;live&quot;\r\n                    },\r\n                    {\r\n                        &quot;Key&quot;: &quot;Tandy&quot;,\r\n                        &quot;Value&quot;: &quot;Dev&quot;\r\n                    }\r\n                ]\r\n            }\r\n        ]\r\n    }\r\n\r\nHow would I write a `jq` query to grab all `StackName`s for stacks that do *NOT* have a `Tags` value `&quot;Key&quot;: &quot;Joe Shmo&quot;`? So the result would return simply `hello-man`.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54138923/how-can-i-filter-for-entries-that-do-not-contain-a-key-value-pair-within-a-neste",
        "title": "How can I filter for entries that do NOT contain a key-value pair within a nested array"
    },
    {
        "tags": [
            "json",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1626286046,
                "post_id": 54141077,
                "comment_id": 120854930,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1547190790,
                "last_edit_date": 1547190790,
                "creation_date": 1547190486,
                "answer_id": 54141840,
                "question_id": 54141077,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, let&#39;s suppose we knew the index of the object with name &quot;Management Configuration&quot; was $i.  Then, assuming the object to be inserted is $o, we would write:\r\n\r\n    .[0:$i+1] + [$o] + .[$i+1:]\r\n\r\n\r\nSo the task boils down to finding $i, which can be done efficiently as follows:\r\n\r\n    first(range(0;length) as $i\r\n          | select(.[$i].name==&quot;Management Configuration&quot;)\r\n          | $i)\r\n\r\n\r\nTaking care to ensure we handle the possibility that the object we expect to occur in the array does not, we can put the pieces together as follows:\r\n\r\n    (first(range(0;length) as $i\r\n     | select(.[$i].name==&quot;Management Configuration&quot;)\r\n     | $i) // null) as $i\r\n    | if $i then .[0:$i+1] + [$o] + .[$i+1:] else . end\r\n   \r\nOne way to set `$o` would be on the command line, e.g. along the lines of:\r\n\r\n    jq --argjson o &#39;....&#39; -f insert.jq 1.json\r\n\r\n## indexof\r\n\r\nIt might make sense to use the following generic def:\r\n\r\n    def indexof(f):\r\n      first(range(0;length) as $i\r\n            | select(.[$i]|f) | $i) // null;\r\n\r\nThe solution then becomes:\r\n\r\n    indexof(.name==&quot;Management Configuration&quot;) as $i\r\n    | if $i then .[0:$i+1] + [$o] + .[$i+1:] else . end\r\n \r\n  ",
                "title": "JQ - how to insert in middle of an array object through jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1547227099,
                "creation_date": 1547227099,
                "answer_id": 54151229,
                "question_id": 54141077,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `map/1` to perform the insertion.  In the mapping, you could check if you&#39;re currently at the node you want to insert after and output it and the new node you wish to insert, otherwise make no further modifications.\r\n\r\n    $ jq --argjson i &#39;...&#39; &#39;map(if .name == &quot;Management Configuration&quot; then ., $i else . end)&#39;",
                "title": "JQ - how to insert in middle of an array object through jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1547227099,
        "creation_date": 1547186146,
        "last_edit_date": 1547188237,
        "question_id": 54141077,
        "body_markdown": "Can you hint on how to insert a new element in middle of an array object through jq..\r\n\r\n1.json file :-\r\n\r\n    [ {\r\n        &quot;name&quot;: &quot;Dependencies&quot;,\r\n        &quot;asyncInstallation&quot;: false,\r\n        &quot;failOnError&quot;: true,\r\n        &quot;yamls&quot;: [\r\n          &quot;dependency.yaml&quot;,\r\n              ]\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Management Configuration&quot;,\r\n        &quot;asyncInstallation&quot;: false,\r\n        &quot;failOnError&quot;: true,\r\n        &quot;yamls&quot;: [\r\n          &quot;mgmt-job.yaml&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Data Configuration&quot;,\r\n        &quot;asyncInstallation&quot;: false,\r\n        &quot;failOnError&quot;: true,\r\n        &quot;yamls&quot;: [\r\n          &quot;data-job.yaml&quot;\r\n        ]\r\n      }, \r\n      {\r\n        &quot;name&quot;: &quot;Tools&quot;,\r\n        &quot;asyncInstallation&quot;: true,\r\n        &quot;failOnError&quot;: false,\r\n        &quot;yamls&quot;: [\r\n          &quot;tools-job.yaml&quot;\r\n        ]\r\n      }\r\n    ]\r\n\r\nI would like to insert the following text post Management Configuration. \r\n\r\n\r\n \r\n\r\n     {\r\n        &quot;name&quot;: &quot;NEW Configuration&quot;,\r\n        &quot;asyncInstallation&quot;: false,\r\n        &quot;failOnError&quot;: true,\r\n        &quot;yamls&quot;: [\r\n          &quot;newfile.yaml&quot;\r\n        ]\r\n      }, \r\n\r\nCan you please suggest how can we do by using jq or sed ?\r\n\r\nthanks\r\nsaravanan\r\n",
        "link": "https://stackoverflow.com/questions/54141077/jq-how-to-insert-in-middle-of-an-array-object-through-jq",
        "title": "JQ - how to insert in middle of an array object through jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 79449,
                    "reputation": 894,
                    "user_id": 225268,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/uENno.jpg?s=256",
                    "display_name": "Awin",
                    "link": "https://stackoverflow.com/users/225268/awin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547190258,
                "post_id": 54141729,
                "comment_id": 95114660,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14973567,
                    "reputation": 347,
                    "user_id": 10809642,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-ks4sRCSMCDI/AAAAAAAAAAI/AAAAAAAAAAc/DkCIfzFZsZ0/s256-rj/photo.jpg",
                    "display_name": "Pradeep Chandran",
                    "link": "https://stackoverflow.com/users/10809642/pradeep-chandran"
                },
                "reply_to_user": {
                    "account_id": 79449,
                    "reputation": 894,
                    "user_id": 225268,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/uENno.jpg?s=256",
                    "display_name": "Awin",
                    "link": "https://stackoverflow.com/users/225268/awin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547190962,
                "post_id": 54141729,
                "comment_id": 95114900,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 79449,
                    "reputation": 894,
                    "user_id": 225268,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/uENno.jpg?s=256",
                    "display_name": "Awin",
                    "link": "https://stackoverflow.com/users/225268/awin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547191995,
                "post_id": 54141729,
                "comment_id": 95115313,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547192822,
                "post_id": 54141729,
                "comment_id": 95115630,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14973567,
                    "reputation": 347,
                    "user_id": 10809642,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-ks4sRCSMCDI/AAAAAAAAAAI/AAAAAAAAAAc/DkCIfzFZsZ0/s256-rj/photo.jpg",
                    "display_name": "Pradeep Chandran",
                    "link": "https://stackoverflow.com/users/10809642/pradeep-chandran"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547192869,
                "post_id": 54141729,
                "comment_id": 95115645,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1568366599,
                "post_id": 54141729,
                "comment_id": 102259377,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1547232028,
                "last_edit_date": 1547232028,
                "creation_date": 1547192234,
                "answer_id": 54142182,
                "question_id": 54141729,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The requirements are a bit fuzzy but when used with the -r command-line option, the following produces the desired output and has the advantage of simplicity, but you might want to tweak it to meet your exact requirements:\r\n\r\n\r\n    .. | objects | select(.type) | &quot;\\&quot;type\\&quot;:\\&quot;\\(.type)\\&quot;&quot;\r\n\r\n",
                "title": "How can I fetch a word from this JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1547232028,
        "creation_date": 1547189930,
        "last_edit_date": 1547190309,
        "question_id": 54141729,
        "body_markdown": "I want to fetch `type` results from this JSON file. How can I do this?\r\n\r\n    {\r\n    \t&quot;inputs&quot;: [{\r\n    \t\t&quot;title&quot;: &quot;vault_beats&quot;,\r\n    \t\t&quot;global&quot;: true,\r\n    \t\t&quot;name&quot;: &quot;Beats&quot;,\r\n    \t\t&quot;content_pack&quot;: null,\r\n    \t\t&quot;created_at&quot;: &quot;2019-01-11T05:31:49.720Z&quot;,\r\n    \t\t&quot;type&quot;: &quot;org.graylog.plugins.beats.Beats2Input&quot;,\r\n    \t\t&quot;creator_user_id&quot;: &quot;admin&quot;,\r\n    \t\t&quot;attributes&quot;: {\r\n    \t\t\t&quot;recv_buffer_size&quot;: 1048576,\r\n    \t\t\t&quot;tcp_keepalive&quot;: false,\r\n    \t\t\t&quot;number_worker_threads&quot;: 1,\r\n    \t\t\t&quot;tls_client_auth_cert_file&quot;: &quot;&quot;,\r\n    \t\t\t&quot;beats_prefix&quot;: false,\r\n    \t\t\t&quot;bind_address&quot;: &quot;0.0.0.0&quot;,\r\n    \t\t\t&quot;tls_cert_file&quot;: &quot;&quot;,\r\n    \t\t\t&quot;port&quot;: 5044,\r\n    \t\t\t&quot;tls_key_file&quot;: &quot;admin&quot;,\r\n    \t\t\t&quot;tls_enable&quot;: false,\r\n    \t\t\t&quot;tls_key_password&quot;: &quot;admin&quot;,\r\n    \t\t\t&quot;tls_client_auth&quot;: &quot;disabled&quot;,\r\n    \t\t\t&quot;override_source&quot;: null\r\n    \t\t},\r\n    \t\t&quot;static_fields&quot;: {},\r\n    \t\t&quot;node&quot;: null,\r\n    \t\t&quot;id&quot;: &quot;5c382a45590801001d742017&quot;\r\n    \t}, {\r\n    \t\t&quot;title&quot;: &quot;vault_beatsl&quot;,\r\n    \t\t&quot;global&quot;: true,\r\n    \t\t&quot;name&quot;: &quot;GELF TCP&quot;,\r\n    \t\t&quot;content_pack&quot;: null,\r\n    \t\t&quot;created_at&quot;: &quot;2019-01-11T05:32:05.869Z&quot;,\r\n    \t\t&quot;type&quot;: &quot;org.graylog2.inputs.gelf.tcp.GELFTCPInput&quot;,\r\n    \t\t&quot;creator_user_id&quot;: &quot;admin&quot;,\r\n    \t\t&quot;attributes&quot;: {\r\n    \t\t\t&quot;recv_buffer_size&quot;: 1048576,\r\n    \t\t\t&quot;tcp_keepalive&quot;: false,\r\n    \t\t\t&quot;use_null_delimiter&quot;: true,\r\n    \t\t\t&quot;number_worker_threads&quot;: 1,\r\n    \t\t\t&quot;tls_client_auth_cert_file&quot;: &quot;&quot;,\r\n    \t\t\t&quot;bind_address&quot;: &quot;0.0.0.0&quot;,\r\n    \t\t\t&quot;tls_cert_file&quot;: &quot;&quot;,\r\n    \t\t\t&quot;decompress_size_limit&quot;: 8388608,\r\n    \t\t\t&quot;port&quot;: 12201,\r\n    \t\t\t&quot;tls_key_file&quot;: &quot;admin&quot;,\r\n    \t\t\t&quot;tls_enable&quot;: false,\r\n    \t\t\t&quot;tls_key_password&quot;: &quot;admin&quot;,\r\n    \t\t\t&quot;max_message_size&quot;: 2097152,\r\n    \t\t\t&quot;tls_client_auth&quot;: &quot;disabled&quot;,\r\n    \t\t\t&quot;override_source&quot;: null\r\n    \t\t},\r\n    \t\t&quot;static_fields&quot;: {},\r\n    \t\t&quot;node&quot;: null,\r\n    \t\t&quot;id&quot;: &quot;5c382a55590801001d74202b&quot;\r\n    \t}],\r\n    \t&quot;total&quot;: 2\r\n    }\r\n\r\nSample Output:- \r\n\r\n    &quot;type&quot;:&quot;org.graylog.plugins.beats.Beats2Input&quot;\r\n    &quot;type&quot;:&quot;org.graylog2.inputs.gelf.tcp.GELFTCPInput&quot;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54141729/how-can-i-fetch-a-word-from-this-json-file",
        "title": "How can I fetch a word from this JSON file"
    },
    {
        "tags": [
            "json",
            "edit",
            "jq",
            "string-concatenation"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1547204642,
                "last_edit_date": 1547204642,
                "creation_date": 1547204443,
                "answer_id": 54145196,
                "question_id": 54145011,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n    jq &#39;.times |= map(join(&quot; &quot;))&#39; file\r\nyields:\r\n\r\n    {\r\n      &quot;times&quot;: [\r\n        &quot;7:29 IN&quot;,\r\n        &quot;10:29 OUT&quot;\r\n      ],\r\n      &quot;foo&quot;: &quot;bar&quot;\r\n    }",
                "title": "Merge json array elements with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1547228486,
        "creation_date": 1547203841,
        "last_edit_date": 1547228486,
        "question_id": 54145011,
        "body_markdown": "I want to merge array values using jq.\r\nIn my input json there&#39;s an array `times` of nested arrays, each having (always) two string elements. I want those two string elements concatenated and the nested array removed so that there&#39;s ony one array left:\r\n\r\nMy input:\r\n\r\n    {\r\n       &quot;times&quot;:[\r\n          [\r\n             &quot;7:29&quot;, &quot;IN&quot;\r\n          ],\r\n          [\r\n             &quot;10:29&quot;, &quot;OUT&quot;\r\n          ]\r\n       ],\r\n       &quot;foo&quot;:&quot;bar&quot;\r\n    }\r\n\r\nMy desired output is:\r\n\r\n    {\r\n       &quot;times&quot;:\r\n       [\r\n             &quot;7:29 IN&quot;, &quot;10:29 OUT&quot;\r\n       ],\r\n       &quot;foo&quot;:&quot;bar&quot;\r\n    }\r\n\r\nThis is how I merged the array elements, what&#39;s missing is to make a json array from it again:\r\n\r\n    jq    &#39;.times | to_entries | .[] | (.value[0]+ &quot; &quot; + .value[1])&#39;",
        "link": "https://stackoverflow.com/questions/54145011/merge-json-array-elements-with-jq",
        "title": "Merge json array elements with jq"
    },
    {
        "tags": [
            "ansible",
            "jinja2",
            "jq",
            "ansible-inventory"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547309771,
                "post_id": 54146501,
                "comment_id": 95152596,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15104198,
                    "reputation": 3,
                    "user_id": 10900349,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/be56cc6a0deae02f2180882301621fa4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Maxim",
                    "link": "https://stackoverflow.com/users/10900349/maxim"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547444697,
                "post_id": 54146501,
                "comment_id": 95181205,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1547212759,
                "creation_date": 1547212759,
                "answer_id": 54147377,
                "question_id": 54146501,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This would probably be easier with a custom Python filter, but here&#39;s a solution using Ansible&#39;s built-in filters:\r\n\r\n    ---\r\n    - hosts: localhost\r\n      gather_facts: false\r\n      vars:\r\n        &quot;base_list&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;kibana&quot;,\r\n                &quot;path&quot;: &quot;kibana/conf/kibana.xml&quot;,\r\n                &quot;src&quot;: &quot;/Users/ansible/inventories/_base/group_vars/kibana/conf/kibana.xml&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;logstash&quot;,\r\n                &quot;path&quot;: &quot;logstash/conf/logstash.yml&quot;,\r\n                &quot;src&quot;: &quot;/Users/ansible/inventories/_base/group_vars/logstash/conf/logstash.yml&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;grafana&quot;,\r\n                &quot;path&quot;: &quot;grafana/conf/grafana.json&quot;,\r\n                &quot;src&quot;: &quot;/Users/ansible/inventories/_base/group_vars/grafana/conf/grafana.json&quot;\r\n            },\r\n        ]\r\n\r\n        &quot;dev_list&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;kibana&quot;,\r\n                &quot;path&quot;: &quot;kibana/conf/kibana.xml&quot;,\r\n                &quot;src&quot;: &quot;/Users/ansible/inventories/dev-st/group_vars/kibana/conf/kibana.xml&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;logstash&quot;,\r\n                &quot;path&quot;: &quot;logstash/conf/jvm.options&quot;,\r\n                &quot;src&quot;: &quot;/Users/ansible/inventories/dev-st/group_vars/logstash/conf/jvm.options&quot;\r\n            }\r\n        ]\r\n      tasks:\r\n        - set_fact:\r\n            end_list: &gt;-\r\n              {{ end_list|default([]) + [\r\n              {\r\n              &#39;name&#39;: item.0.name,\r\n              &#39;path&#39;: item.1.path|ternary([item.0.path, item.1.path], item.0.path),\r\n              &#39;src&#39;: item.1.src|ternary([item.0.src, item.1.src], item.1.src)\r\n              }\r\n              ]}}\r\n          loop: &gt;-\r\n            {{ base_list|zip_longest(dev_list,\r\n            fillvalue={&#39;path&#39;: false, &#39;src&#39;: false})|list }}\r\n\r\n        - debug:\r\n            var: end_list\r\n\r\nThis was a little tricky to put together, so I&#39;ll try to describe the various parts:\r\n\r\nThe loop uses the [zip_longest](https://docs.python.org/3.0/library/itertools.html#itertools.zip_longest) filter.  Given the lists `list1=[1, 2, 3]` and `list2=[11, 12]`, `list1|zip_longest(list2)` would produce `[[1,11], [2,12], [3,None]]` (that is, by default, `zip_longest` will use `None` as a fill value if one list is shorter than the other).  By setting the `fillvalue` parameter, we can use a value other than `None`.  In this case...\r\n\r\n    loop: &gt;-\r\n      {{ base_list|zip_longest(dev_list,\r\n      fillvalue={&#39;path&#39;: false, &#39;src&#39;: false})|list }}\r\n\r\n...We&#39;re setting the fill value to a dictionary with stub values for `path` and `src`, since this makes the rest of the expression easier.\r\n\r\nThe meat of the solution is of course the `set_fact` action, which in simplified form looks like:\r\n\r\n    end_list: &quot;{{ end_list|default([]) + [{...a dictionary...}] }}&quot;\r\n\r\nIn other words, for each iteration of the `loop`, this will append a new dictionary to `end_list`.\r\n\r\nWe create the dictionary like this:\r\n\r\n    {\r\n    &#39;name&#39;: item.0.name,\r\n    &#39;path&#39;: item.1.path|ternary([item.0.path, item.1.path], item.0.path),\r\n    &#39;src&#39;: item.1.src|ternary([item.0.src, item.1.src], item.1.src)\r\n    }\r\n\r\nWe&#39;re using the `ternary` filter here, which evaluates it&#39;s input as a boolean; if it&#39;s `true`, it selects the first argument, otherwise the second. Here we&#39;re taking advantage of the `fillvalue` we passed to the `zip_longest` filter: if `dev_list` is shorter than `base_list`, we&#39;ll have some items for which `item.1.path` and `item.1.src` are `false`, causing the ternary filter to select the second value (either `item.0.path` or `item.1.src`).  In other cases, we build a list by combining the values from each of `base_list` and `dev_list`.\r\n\r\nThe result of running this playbook looks like:\r\n\r\n    ok: [localhost] =&gt; {\r\n        &quot;end_list&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;kibana&quot;, \r\n                &quot;path&quot;: [\r\n                    &quot;kibana/conf/kibana.xml&quot;, \r\n                    &quot;kibana/conf/kibana.xml&quot;\r\n                ], \r\n                &quot;src&quot;: [\r\n                    &quot;/Users/ansible/inventories/_base/group_vars/kibana/conf/kibana.xml&quot;, \r\n                    &quot;/Users/ansible/inventories/dev-st/group_vars/kibana/conf/kibana.xml&quot;\r\n                ]\r\n            }, \r\n            {\r\n                &quot;name&quot;: &quot;logstash&quot;, \r\n                &quot;path&quot;: [\r\n                    &quot;logstash/conf/logstash.yml&quot;, \r\n                    &quot;logstash/conf/jvm.options&quot;\r\n                ], \r\n                &quot;src&quot;: [\r\n                    &quot;/Users/ansible/inventories/_base/group_vars/logstash/conf/logstash.yml&quot;, \r\n                    &quot;/Users/ansible/inventories/dev-st/group_vars/logstash/conf/jvm.options&quot;\r\n                ]\r\n            }, \r\n            {\r\n                &quot;name&quot;: &quot;grafana&quot;, \r\n                &quot;path&quot;: &quot;grafana/conf/grafana.json&quot;, \r\n                &quot;src&quot;: false\r\n            }\r\n        ]\r\n    }\r\n\r\nLet me know if that helps, and whether or not the resulting data structure is what you were looking for. I had to make a few assumptions since your example `end_list` contained invalid syntax, so I took a guess at what you wanted.\r\n",
                "title": "Ansible - How to combine list attributes?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1548062205,
                "creation_date": 1548062205,
                "answer_id": 54286655,
                "question_id": 54146501,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming you had well-formed json and those are properties on the root object, jq is perfectly suited for this.  Group the contents of the arrays by name then generate the appropriate result objects.\r\n\r\n    $ jq &#39;{\r\n        end_combine: (\r\n            .base_list + .dev_list\r\n              | group_by(.name)\r\n              | map({ name: .[0].name, path: map(.path), src: map(.src) })\r\n        )\r\n    }&#39; input.json\r\n\r\n&lt;!-- --&gt;\r\n\r\n    {\r\n      &quot;end_combine&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;grafana&quot;,\r\n          &quot;path&quot;: [\r\n            &quot;grafana/conf/grafana.json&quot;,\r\n            &quot;grafana/conf/nginx.json&quot;,\r\n            &quot;grafana/conf/config.json&quot;\r\n          ],\r\n          &quot;src&quot;: [\r\n            &quot;/Users/ansible/inventories/_base/group_vars/grafana/conf/grafana.json&quot;,\r\n            &quot;/Users/ansible/inventories/_base/group_vars/grafana/conf/nginx.json&quot;,\r\n            &quot;/Users/ansible/inventories/_base/group_vars/grafana/conf/config.json&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;kibana&quot;,\r\n          &quot;path&quot;: [\r\n            &quot;kibana/conf/kibana.xml&quot;,\r\n            &quot;kibana/conf/kibana.xml&quot;\r\n          ],\r\n          &quot;src&quot;: [\r\n            &quot;/Users/ansible/inventories/_base/group_vars/kibana/conf/kibana.xml&quot;,\r\n            &quot;/Users/ansible/inventories/dev-st/group_vars/kibana/conf/kibana.xml&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;logstash&quot;,\r\n          &quot;path&quot;: [\r\n            &quot;logstash/conf/logstash.yml&quot;,\r\n            &quot;logstash/conf/jvm.options&quot;\r\n          ],\r\n          &quot;src&quot;: [\r\n            &quot;/Users/ansible/inventories/_base/group_vars/logstash/conf/logstash.yml&quot;,\r\n            &quot;/Users/ansible/inventories/dev-st/group_vars/logstash/conf/jvm.options&quot;\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n",
                "title": "Ansible - How to combine list attributes?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1548062205,
        "creation_date": 1547209378,
        "last_edit_date": 1547640587,
        "question_id": 54146501,
        "body_markdown": "I have two separate lists. The first is a list (base_list) with basic parameters, and the second is a list (dev_list) with parameters for a specific stand.\r\n\r\n    &quot;base_list&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;kibana&quot;,\r\n            &quot;path&quot;: &quot;kibana/conf/kibana.xml&quot;,\r\n            &quot;src&quot;: &quot;/Users/ansible/inventories/_base/group_vars/kibana/conf/kibana.xml&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;logstash&quot;,\r\n            &quot;path&quot;: &quot;logstash/conf/logstash.yml&quot;,\r\n            &quot;src&quot;: &quot;/Users/ansible/inventories/_base/group_vars/logstash/conf/logstash.yml&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;grafana&quot;,\r\n            &quot;path&quot;: &quot;grafana/conf/grafana.json&quot;,\r\n            &quot;src&quot;: &quot;/Users/ansible/inventories/_base/group_vars/grafana/conf/grafana.json&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;grafana&quot;,\r\n            &quot;path&quot;: &quot;grafana/conf/nginx.json&quot;,\r\n            &quot;src&quot;: &quot;/Users/ansible/inventories/_base/group_vars/grafana/conf/nginx.json&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;grafana&quot;,\r\n            &quot;path&quot;: &quot;grafana/conf/config.json&quot;,\r\n            &quot;src&quot;: &quot;/Users/ansible/inventories/_base/group_vars/grafana/conf/config.json&quot;\r\n        },\r\n    ]\r\n\r\n    &quot;dev_list&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;kibana&quot;,\r\n            &quot;path&quot;: &quot;kibana/conf/kibana.xml&quot;,\r\n            &quot;src&quot;: &quot;/Users/ansible/inventories/dev-st/group_vars/kibana/conf/kibana.xml&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;logstash&quot;,\r\n            &quot;path&quot;: &quot;logstash/conf/jvm.options&quot;,\r\n            &quot;src&quot;: &quot;/Users/ansible/inventories/dev-st/group_vars/logstash/conf/jvm.options&quot;\r\n        }\r\n    ]\r\n\r\nMy goal is to combine these two lists to get one item.name with several item.path and item.src. Paths that look like this:\r\n\r\n    &quot;end_list&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;kibana&quot;, \r\n                &quot;path&quot;: &quot;kibana/conf/kibana.xml&quot;,\r\n                &quot;src&quot;: &quot;/Users/ansible/inventories/dev-st/group_vars/kibana/conf/kibana.xml&quot;\r\n            }, \r\n            {\r\n                &quot;name&quot;: &quot;logstash&quot;, \r\n                &quot;path&quot;: [\r\n                    &quot;logstash/conf/logstash.yml&quot;, \r\n                    &quot;logstash/conf/jvm.options&quot;\r\n                ], \r\n                &quot;src&quot;: [\r\n                    &quot;/Users/ansible/inventories/_base/group_vars/logstash/conf/logstash.yml&quot;, \r\n                    &quot;/Users/ansible/inventories/dev-st/group_vars/logstash/conf/jvm.options&quot;\r\n                ]\r\n            }, \r\n            {\r\n                &quot;name&quot;: &quot;grafana&quot;,\r\n                &quot;path&quot;: [\r\n                    &quot;grafana/conf/grafana.json&quot;,\r\n                    &quot;grafana/conf/nginx.json&quot;,\r\n                    &quot;grafana/conf/config.json&quot;\r\n                ]\r\n                &quot;src&quot;: [\r\n                    &quot;/Users/ansible/inventories/_base/group_vars/grafana/conf/grafana.json&quot;,\r\n                    &quot;/Users/ansible/inventories/_base/group_vars/grafana/conf/nginx.json&quot;,\r\n                    &quot;/Users/ansible/inventories/_base/group_vars/grafana/conf/config.json&quot;\r\n                ]\r\n            },\r\n        ]\r\n\r\nWhat would be the best way to do this?",
        "link": "https://stackoverflow.com/questions/54146501/ansible-how-to-combine-list-attributes",
        "title": "Ansible - How to combine list attributes?"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1547244369,
                "last_edit_date": 1547244369,
                "creation_date": 1547240093,
                "answer_id": 54153917,
                "question_id": 54153245,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the innermost keys are always in the same order, you could use the filter:\r\n\r\n    .[] | [.[][]] | @csv\r\n\r\nOtherwise:\r\n\r\n    .[][]\r\n    | [.phone, .termination, .duration]\r\n    | @csv\r\n\r\nIn either case, you&#39;d probably want to use the -r command-line option to yield:\r\n\r\n    &quot;12345&quot;,&quot;picked-up&quot;,5\r\n    &quot;67891&quot;,&quot;picked-up&quot;,10\r\n    &quot;78912&quot;,&quot;busy&quot;,0\r\n\r\n## Unquoted\r\n\r\nIf you want to suppress the quotation marks, you could use the following, again with the -r option:\r\n\r\n    .[] | [.[][]] | join(&quot;, &quot;)\r\n\r\nor:\r\n\r\n    .[][] | &quot;\\(.phone), \\(.termination), \\(.duration)&quot;\r\n\r\nWith the -r command-line option, these last two yield:\r\n\r\n    12345, picked-up, 5\r\n    67891, picked-up, 10\r\n    78912, busy, 0\r\n\r\n",
                "title": "Can I extract all key values inside second-level curly braces while ignoring values in the first-level of the curly braces"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1547250146,
        "creation_date": 1547236612,
        "last_edit_date": 1547240626,
        "question_id": 54153245,
        "body_markdown": "With JQ I am trying to read/extract the values present in the second-level of the curly braces (.phone, .termination, .duration, while ignoring values present in the first-level of curly braces (12345, 67891 and 78912, which are already repeated inside the second-level braces. Can this be done?\r\n\r\n```\r\n{\r\n\t&quot;12345&quot;:[{\r\n\t\t&quot;phone&quot;: &quot;12345&quot;,\r\n\t\t&quot;termination&quot;: &quot;picked-up&quot;,\r\n\t\t&quot;duration&quot;: 5\r\n\t\t}],\r\n\t&quot;67891&quot;:[{\r\n\t\t&quot;phone&quot;: &quot;67891&quot;,\r\n\t\t&quot;termination&quot;: &quot;picked-up&quot;,\r\n\t\t&quot;duration&quot;: 10\r\n\t}],\r\n\t&quot;78912&quot;:[{\r\n\t\t&quot;phone&quot;: &quot;78912&quot;,\r\n\t\t&quot;termination&quot;: &quot;busy&quot;,\r\n\t\t&quot;duration&quot;: 0\r\n\t}]\r\n}\r\n```\r\n\r\nI&#39;ve tried filtering values by defining the keyword filters that interest me, but I am clearly missing additional first steps. There are the square brackets to consider as well. Ty\r\n\r\n\r\n    cat test.json | jq [.phone, .termination, .duration] | less\r\n\r\n\r\nI&#39;d like to have a line containing comma separated values for the three filters described.\r\n\r\n    12345, picked-up, 5,\r\n    67891, picked-up, 10,\r\n    78912, busy, 0\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54153245/can-i-extract-all-key-values-inside-second-level-curly-braces-while-ignoring-val",
        "title": "Can I extract all key values inside second-level curly braces while ignoring values in the first-level of the curly braces"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10643264,
                    "reputation": 1371,
                    "user_id": 7837563,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/84bd9ecd95886440422f56a8b29c62b6?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Rmahajan",
                    "link": "https://stackoverflow.com/users/7837563/rmahajan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547479751,
                "post_id": 54184147,
                "comment_id": 95197228,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1547479377,
                "creation_date": 1547479377,
                "answer_id": 54184316,
                "question_id": 54184147,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; what am I missing?\r\n\r\nA pair of parentheses:\r\n\r\n    .key + &quot;=&quot; + ( .value|tostring )\r\n\r\nAlternatively, you could use string interpolation, e.g.\r\n\r\n    &quot;\\(.key)=\\(.value)&quot;",
                "title": "jq to_entries string and number cannot be added"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1547479377,
        "creation_date": 1547478783,
        "question_id": 54184147,
        "body_markdown": "I&#39;m not understanding how `to_entries` works in jq. \r\n\r\nI have the following json payload in `payload.json` \r\n\r\n    {&quot;REGION&quot;:&quot;us-east-1&quot;,&quot;EMAIL&quot;:&quot;contain&quot;,&quot;UPDATE&quot;:1}\r\n\r\nwhich I want to convert into `=` delimited keypairs, like so;\r\n\r\n    REGION=us-east-1\r\n    EMAIL=contain\r\n    UPDATE=1\r\n\r\nI was using\r\n\r\n    jq -r &#39;to_entries | .[] | .key + &quot;=&quot; + .value&#39; &lt; payload.json\r\n\r\nBut I get an error\r\n\r\n    jq: error (at &lt;stdin&gt;:0): string (&quot;UPDATE=&quot;) and number (1) cannot be added\r\n\r\nIf I understand correctly, the issue is that the update value is a number, not a string (ie, having them not match types is an issue) so I tried the following, both with the same error;\r\n\r\n    string interpolation:\r\n    jq -r &#39;to_entries | .[] | (.key) + &quot;=&quot; + (.value)&#39; &lt; payload.json\r\n\r\n    tostring:\r\n    jq -r &#39;to_entries | .[] | .key + &quot;=&quot; + .value|tostring&#39; &lt; payload.json\r\n\r\nWhat am I missing?",
        "link": "https://stackoverflow.com/questions/54184147/jq-to-entries-string-and-number-cannot-be-added",
        "title": "jq to_entries string and number cannot be added"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1547481281,
                "post_id": 54184803,
                "comment_id": 95198129,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 365431,
                    "reputation": 5132,
                    "user_id": 2057091,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://i.sstatic.net/7kWv6.png?s=256",
                    "display_name": "Aserre",
                    "link": "https://stackoverflow.com/users/2057091/aserre"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1547481515,
                "post_id": 54184803,
                "comment_id": 95198261,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1547483195,
                "post_id": 54184803,
                "comment_id": 95199233,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1547482134,
                "last_edit_date": 1547482134,
                "creation_date": 1547481611,
                "answer_id": 54184956,
                "question_id": 54184803,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this.\r\n\r\n    jq -c --arg basejq &quot;${base}&quot; \\\r\n        --arg tempvarjq &quot;${tempvar}&quot; \\\r\n        &#39;.auths[$tempvarjq].auth= $basejq&#39; \\\r\n        ../post-auth/docker-auth.json \\\r\n            &gt; ../post-auth/docker-auth.json.tmp &amp;&amp;\r\n    mv  ../post-auth/docker-auth.json.tmp  \\\r\n        ../post-auth/docker-auth.json",
                "title": "jq json path single quotes and variable"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1547483088,
        "creation_date": 1547481099,
        "last_edit_date": 1547481200,
        "question_id": 54184803,
        "body_markdown": "Trying to figure out the syntax for jq.\r\nThis line works absolutely fine:\r\n\r\n    echo $(cat ../post-auth/rkt-auth.json | jq -c --arg user ${vsphere_user} &#39;.credentials.user = $user&#39;) &gt; ../post-auth/rkt-auth.json\r\n\r\nHowever this is not the case when variable is a part of json path:\r\n\r\n    echo $(cat ../post-auth/docker-auth.json | jq -c --arg basejq ${base} --arg tempvarjq ${tempvar} &#39;.auths.$tempvarjq.auth= $basejq&#39;) &gt; ../post-auth/docker-auth.json\r\n\r\nError:\r\n\r\n    jq: error: syntax error, unexpected &#39;$&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .auths.$tempvarjq.auth= $basejq       \r\n    jq: 1 compile error\r\n\r\nAny suggestions how to correct this syntax with that variable?",
        "link": "https://stackoverflow.com/questions/54184803/jq-json-path-single-quotes-and-variable",
        "title": "jq json path single quotes and variable"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1563814087,
                "last_edit_date": 1563814087,
                "creation_date": 1547495747,
                "answer_id": 54188292,
                "question_id": 54187750,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let&#39;s proceed in two steps: first, the (heavy) lifting, and secondly, the (light) trimming.\r\n\r\n### Lifting\r\n\r\n    .emails | map( {email}  + .events[])\r\n\r\nor equivalently:\r\n\r\n    [.emails[] | {email}  + .events[]]\r\n\r\nNotice that `{&quot;email&quot;: .email}` has been abbreviated to `{email}`.\r\n\r\n### Trimming\r\n\r\nWe can delete the &quot;ignore&quot; key using `del(.ignore)`. With an eye to efficiency, we arrive at the following solution:\r\n\r\n    .emails | map( {email}  + (.events[] | del(.ignore) ) )\r\n",
                "title": "jq: Lifting fields from array of objects into the parent object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1563814087,
        "creation_date": 1547493221,
        "last_edit_date": 1547517245,
        "question_id": 54187750,
        "body_markdown": "I have a JSON object an array at the top-level, and each array entry is an object with a nested array of objects as one of the fields.\r\nI&#39;d like to &quot;lift&quot; some fields from the sub-arrays into the objects within the first array. It&#39;s confusing to write, so, here&#39;s my input:\r\n\r\n    { &quot;emails&quot;: [\r\n      { &quot;email&quot;:&quot;foo1@bar.com&quot;,\r\n        &quot;events&quot;:[\r\n          { &quot;type&quot;:&quot;open&quot;, &quot;time&quot;:&quot;t1&quot;, &quot;ignore&quot;:&quot;this&quot; },\r\n          { &quot;type&quot;:&quot;click&quot;, &quot;time&quot;:&quot;t2&quot;, &quot;ignore&quot;:&quot;this&quot; } ] },\r\n      { &quot;email&quot;:&quot;foo2@bar.com&quot;,\r\n        &quot;events&quot;:[\r\n          { &quot;type&quot;:&quot;open&quot;, &quot;time&quot;:&quot;t3&quot;, &quot;ignore&quot;:&quot;this&quot; },\r\n          { &quot;type&quot;:&quot;click&quot;, &quot;time&quot;:&quot;t4&quot;, &quot;ignore&quot;:&quot;this&quot; },\r\n          { &quot;type&quot;:&quot;open&quot;, &quot;time&quot;:&quot;t5&quot;, &quot;ignore&quot;:&quot;this&quot; } ] }\r\n    ] }\r\n\r\nWhat I&#39;d like to receive as output is:\r\n\r\n    [\r\n      { &quot;email&quot;:&quot;foo1@bar.com&quot;, &quot;type&quot;:&quot;open&quot;, &quot;time&quot;:&quot;t1&quot; },\r\n      { &quot;email&quot;:&quot;foo1@bar.com&quot;, &quot;type&quot;:&quot;click&quot;, &quot;time&quot;:&quot;t2&quot; },\r\n      { &quot;email&quot;:&quot;foo2@bar.com&quot;, &quot;type&quot;:&quot;open&quot;, &quot;time&quot;:&quot;t3&quot; },\r\n      { &quot;email&quot;:&quot;foo2@bar.com&quot;, &quot;type&quot;:&quot;click&quot;, &quot;time&quot;:&quot;t4&quot; },\r\n      { &quot;email&quot;:&quot;foo2@bar.com&quot;, &quot;type&quot;:&quot;open&quot;, &quot;time&quot;:&quot;t5&quot; }\r\n    ]\r\n\r\nI can `jq` this with multiple pipes already, like so:\r\n\r\n     [ .emails[] | { email:.email, event:(.events[] | { type:.type, time:.time }) } | { email:.email, type:.event.type, time:.event.time } ]\r\n\r\n... but this seems way too verbose.\r\nIs there an easier way to &#39;lift&#39; those `type` and `time` fields from the deepest objects to the object one-level up?\r\nWhen I try to use the `.events[]` iterator twice, I wind up with the Cartesian product of events, which is wrong :-/\r\n\r\nI must be missing some simpler way (than my &#39;intermediate-object&#39; approach above) to achieve this ... anyone know of a better way?\r\n        ",
        "link": "https://stackoverflow.com/questions/54187750/jq-lifting-fields-from-array-of-objects-into-the-parent-object",
        "title": "jq: Lifting fields from array of objects into the parent object"
    },
    {
        "tags": [
            "json",
            "bash",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1547498720,
                "creation_date": 1547498720,
                "answer_id": 54188908,
                "question_id": 54188847,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This `jq` script might work for you:\r\n\r\n    $ cat file\r\n    {\r\n      &quot;blocks&quot;: {\r\n        &quot;foo_b&quot;: {\r\n          &quot;aaa&quot;: &quot;bbb&quot;\r\n        },\r\n        &quot;bar_b&quot;: {\r\n          &quot;ccc&quot;: &quot;ddd&quot;\r\n        }\r\n      }\r\n    }\r\n\r\n    $ jq -r &#39;.blocks | to_entries[].key&#39; file\r\n    foo_b\r\n    bar_b\r\n\r\n\r\n",
                "title": "Can&#39;t use JQ to get items within JSON"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1547498957,
                "creation_date": 1547498957,
                "answer_id": 54188967,
                "question_id": 54188847,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`keys_unsorted` gives an array of keys. Whence:\r\n\r\n    jq -r &#39;.blocks | keys_unsorted[]&#39; input.json\r\n    xrb_1111111111111111111111111111111111111111111111111117353trpda\r\n    xrb_3t6k35gi95xu6tergt6p69ck76ogmitsa8mnijtpxm9fkcm736xtoncuohr3",
                "title": "Can&#39;t use JQ to get items within JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1547591740,
        "creation_date": 1547498343,
        "last_edit_date": 1547500766,
        "question_id": 54188847,
        "body_markdown": "I have this JSON:\r\n\r\n    {  \r\n      &quot;blocks&quot; : {\r\n        &quot;xrb_1111111111111111111111111111111111111111111111111117353trpda&quot;: {    \r\n            &quot;142A538F36833D1CC78B94E11C766F75818F8B940771335C6C1B8AB880C5BB1D&quot;: &quot;6000000000000000000000000000000&quot;    \r\n        },    \r\n        &quot;xrb_3t6k35gi95xu6tergt6p69ck76ogmitsa8mnijtpxm9fkcm736xtoncuohr3&quot;: {    \r\n            &quot;4C1FEEF0BEA7F50BE35489A1233FE002B212DEA554B55B1B470D78BD8F210C74&quot;: &quot;106370018000000000000000000000000&quot;    \r\n        }  \r\n    }\r\n\r\n\r\nI am having trouble using `jq` in `bash` to read out:\r\n\r\n    xrb_1111111111111111111111111111111111111111111111111117353trpda\r\n    xrb_3t6k35gi95xu6tergt6p69ck76ogmitsa8mnijtpxm9fkcm736xtoncuohr3\r\n\r\nI try to do it on [jqplay](https://jqplay.org/) but not having much luck with it.\r\n\r\nI have tried with [jqplay](https://jqplay.org/) to get the results and manage find but not when its nested this way.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54188847/cant-use-jq-to-get-items-within-json",
        "title": "Can&#39;t use JQ to get items within JSON"
    },
    {
        "tags": [
            "json",
            "bash",
            "types",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 39,
                "is_accepted": true,
                "score": 39,
                "last_activity_date": 1547513106,
                "creation_date": 1547513106,
                "answer_id": 54191249,
                "question_id": 54191177,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `type`:\r\n\r\n    jq -r &#39;[1.23,&quot;abc&quot;,true,[],{},null][]| type&#39; &lt;&lt;&lt; &#39;&quot;&quot;&#39;\r\n    number\r\n    string\r\n    boolean\r\n    array\r\n    object\r\n    null\r\n\r\nIn your example you could check:\r\n\r\n    jq &#39;.id|type==&quot;number&quot;&#39; file.json\r\n\r\nOr use it in a `select` filter to display those ids which are **not** numbers for example:\r\n\r\n    jq &#39;.[]|select(id|type==&quot;number&quot;|not)&#39; file.json\r\n\r\n",
                "title": "Check JSON data type using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1547513117,
                "creation_date": 1547513117,
                "answer_id": 54191252,
                "question_id": 54191177,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `type` function in order to get the value type as a string.\r\n\r\nExample: https://jqplay.org/jq?q=map(type)&amp;j=%5B0%2C%20false%2C%20%5B%5D%2C%20%7B%7D%2C%20null%2C%20%22hello%22%5D",
                "title": "Check JSON data type using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 20,
        "last_activity_date": 1547521237,
        "creation_date": 1547512404,
        "last_edit_date": 1547521237,
        "question_id": 54191177,
        "body_markdown": "I&#39;m trying to check the actual data type of a JSON value belonging to a specific key.\r\n\r\n`test.json`\r\n\r\n    {\r\n        &quot;id&quot;: 50,\r\n        &quot;name&quot;: &quot;Joe&quot;\r\n    }\r\n\r\nI want something analogous to this:\r\n\r\n    $ `jq &#39;typeof(&quot;id&quot;)&#39; &lt; test.json`\r\n    (output)&gt;&gt; string\r\n\r\nIs this possible using `jq`?",
        "link": "https://stackoverflow.com/questions/54191177/check-json-data-type-using-jq",
        "title": "Check JSON data type using jq"
    },
    {
        "tags": [
            "json",
            "debugging",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1547524208,
                "creation_date": 1547524208,
                "answer_id": 54192465,
                "question_id": 54192356,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`awseb-e-ASG` is under .AutoScalingGroups\r\n\r\nso you could use the following filter:\r\n\r\n    .EnvironmentResources.AutoScalingGroups[].Name\r\n\r\n## Debugging\r\nIt usually pays to pay attention to the error message:\r\n\r\n&gt;  jq: error: Cannot index array with string\r\n\r\nThis, in effect, is telling you that `.LaunchConfigurations.Name` is erroneous because .LaunchConfigurations is an array, and therefore cannot have a string-valued key.\r\n\r\n",
                "title": "JSON QUERY parse tip"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1547525884,
        "creation_date": 1547523298,
        "last_edit_date": 1547525884,
        "question_id": 54192356,
        "body_markdown": "just want to get some expert tips on you on how to grab only this from AutoScalingGroups:\r\n\r\n&gt; awseb-e-ASG\r\n\r\nActual JSON Output\r\n\r\n    {\r\n    &quot;EnvironmentResources&quot;: {\r\n        &quot;EnvironmentName&quot;: &quot;MY-APP&quot;,\r\n        &quot;AutoScalingGroups&quot;: [\r\n            {\r\n                &quot;Name&quot;: &quot;awseb-e-ASG&quot;\r\n            }\r\n        ],\r\n        &quot;Triggers&quot;: [],\r\n        &quot;LoadBalancers&quot;: [\r\n            {\r\n                &quot;Name&quot;: &quot;awseb-e-ELB&quot;\r\n            }\r\n        ],\r\n        &quot;Queues&quot;: [],\r\n        &quot;Instances&quot;: [\r\n            {\r\n                &quot;Id&quot;: &quot;i-XXXXXXXXXXXXXXXd&quot;\r\n            }\r\n        ],\r\n        &quot;LaunchConfigurations&quot;: [\r\n            {\r\n                &quot;Name&quot;: &quot;awseb-e-LAUNCH&quot;\r\n            }\r\n        ]\r\n    }\r\n    }\r\n\r\n\r\nI tried several commands but only getting this:\r\n\r\n    jq -r &quot;.EnvironmentResources.LaunchConfigurations&quot;\r\n\r\n    [\r\n     {\r\n      &quot;Name&quot;: &quot;awseb-e-ASG&quot;\r\n     }\r\n    ]\r\n\r\n\r\n    jq -r &quot;.EnvironmentResources.LaunchConfigurations.Name&quot;\r\n    jq: error: Cannot index array with string",
        "link": "https://stackoverflow.com/questions/54192356/json-query-parse-tip",
        "title": "JSON QUERY parse tip"
    },
    {
        "tags": [
            "json",
            "date",
            "grouping",
            "aggregate",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1547577006,
                "creation_date": 1547577006,
                "answer_id": 54204863,
                "question_id": 54199974,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A solution is easily obtained with the following helper function:\r\n\r\n    # $day should be the day (an integer) that defines the cutoff point;\r\n    # input should be a Y-M-D string\r\n    def bucket($day):\r\n      def prev: if .m &gt; 1 then .m -= 1 else .m = 12 | .y -= 1 end;\r\n      def fmt: if .m &lt;= 9 then &quot;\\(.y)-0\\(.m)&quot; else &quot;\\(.y)-\\(.m)&quot; end;\r\n      capture(&quot;(?&lt;y&gt;[0-9]+)-(?&lt;m&gt;[0-9]+)-(?&lt;d&gt;[0-9]+)&quot;)\r\n      | map_values(tonumber)\r\n      | if .d &gt;= $day then . else prev end\r\n      | fmt ;\r\n    \r\nWe now compute the bucket-count pairs:\r\n\r\n    .data\r\n    | (.[0].date | capture(&quot;(?&lt;d&gt;[0-9]+)$&quot;) | .d | tonumber) as $day\r\n    | reduce .[] as $pair ({};\r\n      .[$pair.date | bucket($day)] += ($pair.value) )\r\n\r\nWith the sample data, this produces:\r\n\r\n    {\r\n      &quot;2018-08&quot;: 6,\r\n      &quot;2018-09&quot;: 12,\r\n      &quot;2018-10&quot;: 6\r\n    }      \r\n\r\nIt is now a trivial matter to convert this into the desired format, and is thus left as an exercise.\r\n\r\n",
                "title": "JSON parsing - group by date range with JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1666503833,
                "creation_date": 1666503833,
                "answer_id": 74168925,
                "question_id": 54199974,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In case someone is looking at this, here is an alternative solution in Unquery (disclaimer: I lead Unquery&#39;s development):\r\nhttps://github.com/xcite-db/Unquery\r\n\r\n    {\r\n       &quot;#var dates&quot;: [\r\n       \t &quot;&#39;2018-08-22&#39;&quot;,\r\n       \t &quot;&#39;2018-09-22&#39;&quot;,\r\n       \t &quot;&#39;2018-10-22&#39;&quot;,\r\n       \t &quot;&#39;2018-11-22&#39;&quot;\r\n       ],\r\n       &quot;#return:data[]&quot;: {\r\n       \t&quot;#var i-&gt;%dates:[]?$to_time(&lt;&lt;date)&lt;$to_time(.)&quot;:&quot;&#39;up to &#39;+.&quot;,\r\n    \t&quot;%i&quot;:&quot;$sum(value)&quot;\r\n       }\r\n    }\r\n\r\nResult:\r\n\r\n    {\r\n        &quot;up to 2018-09-22&quot;: 6,\r\n        &quot;up to 2018-10-22&quot;: 12,\r\n        &quot;up to 2018-11-22&quot;: 6\r\n    }\r\n",
                "title": "JSON parsing - group by date range with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1666503833,
        "creation_date": 1547559377,
        "last_edit_date": 1547664664,
        "question_id": 54199974,
        "body_markdown": "I have the following JSON data :\r\n\r\n    {\r\n      &quot;data&quot;: [  \r\n        {&quot;date&quot;: &quot;2018-08-22&quot;,&quot;value&quot;: 1},\r\n        {&quot;date&quot;: &quot;2018-08-30&quot;,&quot;value&quot;: 2},\r\n        {&quot;date&quot;: &quot;2018-09-01&quot;,&quot;value&quot;: 3},\r\n        {&quot;date&quot;: &quot;2018-09-22&quot;,&quot;value&quot;: 3},\r\n        {&quot;date&quot;: &quot;2018-09-28&quot;,&quot;value&quot;: 4},\r\n        {&quot;date&quot;: &quot;2018-10-18&quot;,&quot;value&quot;: 5},\r\n        {&quot;date&quot;: &quot;2018-10-23&quot;,&quot;value&quot;: 6}\r\n      ]\r\n    }\r\n\r\nI would like to use JQ to group data per month starting at the first value :\r\nMy month would be : \r\n\r\n - 2018 08 22 to 2018 09 21\r\n\r\n\r\n\r\n - 2018 09 22 to 2018 10 21\r\n\r\n\r\n - 2018 10 22 to 2018 11 21\r\n\r\nMy expected output is the following :\r\n\r\n    {\r\n      &quot;data&quot;: [  \r\n        {&quot;month&quot;: &quot;2018-08-22 to 2018-09-21&quot;,&quot;sum&quot;: 6},\r\n        {&quot;month&quot;: &quot;2018-09-22 to 2018-10-21&quot;,&quot;sum&quot;: 12},\r\n        {&quot;month&quot;: &quot;2018-10-23 to 2018-11-21&quot;,&quot;sum&quot;: 6}\r\n      ]\r\n    }\r\n\r\nHow can I do that ?",
        "link": "https://stackoverflow.com/questions/54199974/json-parsing-group-by-date-range-with-jq",
        "title": "JSON parsing - group by date range with JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1547564372,
                "post_id": 54200265,
                "comment_id": 95229699,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547567952,
                "post_id": 54200265,
                "comment_id": 95231955,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1547571124,
                "last_edit_date": 1547571124,
                "creation_date": 1547568109,
                "answer_id": 54202514,
                "question_id": 54200265,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your goal is to split a string on commas to generate a list, and use your list in jq, that might look like:\r\n\r\n    val=text1,text2,text3\r\n    jq --arg val &quot;$val&quot; &#39;.whatever.item |= ($val | split(&quot;,&quot;))&#39; &lt;&lt;&lt;&#39;{&quot;whatever&quot;: {}}&#39;\r\n\r\nNote:\r\n\r\n- There&#39;s no point to paired double-quote sets in the shell assignment -- they literally cancel each other out and don&#39;t become part of the variable&#39;s value.\r\n- The `jq` argument `--arg` is used to pass that variable from a shell context to a jq context.\r\n- The `|=` construct is used to modify a nested value while still evaluating to the larger document.",
                "title": "Using a comma-separated string in shell to update a JSON list with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1547571144,
        "creation_date": 1547560361,
        "last_edit_date": 1547571144,
        "question_id": 54200265,
        "body_markdown": "How to append value to json key using?\r\n\r\n    val=&quot;&quot;text&quot;&quot;,&quot;&quot;text&quot;&quot;,&quot;&quot;text&quot;&quot;\r\n    \r\n    jq &#39;.doc[1].DEF[3].value=&quot;update comma separated val here&quot; &lt;&lt;&lt; &quot;$jsonStr&quot;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54200265/using-a-comma-separated-string-in-shell-to-update-a-json-list-with-jq",
        "title": "Using a comma-separated string in shell to update a JSON list with jq?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547577887,
                "post_id": 54202642,
                "comment_id": 95236806,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1547568958,
                "creation_date": 1547568958,
                "answer_id": 54202774,
                "question_id": 54202642,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This can be done using [`select`][1]. Note if there is more than one item with the key of `level2` this will only return the first:\r\n\r\n    .organizationalStructure | map(select(.key == &quot;level2&quot;) | .id)[0]\r\n\r\n[1]: https://stedolan.github.io/jq/manual/#select(boolean_expression)",
                "title": "Find an entry in a JSON list of objects based on object&#39;s key"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1547573982,
                "last_edit_date": 1547573982,
                "creation_date": 1547569399,
                "answer_id": 54202889,
                "question_id": 54202642,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Or, to keep it simpler (or more complicated, depending on your point of view):\r\n\r\n    jq &#39;.organizationalStructure[] |\r\n        select(.key == &quot;level1&quot;) | {id: .id}&#39; \r\n\r\nOften, it&#39;s nice to clean up the output:\r\n\r\n    jq -r &#39;.organizationalStructure[] |\r\n            select(.key == &quot;level1&quot;) | {id: .id}.id&#39;\r\n\r\nAs per PesaThe&#39;s suggestion in the comments, this can be simplified to:\r\n\r\n    jq -r &#39;.organizationalStructure[] |\r\n        select(.key == &quot;level1&quot;).id&#39; \r\n\r\nand `{.id: id}` can be written simply `{id}`\r\n",
                "title": "Find an entry in a JSON list of objects based on object&#39;s key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1547613965,
        "creation_date": 1547568489,
        "last_edit_date": 1547613965,
        "question_id": 54202642,
        "body_markdown": "I&#39;ve got JSON that, among other top-level content, includes the following:\r\n\r\n```\r\n{\r\n  &quot;organizationStructure&quot;: [\r\n    {\r\n      &quot;id&quot;: 212119,\r\n      &quot;key&quot;: &quot;level2&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: 212112,\r\n      &quot;key&quot;: &quot;level1&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nHow can I filter by the key to find only a given id (such as that for &quot;level2&quot;)?",
        "link": "https://stackoverflow.com/questions/54202642/find-an-entry-in-a-json-list-of-objects-based-on-objects-key",
        "title": "Find an entry in a JSON list of objects based on object&#39;s key"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1547617813,
                "post_id": 54210566,
                "comment_id": 95248173,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1619387504,
                "last_edit_date": 1619387504,
                "creation_date": 1547618799,
                "answer_id": 54211274,
                "question_id": 54210566,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Perhaps the thing you&#39;re missing is the utility of jq variables:\r\n\r\n    .company as $company\r\n    | .sites[]\r\n    | .name as $site\r\n    | .personnel[]\r\n    | { name, id: .UID, $company, $site }\r\n\r\n(`{$x}` is shorthand for `{ x: $x }`.)\r\n\r\nHowever it&#39;s also possible to avoid variables by using parentheses with care.  If you don&#39;t mind the keys being in a slightly different order, you could write:\r\n\r\n    (.sites[] | ( (.personnel[] | { name, id: .UID} ) +  {site: .name} )) + {company} \r\n\r\nIf the keys must be in the order shown in the Q, you could simply append the following filter to the above pipeline:\r\n\r\n    {name, id, company, site}",
                "title": "While unnesting an object in jq, how can I avoid restating labels at each stage in the pipeline?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1619387504,
        "creation_date": 1547613916,
        "question_id": 54210566,
        "body_markdown": "#Summary:\r\n\r\nI have successfully worked out how to unnest objects in jq; however, the working code I have written requires a lot of repetition.  I feel it&#39;s likely there is a cleaner or less verbose way to achieve this same result and I would like to know what it is.\r\n\r\n#Example:\r\n\r\nWith the following nested structure of companies, suppose the goal is to extract the name, ID, company and site for each *person* listed.  (We can ignore the address.)\r\n\r\n###Input:\r\n\r\n```\r\n{\r\n  &quot;company&quot;: &quot;Initrode&quot;,\r\n  &quot;sites&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;HQ&quot;,\r\n      &quot;address&quot;: &quot;123 Main Street&quot;,\r\n      &quot;personnel&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;John Smith&quot;,\r\n          &quot;UID&quot;: 12345\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Jane Doe&quot;,\r\n          &quot;UID&quot;: 23456\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Branch Office&quot;,\r\n      &quot;address&quot;: &quot;Spodunk, Nowhereville&quot;,\r\n      &quot;personnel&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Fred Anderson&quot;,\r\n          &quot;UID&quot;: 56789\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Bill Jones&quot;,\r\n          &quot;UID&quot;: 34567\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;company&quot;: &quot;Inittech&quot;,\r\n  &quot;sites&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Main Office&quot;,\r\n      &quot;address&quot;: &quot;5678 Avenue Blvd&quot;,\r\n      &quot;personnel&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Fred Johnson&quot;,\r\n          &quot;UID&quot;: 6543\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;James Fredson&quot;,\r\n          &quot;UID&quot;: 9876\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Testing Station&quot;,\r\n      &quot;address&quot;: &quot;Alaskan Wilderness&quot;,\r\n      &quot;personnel&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Sally May&quot;,\r\n          &quot;UID&quot;: 5432\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Jack James&quot;,\r\n          &quot;UID&quot;: 8765\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n###Working code:\r\n\r\n```\r\njq &#39;{company,site: .sites[]}|\r\n{company,site: .site.name,personnel: .site.personnel[]}|\r\n{name: .personnel.name,id: .personnel.UID,company,site}&#39; sample.json\r\n```\r\n\r\n###Correct output:\r\n\r\n```\r\n{\r\n  &quot;name&quot;: &quot;John Smith&quot;,\r\n  &quot;id&quot;: 12345,\r\n  &quot;company&quot;: &quot;Initrode&quot;,\r\n  &quot;site&quot;: &quot;HQ&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;Jane Doe&quot;,\r\n  &quot;id&quot;: 23456,\r\n  &quot;company&quot;: &quot;Initrode&quot;,\r\n  &quot;site&quot;: &quot;HQ&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;Fred Anderson&quot;,\r\n  &quot;id&quot;: 56789,\r\n  &quot;company&quot;: &quot;Initrode&quot;,\r\n  &quot;site&quot;: &quot;Branch Office&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;Bill Jones&quot;,\r\n  &quot;id&quot;: 34567,\r\n  &quot;company&quot;: &quot;Initrode&quot;,\r\n  &quot;site&quot;: &quot;Branch Office&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;Fred Johnson&quot;,\r\n  &quot;id&quot;: 6543,\r\n  &quot;company&quot;: &quot;Inittech&quot;,\r\n  &quot;site&quot;: &quot;Main Office&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;James Fredson&quot;,\r\n  &quot;id&quot;: 9876,\r\n  &quot;company&quot;: &quot;Inittech&quot;,\r\n  &quot;site&quot;: &quot;Main Office&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;Sally May&quot;,\r\n  &quot;id&quot;: 5432,\r\n  &quot;company&quot;: &quot;Inittech&quot;,\r\n  &quot;site&quot;: &quot;Testing Station&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;Jack James&quot;,\r\n  &quot;id&quot;: 8765,\r\n  &quot;company&quot;: &quot;Inittech&quot;,\r\n  &quot;site&quot;: &quot;Testing Station&quot;\r\n}\r\n```\r\n\r\n#The problem:\r\n\r\nThere is a lot of repetition involved here.  Aside from repeating the outer labels at each stage of the pipeline, there&#39;s also the repetition of `.site` and `.personnel` in the second and third parts of the pipeline respectively.\r\n\r\nMy real data is much more complicated, so this repetition is even worse and is much harder to read.\r\n\r\nIncidentally, here is some NON-WORKING code that I tried earlier for the same goal above:\r\n\r\n```\r\njq &#39;{company,site: .sites[].name,name: .sites[].personnel[].name,id: .sites[].personnel[].UID}&#39; sample.json\r\n```\r\n\r\nThat is much less repetition, but unfortunately it returns every person associated with every ID and site at their company - incorrect results, like a database &quot;cross join&quot; instead of &quot;inner join.&quot;\r\n\r\nI don&#39;t quite know how to describe in words what&#39;s needed here, but hopefully the above sample helps make it clear.\r\n\r\nOne way to describe it is that I&#39;m trying to merge multiple name-value pairs from arrays of sub-objects into the top-level object, without returning together any combinations of name-value pairs taken from *different* sub-objects within the same array value.  But that&#39;s not exactly easy to follow even for me; hence the above example input/output.\r\n\r\n-------\r\n\r\nJust for interest, here is the real working code I have, with attribute names obfuscated:\r\n\r\n```\r\njq &#39;.pears[]|{pear: .name,file: .somepath,toBeFiltered: (.appletypes[]|select(.name == &quot;orange&quot;)|.bananas[]|{banana: .name,apples: .apples[]})}|{pear,file,banana: .toBeFiltered.banana,applestem: .toBeFiltered.apples.applestem,orangecomment: (.toBeFiltered.apples.peaches[]|select(.akey == &quot;string&quot;)|.avalue.value),linenumber: (.toBeFiltered.apples.peaches[]|select(.akey == &quot;string&quot;)|.line)}&#39; realfile.json\r\n```",
        "link": "https://stackoverflow.com/questions/54210566/while-unnesting-an-object-in-jq-how-can-i-avoid-restating-labels-at-each-stage",
        "title": "While unnesting an object in jq, how can I avoid restating labels at each stage in the pipeline?"
    },
    {
        "tags": [
            "select",
            "jq",
            "reduce"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1559974977,
                "post_id": 54213786,
                "comment_id": 99596190,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1547632373,
                "creation_date": 1547632373,
                "answer_id": 54214373,
                "question_id": 54213786,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I am not sure that I understand your question completely, but I guess this should work\r\n\r\n    reduce (inputs | select(Your_filter)) as $line\r\n    ([]; . + [$line])",
                "title": "Using select with reduce in jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1559971952,
                "creation_date": 1559971952,
                "answer_id": 56503756,
                "question_id": 54213786,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the particular case given, a simpler solution is:\r\n\r\n    [inputs | select(...)]\r\n\r\nIn fact, it often happens that a solution using `reduce` can be simplified, e.g. as here or by using one of the built-in reduction filters (notably `add`).\r\n \r\nOf course, when using `inputs` to avoid slurping, the -n command-line option is needed.\r\n\r\n\r\n\r\n",
                "title": "Using select with reduce in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1559971952,
        "creation_date": 1547630405,
        "last_edit_date": 1547691809,
        "question_id": 54213786,
        "body_markdown": "If I have a simple `reduce` expression:\r\n\r\n    reduce inputs as $line\r\n    ([]; . + [$line])\r\n\r\n_(this is roughly equivalent to `--slurp`: ignore that; it&#39;s just an example)_\r\n\r\n...but I want to filter `inputs` somehow.\r\n\r\n**Where do I put the `select`?**",
        "link": "https://stackoverflow.com/questions/54213786/using-select-with-reduce-in-jq",
        "title": "Using select with reduce in jq?"
    },
    {
        "tags": [
            "json",
            "file",
            "group-by",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1547647591,
                "last_edit_date": 1547647591,
                "creation_date": 1547646758,
                "answer_id": 54218586,
                "question_id": 54217986,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d do it in three passes, filtering the array with the desired `dd` and grouping by `jlo`, then extracting the `jlo` of the first (guaranteed) item of the array and its length :\r\n\r\n    map(select(.dd == &quot;d5f&quot;)) | group_by(.jlo) | map(&quot;\\(.[0].jlo) \\(length)&quot;) | .[]\r\n\r\n\r\nYou can [try it here](https://jqplay.org/s/bffxEaU4Rf).\r\n\r\nFull bash run :\r\n\r\n    jq --arg dd d5f --raw-output &#39;map(select(.dd == $dd)) | group_by(.jlo) | map(&quot;\\(.[0].jlo) \\(length)&quot;) | .[]&#39; yourJsonFile &gt; departmentone.txt\r\n    jq --arg dd 5d9 --raw-output &#39;map(select(.dd == $dd)) | group_by(.jlo) | map(&quot;\\(.[0].jlo) \\(length)&quot;) | .[]&#39; yourJsonFile &gt; departmentalt.txt\r\n    jq --arg dd 1b1 --raw-output &#39;map(select(.dd == $dd)) | group_by(.jlo) | map(&quot;\\(.[0].jlo) \\(length)&quot;) | .[]&#39; yourJsonFile &gt; departmentshort.txt\r\n\r\n\r\nSupposing you have a file named &quot;mapping.txt&quot; with the following content :\r\n\r\n    d5f:departmentone\r\n    5d9:departmentalt\r\n    1b1:departshort\r\n\r\nYou could extract those codes and labels to generate the files :\r\n\r\n    while IFS=: read -r code label; do\r\n        jq --arg dd $code --raw-output &#39;map(select(.dd == $dd)) | group_by(.jlo) | map(&quot;\\(.[0].jlo) \\(length)&quot;) | .[]&#39; yourJsonFile &gt; &quot;$label&quot;.txt\r\n    done &lt; mapping.txt",
                "title": "jq create output in many separate files"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1547961905,
                "last_edit_date": 1547961905,
                "creation_date": 1547654895,
                "answer_id": 54221026,
                "question_id": 54217986,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Only one invocation of jq is necessary.  To allocate the output to the separate files, you can combine this one invocation with a single invocation to awk, or you could use a shell loop as illustrated below.\r\n\r\nFirst, here&#39;s an illustration of how the shell pipeline would look:\r\n\r\n    jq -r --rawfile dd2name dd2name.tsv -f group.jq input.json |\r\n      while IFS=$&#39;\\t&#39; read -r f v ; do echo &quot;$v&quot; &gt;&gt; &quot;$f&quot; ; done\r\n\r\nThis assumes that the mapping to filenames is in a TSV file named dd2name.tsv, and that the following jq program is in group.jq:\r\n\r\n    def dict:\r\n      split(&quot;\\n&quot;) | map(select(length&gt;0) | split(&quot;\\t&quot;))\r\n      | INDEX(.[0]) | map_values(.[1]);\r\n    \r\n    ($dd2name | dict) as $dict\r\n    | ($dict | keys_unsorted[]) as $dd\r\n    | map(select(.dd == $dd))\r\n    | group_by(.jlo)\r\n    | map(&quot;\\($dict[$dd])\\t\\(.[0].jlo) \\(length)&quot;)[]\r\n\r\n\r\nAs the name suggests, the `dict` function creates a dictionary giving the mapping of .dd values to the filenames.  It assumes the availability of `INDEX`.  If your jq does not have `INDEX`, then now would be an excellent time to upgrade your jq; otherwise, its def can easily be copied from builtin.jq (google: `builtin.jq &quot;def INDEX&quot;`), or you could replace the last line by: `| reduce .[] as $p ({}; .[$p[0]] = $p[1]);`\r\n\r\n## awk-based solution\r\n\r\nThe following invocation of awk can be used instead of the `while ... done` command above:\r\n\r\n    awk -F\\\\t &#39;fn &amp;&amp; (fn!=$1) {close(fn)}; {fn=$1; print $2 &gt;&gt; fn}&#39;\r\n\r\n## Season to taste\r\n\r\nIf the dd2name.tsv mapping file does not contain the &quot;.txt&quot; suffix, it can easily be added in any of a variety of ways, according to taste.\r\n\r\nNote also that the proposed solutions above make some assumptions, notably that the .jlo values do not contain tabs, newlines, or NULs.  If any of those assumptions is violated, then some tweaking will be required.\r\n",
                "title": "jq create output in many separate files"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1547961905,
        "creation_date": 1547644873,
        "last_edit_date": 1547657880,
        "question_id": 54217986,
        "body_markdown": "given the following json:\r\n\r\n        [\r\n        {&quot;_id&quot;:{&quot;$oid&quot;:&quot;6d2&quot;},&quot;jlo&quot;:&quot;ΕΙ AJSB&quot;,&quot;dd&quot;:&quot;d5f&quot;},\r\n        {&quot;_id&quot;:{&quot;$oid&quot;:&quot;c6d3&quot;},&quot;jlo&quot;:&quot;ΕΙ ALKSB&quot;,&quot;dd&quot;:&quot;5d9&quot;},\r\n        {&quot;_id&quot;:{&quot;$oid&quot;:&quot;b0cc6d4&quot;},&quot;jlo&quot;:&quot;ΕΙ AGHTSB&quot;,&quot;dd&quot;:&quot;1b1&quot;},\r\n        {&quot;_id&quot;:{&quot;$oid&quot;:&quot;6d2&quot;},&quot;jlo&quot;:&quot;ΕPOWΙ AJSB&quot;,&quot;dd&quot;:&quot;d5f&quot;},\r\n        {&quot;_id&quot;:{&quot;$oid&quot;:&quot;c6d3&quot;},&quot;jlo&quot;:&quot;ΕGTΙ ALKSB&quot;,&quot;dd&quot;:&quot;5d9&quot;},\r\n        {&quot;_id&quot;:{&quot;$oid&quot;:&quot;b0cc6d4&quot;},&quot;jlo&quot;:&quot;ΕLKΙ AGHTSB&quot;,&quot;dd&quot;:&quot;1b1&quot;}\r\n        ]\r\n    \r\nwhat i need to do is have as output for each discrete value of the ll element, the unique values of ta, in a separate file, named after a one to one representation where each dd code is substituted with a human readable representation: \r\n\r\n    d5f:departmentone\r\n    5d9:departmentalt\r\n    1b1:departshort\r\n    \r\nDesired output, in a per row basis, each unique value of jlo with the count of times it was found in each dd element so we get in the end something like this:\r\n    \r\n    first file named departmentone.txt:\r\n    ΕΙ AJSB 1\r\n    ΕPOWΙ AJSB 1\r\n    \r\n    second file named departmentalt.txt\r\n    ΕΙ ALKSB 1\r\n    ΕGTΙ ALKSB 1\r\n    \r\n    third file named departshort.txt\r\n    ΕΙ AGHTSB 2\r\n\r\ni have tried with map and reduce, group_by, sort_by, with really poor results",
        "link": "https://stackoverflow.com/questions/54217986/jq-create-output-in-many-separate-files",
        "title": "jq create output in many separate files"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1547743146,
                "creation_date": 1547743146,
                "answer_id": 54240457,
                "question_id": 54232764,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way is to use `group_by`:\r\n\r\n    jq -n --slurpfile file1 file1.json --slurpfile file2 file2.json -f merge.jq\r\n\r\nwhere merge.jq contains:\r\n\r\n    def sigma(f): reduce f as $x (null; . + $x);\r\n    \r\n    $file1 + $file2\r\n    | group_by(.inst_id)[]\r\n    | {tag_id: sigma(.[].tag_id), inst_id: .[0].inst_id }\r\n\r\n",
                "title": "How to merge json file using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1547751564,
                "creation_date": 1547751564,
                "answer_id": 54242577,
                "question_id": 54232764,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a join-like approach. It assumes your jq has `INDEX/2` and supports the `--slurpfile` command-line option.  If your jq does not have these, now would be a good time to upgrade, though there are easy workarounds.\r\n\r\n## Invocation\r\n\r\n    jq -n --slurpfile file1 file1.json -f join.jq file2.json\r\n\r\n## join.jq\r\n\r\n    def join(s2; joinField; field):\r\n      INDEX(.[]; joinField) \r\n      | reduce s2 as $x (.;\r\n          ($x|joinField) as $key\r\n          | if .[$key] then (.[$key]|field) += ($x|field)\r\n            else .[$key] = $x\r\n          end )\r\n      | .[]\r\n      ;\r\n    \r\n    $file1 | join(inputs; .inst_id; .tag_id)\r\n\r\n",
                "title": "How to merge json file using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1547846800,
                "last_edit_date": 1547846800,
                "creation_date": 1547844872,
                "answer_id": 54261308,
                "question_id": 54232764,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following approach is very efficient in that:\r\n\r\n(a) it takes advantage of the fact that file1.json and file2.json are streams of objects, thus avoiding the memory required to store these objects as arrays;\r\n\r\n(b) it avoids sorting (as entailed, for example, by `group_by`)\r\n\r\nThe key concept is the keywise-addition of objects.  For performing keywise-addition of objects in a stream, we define the following generic function:\r\n\r\n    # s is assumed to be a stream of mutually\r\n    # compatible objects in the sense that, given\r\n    # any key of any object, the values at that key\r\n    # must be compatible w.r.t. `add`\r\n    def keywise_add(s):\r\n      reduce s as $x ({};\r\n         reduce ($x|keys_unsorted)[] as $k (.; \r\n           .[$k] += $x[$k]));\r\n    \r\nThe task can now be accomplished as follows:\r\n\r\n    keywise_add(inputs | {(.inst_id): .tag_id} )\r\n    | keys_unsorted[] as $k\r\n    | {tag_id: .[$k], inst_id: $k}\r\n\r\n## Invocation\r\n\r\nWith the above program in add.jq, the invocation:\r\n\r\n    jq -c -n -f add.jq file1.json file2.json\r\n\r\nyields:\r\n\r\n    {&quot;tag_id&quot;:[&quot;t1&quot;,&quot;t2&quot;],&quot;inst_id&quot;:&quot;s1&quot;}\r\n    {&quot;tag_id&quot;:[&quot;t1&quot;,&quot;t2&quot;],&quot;inst_id&quot;:&quot;s2&quot;}\r\n    {&quot;tag_id&quot;:[&quot;t2&quot;],&quot;inst_id&quot;:&quot;s3&quot;}\r\n\r\n  \r\n## Caveat\r\nThe above assumes that `inst_id` is string-valued. If that is not the case, then the above approach can still be used so long as there are no collisions amongst `inst_id|tostring`, which would be the case, for example, if `inst_id` were always numeric.\r\n\r\n\r\n",
                "title": "How to merge json file using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1547846800,
        "creation_date": 1547717387,
        "last_edit_date": 1547722345,
        "question_id": 54232764,
        "body_markdown": "I&#39;m using the jq tools (jq-json-processor) in shell script to parse json.\r\n\r\nI&#39;ve got 2 json files and want to merge them into one unique file\r\n\r\nHere the content of files:\r\n\r\nfile1:\r\n\r\n    {&quot;tag_id&quot; : [&quot;t1&quot;], &quot;inst_id&quot; : &quot;s1&quot;}\r\n    {&quot;tag_id&quot; : [&quot;t1&quot;], &quot;inst_id&quot; : &quot;s2&quot;}\r\n\r\nfile2:\r\n  \r\n\r\n    {&quot;tag_id&quot; : [&quot;t2&quot;], &quot;inst_id&quot; : &quot;s1&quot;}\r\n    {&quot;tag_id&quot; : [&quot;t2&quot;], &quot;inst_id&quot; : &quot;s2&quot;}\r\n    {&quot;tag_id&quot; : [&quot;t2&quot;], &quot;inst_id&quot; : &quot;s3&quot;}\r\n\r\nexpected result:\r\n  \r\n\r\n    {&quot;tag_id&quot; : [&quot;t1&quot;,&quot;t2&quot;], &quot;inst_id&quot; : &quot;s1&quot;}\r\n    {&quot;tag_id&quot; : [&quot;t1&quot;,&quot;t2&quot;], &quot;inst_id&quot; : &quot;s2&quot;}\r\n    {&quot;tag_id&quot; : [&quot;t2&quot;], &quot;inst_id&quot; : &quot;s3&quot;}\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54232764/how-to-merge-json-file-using-jq",
        "title": "How to merge json file using jq?"
    },
    {
        "tags": [
            "json",
            "date",
            "grouping",
            "aggregate",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1547785229,
                "last_edit_date": 1547785229,
                "creation_date": 1547763204,
                "answer_id": 54245025,
                "question_id": 54240276,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This question is almost identical to\r\n\r\nhttps://stackoverflow.com/questions/54199974/json-parsing-group-by-date-range-with-jq\r\n\r\nand the solution given there can easily be adapted to the problem here:\r\n\r\n\r\n    def bucket: sub(&quot;-\\\\d+$&quot;; &quot;&quot;);\r\n    \r\n    .data\r\n    | reduce .[] as $pair ({};\r\n        .[$pair.date | bucket] += [$pair.value])\r\n    | {data: [to_entries[] | {month: .key, avg: (.value| add/length)}]}\r\n\r\n",
                "title": "JSON parsing - get the average per group with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1547785229,
        "creation_date": 1547742532,
        "question_id": 54240276,
        "body_markdown": "I have the following JSON data :\r\n\r\n    {\r\n      &quot;data&quot;: [  \r\n        {&quot;date&quot;: &quot;2018-08-22&quot;,&quot;value&quot;: 3},\r\n        {&quot;date&quot;: &quot;2018-08-30&quot;,&quot;value&quot;: 5},\r\n        {&quot;date&quot;: &quot;2018-09-01&quot;,&quot;value&quot;: 5},\r\n        {&quot;date&quot;: &quot;2018-09-22&quot;,&quot;value&quot;: 9},\r\n        {&quot;date&quot;: &quot;2018-09-28&quot;,&quot;value&quot;: 4},\r\n        {&quot;date&quot;: &quot;2018-10-18&quot;,&quot;value&quot;: 2},\r\n        {&quot;date&quot;: &quot;2018-10-23&quot;,&quot;value&quot;: 1}\r\n      ]\r\n    }\r\n\r\nI would like to get the average per month.\r\nMy expected output is the following :\r\n\r\n    {\r\n      &quot;data&quot;: [  \r\n        {&quot;month&quot;: &quot;2018-08&quot;,&quot;avg&quot;: 4},\r\n        {&quot;month&quot;: &quot;2018-09&quot;,&quot;avg&quot;: 6},\r\n        {&quot;month&quot;: &quot;2018-10&quot;,&quot;avg&quot;: 3}\r\n      ]\r\n    }\r\n\r\nHow can I do that ?\r\n",
        "link": "https://stackoverflow.com/questions/54240276/json-parsing-get-the-average-per-group-with-jq",
        "title": "JSON parsing - get the average per group with JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547748601,
                "post_id": 54241829,
                "comment_id": 95308104,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547748647,
                "post_id": 54241829,
                "comment_id": 95308124,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13818404,
                    "reputation": 887,
                    "user_id": 10061137,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7f52ae1734cc92958e71bc9210b74bc1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Igniter",
                    "link": "https://stackoverflow.com/users/10061137/igniter"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547748669,
                "post_id": 54241829,
                "comment_id": 95308137,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1547748722,
                "post_id": 54241829,
                "comment_id": 95308158,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13818404,
                    "reputation": 887,
                    "user_id": 10061137,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7f52ae1734cc92958e71bc9210b74bc1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Igniter",
                    "link": "https://stackoverflow.com/users/10061137/igniter"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547748747,
                "post_id": 54241829,
                "comment_id": 95308169,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547748819,
                "post_id": 54241829,
                "comment_id": 95308196,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13818404,
                    "reputation": 887,
                    "user_id": 10061137,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7f52ae1734cc92958e71bc9210b74bc1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Igniter",
                    "link": "https://stackoverflow.com/users/10061137/igniter"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547748869,
                "post_id": 54241829,
                "comment_id": 95308217,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547748914,
                "post_id": 54241829,
                "comment_id": 95308244,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13818404,
                    "reputation": 887,
                    "user_id": 10061137,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7f52ae1734cc92958e71bc9210b74bc1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Igniter",
                    "link": "https://stackoverflow.com/users/10061137/igniter"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547748935,
                "post_id": 54241829,
                "comment_id": 95308254,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547748995,
                "post_id": 54241829,
                "comment_id": 95308281,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547749092,
                "post_id": 54241829,
                "comment_id": 95308338,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13818404,
                    "reputation": 887,
                    "user_id": 10061137,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7f52ae1734cc92958e71bc9210b74bc1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Igniter",
                    "link": "https://stackoverflow.com/users/10061137/igniter"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547749095,
                "post_id": 54241829,
                "comment_id": 95308341,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547749173,
                "post_id": 54241829,
                "comment_id": 95308380,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13818404,
                    "reputation": 887,
                    "user_id": 10061137,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7f52ae1734cc92958e71bc9210b74bc1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Igniter",
                    "link": "https://stackoverflow.com/users/10061137/igniter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547749200,
                "post_id": 54241829,
                "comment_id": 95308395,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1547749271,
                "post_id": 54241829,
                "comment_id": 95308433,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13818404,
                    "reputation": 887,
                    "user_id": 10061137,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7f52ae1734cc92958e71bc9210b74bc1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Igniter",
                    "link": "https://stackoverflow.com/users/10061137/igniter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547749347,
                "post_id": 54241829,
                "comment_id": 95308477,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13818404,
                    "reputation": 887,
                    "user_id": 10061137,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7f52ae1734cc92958e71bc9210b74bc1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Igniter",
                    "link": "https://stackoverflow.com/users/10061137/igniter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547749410,
                "post_id": 54241829,
                "comment_id": 95308515,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1547749496,
                "post_id": 54241829,
                "comment_id": 95308558,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547764260,
                "post_id": 54241829,
                "comment_id": 95314923,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1547771609,
                "last_edit_date": 1547771609,
                "creation_date": 1547759196,
                "answer_id": 54244295,
                "question_id": 54241829,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming your areas.json is valid JSON, then I believe the following would come close to accomplishing your intended edit:\r\n\r\n    names=&#39;[&quot;name1&quot;,&quot;name2&quot;,&quot;name3&quot;,&quot;name4&quot;]&#39;\r\n    jq --argjson names &quot;$names&quot; &#39;.features[].properties.name = $names\r\n      &#39; &lt; areas.json\r\n\r\nHowever, given your proposed solution, it&#39;s not clear to me what you mean by a &quot;random value from a 1d-array&quot;.  If you mean that the index should be randomly chosen (as by a PRNG), then I would suggest computing it using your favorite PRNG and passing in that random value as another argument to jq, as illustrated in the following section.  \r\n\r\nSo the question becomes how to transform the text\r\n\r\n    [&#39;name1&#39;,&#39;name2&#39;,&#39;name3&#39;,&#39;name4&#39;]\r\n\r\ninto a valid JSON array.  There are numerous ways this can be done, whether using jq or not, but I believe that is best left as a separate question or as an exercise, because the selection of the method will probably depend on specific details which are not mentioned in this Q.  Personally, I&#39;d use `sed` if possible; you might also consider using [tag:hjson], as also illustrated in the following section.\r\n\r\n\r\n## Illustration using hjson and awk\r\n    \r\n    hjson -j &lt;&lt;&lt; &quot;[&#39;name1&#39;,&#39;name2&#39;,&#39;name3&#39;,&#39;name4&#39;]&quot; &gt; names.json.tmp\r\n    \r\n    function randint {\r\n      awk -v n=&quot;$(jq length names.json.tmp)&quot; &#39;\r\n        function randint(n) {return int(n * rand())}\r\n        BEGIN {srand(); print randint(n)}&#39;\r\n    }\r\n    \r\n    jq --argfile names names.json.tmp --argjson n $(randint) &#39;\r\n      .features[].properties.name = $names[$n]\r\n    &#39; &lt; areas.json\r\n\r\n## Addendum\r\nCurrently, jq does not have a builtin PRNG, but if you want to use jq and if you want a value from the &quot;names&quot; array to be chosen at random (with replacement?) for each occurrence of the .name field, then one option would be to pre-compute an array of the randomly selected names (an array of length `features | length`) using your favorite PRNG, and passing that array into jq:\r\n\r\n    jq --argjson randomnames &quot;$randomnames&quot; &#39; \r\n      reduce range(0; .features[]|length) as $i (.;\r\n        .features[$i].properties.name = $randomnames[$i]) \r\n      &#39; &lt; areas.json\r\n\r\nAnother option would be to use a PRNG written in jq, as illustrated elsewhere on this page.",
                "title": "Replacing a value in a JSON structure with randomly-chosen strings from a list using jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1547766932,
                "last_edit_date": 1547766932,
                "creation_date": 1547763799,
                "answer_id": 54245130,
                "question_id": 54241829,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your document (https://echarts.baidu.com/examples/data-gl/asset/data/buildings.json) is actually small enough that we don&#39;t need to do any crazy memory-conservation tricks to make it work; the following functions as-is:\r\n\r\n```bash\r\n# create sample data\r\n[[ -e words.txt ]] || printf &#39;%s\\n&#39; &#39;First Word&#39; &#39;Second Word&#39; &#39;Third Word&#39; &gt;words.txt\r\n\r\n# actually run the replacements\r\njq -n --slurpfile buildings buildings.json &#39;\r\n  # define a jq function that changes the current property name with the next input\r\n  def replaceName: (.properties.name |= input);\r\n  # now, for each document in buildings.json, replace each name it contains\r\n  $buildings[] | (.features |= map(replaceName))\r\n&#39; &lt; &lt;(shuf -r words.txt | jq -R .)\r\n```\r\n\r\nThis works because `shuf -r words.txt` creates an unending stream of words randomly chosen from `words.txt`, and the `jq -R .` inside the process substitution quotes those as strings. (Because we only call `input` once per item in `buildings.json`, we don&#39;t try to keep running after that file&#39;s contents have been completely consumed).\r\n\r\n---\r\n\r\nFor the tiny two-record document given in the question, the output looks like:\r\n\r\n```\r\n{\r\n  &quot;features&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;Feature&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;name&quot;: &quot;Third Word&quot;,\r\n        &quot;height&quot;: 0.7\r\n      }\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;Feature&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;name&quot;: &quot;Second Word&quot;,\r\n        &quot;height&quot;: 0\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n...with the actual words varying each run; it&#39;s similarly been smoketested with the full externally-hosted file.",
                "title": "Replacing a value in a JSON structure with randomly-chosen strings from a list using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1547768125,
                "last_edit_date": 1547768125,
                "creation_date": 1547767792,
                "answer_id": 54245777,
                "question_id": 54241829,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution to the problem of choosing the names randomly with replacement, using the very simple PRNG written in jq\r\ncopied from https://rosettacode.org/wiki/Random_numbers#jq\r\n\r\n## Invocation:\r\n\r\n    jq  --argjson names &#39;[&quot;name1&quot;,&quot;name2&quot;,&quot;name3&quot;,&quot;name4&quot;]&#39; \\\r\n      -f areas.jq areas.json\r\n\r\n## areas.jq\r\n\r\n    # The random numbers are in [0 -- 32767] inclusive.\r\n    # Input: an array of length at least 2 interpreted as [count, state, ...]\r\n    # Output: [count+1, newstate, r] where r is the next pseudo-random number.\r\n    def next_rand_Microsoft:\r\n      .[0] as $count | .[1] as $state\r\n      | ( (214013 * $state) + 2531011) % 2147483648 # mod 2^31\r\n      | [$count+1 , ., (. / 65536 | floor) ] ;\r\n    \r\n    # generate a stream of random integers &lt; $n\r\n    def randoms($n):\r\n      def r: next_rand_Microsoft\r\n        | (.[2] % $n), r;\r\n      [0,11] | r ;\r\n    \r\n    \r\n    . as $in\r\n    | ($names|length) as $count\r\n    | (.features|length) as $n\r\n    | [limit($n; randoms($count))] as $randoms\r\n    | reduce range(0; $n) as $i (.;\r\n        .features[$i].properties.name = $names[$randoms[$i]] )\r\n\r\n",
                "title": "Replacing a value in a JSON structure with randomly-chosen strings from a list using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1548121664,
        "creation_date": 1547748470,
        "last_edit_date": 1547769994,
        "question_id": 54241829,
        "body_markdown": "There are lots of similar questions but none for dynamically joining 2 files.\r\nWhat I&#39;m trying to do is to dynamically edit the following structure:\r\n\r\n```\r\n{\r\n  &quot;features&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;Feature&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;name&quot;: &quot;0&quot;,\r\n        &quot;height&quot;: 0.7\r\n      }\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;Feature&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;name&quot;: &quot;1&quot;,\r\n        &quot;height&quot;: 0\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI want to replace only the one field `.features[].properties.name` with a random value from a 1d-array inside another txt file. There are 8,000 features and around 100 names I&#39;ve prepared.  \r\n\r\nThis is what I&#39;ve got now failing with errors:\r\n```\r\n#!/bin/bash\r\ndeclare -a names=(&quot;name1&quot; &quot;name2&quot; &quot;name3&quot;)\r\njq &#39;{\r\n    &quot;features&quot; : [\r\n        &quot;type&quot; : &quot;Feature&quot;,\r\n        &quot;properties&quot; : {\r\n            &quot;name&quot; : `$names[seq 0 100]`,\r\n            &quot;height&quot; : .features[].properties.height\r\n        },\r\n        .features[].geometry\r\n    ]\r\n}&#39; &lt; areas.json\r\n\r\n```\r\n\r\nIs it even possible to do in a single command or I should use python or js for such tasks?",
        "link": "https://stackoverflow.com/questions/54241829/replacing-a-value-in-a-json-structure-with-randomly-chosen-strings-from-a-list-u",
        "title": "Replacing a value in a JSON structure with randomly-chosen strings from a list using jq"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "jq",
            "amazon-iam"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547762901,
                "post_id": 54244859,
                "comment_id": 95314458,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 77406,
                    "reputation": 14202,
                    "user_id": 220949,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/883143691cd80ebe6812fc195171dae8?s=256&d=identicon&r=PG",
                    "display_name": "arod",
                    "link": "https://stackoverflow.com/users/220949/arod"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1547763939,
                "post_id": 54244859,
                "comment_id": 95314812,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1547834162,
                "last_edit_date": 1547834162,
                "creation_date": 1547765238,
                "answer_id": 54245390,
                "question_id": 54244859,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## Obtaining the paths and objects satisfying the condition\r\n\r\n[This section addresses the question as originally worded, that is, when the question specifically asked for the paths to the objects of interest.]\r\n\r\n    paths(objects and has(&quot;Action&quot;) \r\n          and (.Action == &quot;*&quot; or (.Action|index(&quot;*&quot;)))) as $path\r\n    | [ $path, getpath($path)]\r\n\r\n## Collapsing the input based on the selection criterion\r\n\r\n    . as $in\r\n    | reduce paths(objects and has(&quot;Action&quot;)\r\n                   and (.Action == &quot;*&quot; or (.Action|index(&quot;*&quot;)))) as $path\r\n        ({}; setpath($path; $in | getpath($path)))\r\n\r\nGiven input similar to that shown in the Q, the filter immediately above would produce:\r\n\r\n    {\r\n      &quot;AssumeRolePolicyDocument&quot;: {\r\n        &quot;Statement&quot;: [\r\n          {\r\n            &quot;Action&quot;: &quot;*&quot;,\r\n            &quot;Effect&quot;: &quot;Allow&quot;,\r\n            &quot;Principal&quot;: {\r\n              &quot;Service&quot;: &quot;ec2.amazonaws.com&quot;\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    }",
                "title": "Search string with jq on any level"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1550677102,
        "creation_date": 1547762201,
        "last_edit_date": 1547825776,
        "question_id": 54244859,
        "body_markdown": "I want to use `jq` to extract any appeareance of the key `Action` in a JSON file. `Action` appears multiple times in the JSON within different paths (or same path-key-structure with different values).\r\n\r\nThe use case is to extract all IAM policies that give `*` permissions.\r\n\r\nI want to select cases in which .Action is the value &quot;*&quot; or is an array with `&quot;*&quot;` as an element, like \r\n\r\n    &quot;Action&quot;:[&quot;not this&quot;, &quot;*&quot;, &quot;not that&quot;]\r\n\r\nAs a plus, it would be good to include the piece of JSON that contains the `&quot;Action&quot;` up to some levels above.\r\n\r\nFor example this JSON :\r\n\r\n        {\r\n            &quot;AssumeRolePolicyDocument&quot;: {\r\n                &quot;Version&quot;: &quot;2012-10-17&quot;,\r\n                &quot;Statement&quot;: [\r\n                    {\r\n                        &quot;Action&quot;: &quot;*&quot;,\r\n                        &quot;Effect&quot;: &quot;Allow&quot;,\r\n                        &quot;Principal&quot;: {\r\n                            &quot;Service&quot;: &quot;ec2.amazonaws.com&quot;\r\n                        }\r\n                    }\r\n                ]\r\n            },\r\n            ...\r\n\r\n\r\nIt would be extracted\r\n\r\n        {\r\n            &quot;AssumeRolePolicyDocument&quot;: {\r\n                &quot;Version&quot;: &quot;2012-10-17&quot;,\r\n                &quot;Statement&quot;: [\r\n                    {\r\n                        &quot;Action&quot;: &quot;*&quot;,\r\n                        &quot;Effect&quot;: &quot;Allow&quot;,\r\n                        &quot;Principal&quot;: {\r\n                            &quot;Service&quot;: &quot;ec2.amazonaws.com&quot;\r\n                        }\r\n                    }\r\n                ]\r\n            },\r\n            ...\r\n        }\r\n\r\n\r\nIs this achievable with `jq`, and how?",
        "link": "https://stackoverflow.com/questions/54244859/search-string-with-jq-on-any-level",
        "title": "Search string with jq on any level"
    },
    {
        "tags": [
            "json",
            "shell",
            "select",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1547821787,
                "last_edit_date": 1547821787,
                "creation_date": 1547818052,
                "answer_id": 54255008,
                "question_id": 54254963,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "All you need to do is add a `select` call in your map function, like so:\r\n\r\n    jq &#39;map(select(.website_ids.item[] | contains(&quot;4&quot;)))&#39;\r\n\r\nAfter your edit, it&#39;s a bit more complicated, but it can be worked around by checking the type of `.website_ids.item` and then based off of that type, doing a contains check or a simple equality check:\r\n\r\n    map((select((.website_ids.item | type) == &quot;array&quot;) | select(.website_ids.item[] | contains(&quot;4&quot;))), (select((.website_ids.item | type) == &quot;string&quot;) | select (.website_ids.item == &quot;4&quot;)))\r\n\r\nHere it is formatted a bit more readable:\r\n\r\n    map(\r\n        (select((.website_ids.item | type) == &quot;array&quot;) | select(.website_ids.item[] | contains(&quot;4&quot;))),\r\n        (select((.website_ids.item | type) == &quot;string&quot;) | select (.website_ids.item == &quot;4&quot;))\r\n    )",
                "title": "Nested filtering with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1548124247,
        "creation_date": 1547817877,
        "last_edit_date": 1548115164,
        "question_id": 54254963,
        "body_markdown": "First time user of jq and I&#39;m wanting to filter out objects based on a value within them and I&#39;m struggling to figure it out.\r\n\r\nI have a big json file with lots of product data like what&#39;s below. I&#39;m wanting to filter out based upon which website_ids they have.\r\n\r\nExample Input:\r\n\r\n    [{\r\n        &quot;product_id&quot;: &quot;2&quot;,\r\n        &quot;sku&quot;: &quot;PROD2&quot;,\r\n        &quot;name&quot;: &quot;Product Name 2&quot;,\r\n        &quot;set&quot;: &quot;4&quot;,\r\n        &quot;type&quot;: &quot;simple&quot;,\r\n        &quot;category_ids&quot;: {\r\n          &quot;item&quot;: &quot;15&quot;\r\n        },\r\n        &quot;website_ids&quot;: {\r\n          &quot;item&quot;: [\r\n          &quot;1&quot;,\r\n          &quot;4&quot;\r\n        ]}\r\n    },{\r\n        &quot;product_id&quot;: &quot;3&quot;,\r\n        &quot;sku&quot;: &quot;PROD3&quot;,\r\n        &quot;name&quot;: &quot;Product Name 3&quot;,\r\n        &quot;set&quot;: &quot;4&quot;,\r\n        &quot;type&quot;: &quot;simple&quot;,\r\n        &quot;category_ids&quot;: {\r\n          &quot;item&quot;: &quot;15&quot;\r\n        },\r\n        &quot;website_ids&quot;: {\r\n          &quot;item&quot;: [\r\n          &quot;1&quot;,\r\n          &quot;2&quot;\r\n        ]}\r\n    }]\r\n\r\nDesired output:\r\n\r\n    [{\r\n        &quot;product_id&quot;: &quot;2&quot;,\r\n        &quot;sku&quot;: &quot;PROD2&quot;,\r\n        &quot;name&quot;: &quot;Product Name 2&quot;,\r\n        &quot;set&quot;: &quot;4&quot;,\r\n        &quot;type&quot;: &quot;simple&quot;,\r\n        &quot;category_ids&quot;: {\r\n          &quot;item&quot;: &quot;15&quot;\r\n        },\r\n        &quot;website_ids&quot;: {\r\n          &quot;item&quot;: [\r\n          &quot;1&quot;,\r\n          &quot;4&quot;\r\n        ]}\r\n    }]\r\n\r\nI&#39;ve tried a few different things but I&#39;m clearly just not getting it.\r\n\r\n```jq &#39;map(.website_ids.item[] | contains(&quot;4&quot;))&#39;```\r\n\r\nGives me:\r\n\r\n    [\r\n      false,\r\n      true,\r\n      false,\r\n      false\r\n    ]\r\n\r\nWhich seems to match the website_ids items I want, but I&#39;m not sure how to get the full JSON object from that.\r\n\r\nAny help would be super appreciated! Thanks.\r\n\r\nEDIT:\r\n\r\nI&#39;ve used this and it works with my example:\r\n\r\n```map(select(.website_ids.item[] | contains(&quot;4&quot;)))```\r\n\r\nWhat I&#39;ve realised is that my example and the file I was actually testing on have some differences.\r\n\r\nSometimes a product has this for the website_id items:\r\n\r\n   &quot;website_ids&quot;: {\r\n      &quot;item&quot;: &quot;2&quot;\r\n   }\r\n\r\nWhich results in the error:\r\n\r\n```Cannot iterate over string (&quot;2&quot;)```\r\n\r\nIs there a way around this?",
        "link": "https://stackoverflow.com/questions/54254963/nested-filtering-with-jq",
        "title": "Nested filtering with jq"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1548131483,
                "post_id": 54300938,
                "comment_id": 95422683,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 229143,
                    "reputation": 1304,
                    "user_id": 491894,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/05abfb520b1fafe57e2e5594ad9f82f1?s=256&d=identicon&r=PG",
                    "display_name": "harleypig",
                    "link": "https://stackoverflow.com/users/491894/harleypig"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1548132513,
                "post_id": 54300938,
                "comment_id": 95422927,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1548131738,
                "creation_date": 1548131738,
                "answer_id": 54301348,
                "question_id": 54300938,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It would be less klunky, and perhaps a bit more robust, if instead of:\r\n\r\n    jq -r &#39;. | to_entries | .[] | .key + &quot;=&quot; + .value &#39;)\r\n\r\nyou had:\r\n\r\n    jq -r &#39;to_entries[] | &quot;\\(.key)=\\(.value)&quot;&#39;\r\n\r\nAnd similarly you could replace the `for` loop used to create the JSON object with something like:\r\n\r\n    for key in &quot;${!aaname[@]}&quot;; do\r\n        printf &quot;%s\\n&quot; &quot;$key&quot;\r\n        printf &quot;%s\\n&quot; &quot;${aaname[$key]}&quot;\r\n    done | jq -Rn &#39;[inputs | { (.): input}] | add&#39;\r\n\r\nRegarding the second issue, I&#39;m afraid your question isn&#39;t so clear to me.\r\nWhat format are you expecting for the non-JSON representation?\r\nHow generic a serialization/deserialization solution are you expecting?\r\nIn this connection, you might like to look at the output of `jq --stream . &lt;&lt;&lt; &quot;$json&quot;`\r\nfor various JSON texts.\r\n\r\n",
                "title": "Serializing and de-serializing an associative array in bash using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1548134910,
        "creation_date": 1548128504,
        "last_edit_date": 1548134910,
        "question_id": 54300938,
        "body_markdown": "I have some bash code that serializes and de-serializes a single dimensional associative array in bash using jq. It does what I want for now, but I have two issues.\r\n\r\nThe first issue is, this code feels really klunky. Especially the serialization part. Is there a better way to do this? Either with jq or some other way?\r\n\r\nThe second issue is, I can deserialize nested data (.e.g, with `{&quot;data&quot;:{...}}`) but I can&#39;t figure out how to wrap the output in the same nested structure. How can I recreate the original structure?\r\n\r\nEdit: Clarification. What I want to be able to do is, with the commented json, `json=&#39;{&quot;data&quot;: {&quot;one&quot;: &quot;1&quot;, &quot;two&quot;: &quot;2&quot;, &quot;three&quot;: &quot;3&quot;}}&#39;` in the example code and have the final result of `\r\njson=&#39;{&quot;data&quot;: {&quot;four&quot;: &quot;4&quot;, &quot;one&quot;: &quot;100&quot;, &quot;two&quot;: &quot;2&quot;}}` dumped.\r\n\r\nI can read in the &#39;data&#39; structure and assign the key/values correctly, but I&#39;m not having any luck in figuring out how to embed the `{&quot;four&quot;: ...}` construct into the `&quot;data&quot;:  {...}` object.\r\n\r\nEdit 2: The answer to my second issue, in combination with peak&#39;s answer is the following:\r\n\r\n```language=bash\r\nfor key in &quot;${!aaname[@]}&quot;; do\r\n  printf &#39;%s\\n%s\\n&#39; &quot;$key&quot; &quot;${aaname[$key]}&quot;\r\ndone | jq -SRn &#39;.data = ([inputs | {(.): input}] | add)&#39;\r\n```\r\n\r\nThe code is:\r\n\r\n```language=bash\r\n#!/bin/bash\r\n\r\n#json=&#39;{&quot;data&quot;: {&quot;one&quot;: &quot;1&quot;, &quot;two&quot;: &quot;2&quot;, &quot;three&quot;: &quot;3&quot;}}&#39;\r\njson=&#39;{&quot;one&quot;: &quot;1&quot;, &quot;two&quot;: &quot;2&quot;, &quot;three&quot;: &quot;3&quot;}&#39;\r\n\r\n#------------------------------------------------------------------------------\r\n# De-serialize data\r\n\r\ndeclare -A aaname\r\n\r\nwhile IFS=&#39;=&#39; read -r key value; do\r\n  aaname[&quot;$key&quot;]=&quot;$value&quot;\r\ndone &lt; &lt;(echo &quot;$json&quot; | jq -r &#39;. | to_entries | .[] | .key + &quot;=&quot; + .value &#39;)\r\n#done &lt; &lt;(echo &quot;$json&quot; | jq -r &#39;.data | to_entries | .[] | .key + &quot;=&quot; + .value &#39;)\r\n\r\n#------------------------------------------------------------------------------\r\n# Manipulate data\r\n\r\n# Change existing value ...\r\naaname[&#39;one&#39;]=&#39;100&#39;\r\n\r\n# Add element ...\r\naaname[&#39;four&#39;]=&#39;4&#39;\r\n\r\n# Remove element ...\r\nunset aaname[&#39;three&#39;]\r\n\r\n#------------------------------------------------------------------------------\r\n# Serialize data\r\n\r\n# Why can&#39;t I use ${#aaname[@]} in ((...))?\r\ntotal=&quot;${#aaname[@]}&quot;\r\ncount=0\r\n\r\n{\r\n  printf &#39;[&#39;\r\n  for key in &quot;${!aaname[@]}&quot;; do\r\n    printf &#39;{&quot;key&quot;: &quot;%s&quot;, &quot;value&quot;: &quot;%s&quot;}&#39; &quot;$key&quot; &quot;${aaname[$key]}&quot;\r\n    ((++count &lt; total)) &amp;&amp; printf &#39;,&#39;\r\n  done\r\n  printf &#39;]&#39;\r\n#}\r\n#} | jq -S &#39; . | &quot;data{&quot; + from_entries + &quot;}&quot;&#39;\r\n} | jq -S &#39; . | from_entries&#39;\r\n\r\n# gives\r\n#\r\n#{\r\n#  &quot;four&quot;: &quot;4&quot;,\r\n#  &quot;one&quot;: &quot;100&quot;,\r\n#  &quot;two&quot;: &quot;2&quot;\r\n#}\r\n```",
        "link": "https://stackoverflow.com/questions/54300938/serializing-and-de-serializing-an-associative-array-in-bash-using-jq",
        "title": "Serializing and de-serializing an associative array in bash using jq"
    },
    {
        "tags": [
            "json",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1548161130,
                "last_edit_date": 1548161130,
                "creation_date": 1548160744,
                "answer_id": 54308488,
                "question_id": 54306265,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq -n &#39;input as $b | input\r\n    | .one.vars |= . + $b.one.vars\r\n    | .two.vars |= . + $b.two.vars&#39; file2.json file1.json\r\n\r\n`file1.json` must come after `file2.json` in order to preserve `extras`.",
                "title": "Merge two complex JSON objects with arrays"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1548215448,
                "last_edit_date": 1548215448,
                "creation_date": 1548214167,
                "answer_id": 54319628,
                "question_id": 54306265,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, here is a solution which is oblivious to the top-level key names, but which does not attempt to avoid duplicates:\r\n\r\n    $A\r\n    | reduce keys_unsorted[] as $k (.;\r\n        if .[$k] | (type == &quot;object&quot;) and has(&quot;vars&quot;)\r\n        then (.[$k]|.vars) += ($B[$k]|.vars) else . end )\r\n  \r\nHere of course $A and $B refer to the two objects.  You can set $A and $B in several ways.\r\n\r\nIf you want to reorder the top-level keys, you can simply extend the above with a filter specifying the order, e.g.: `{extras, two, one}`.\r\n\r\nTo avoid duplicates, I&#39;d suggest writing a helper function to do just that, as illustrated in the following section.\r\n\r\n## Avoiding duplicates\r\n\r\n    def extend(stream):\r\n      reduce stream as $s (.;\r\n        (map(.name) | index($s|.name)) as $i\r\n        | if $i then .[$i] += $s\r\n    \t  else . + [$s]\r\n          end) ;\r\n    \r\n    \r\n    $A\r\n    | reduce keys_unsorted[] as $k (.;\r\n        if .[$k] | (type == &quot;object&quot;) and has(&quot;vars&quot;)\r\n        then (.[$k].vars) = ( .[$k].vars | extend(($B[$k].vars[])))\r\n        else . end\r\n      )\r\n\r\n\r\n\r\n\r\n",
                "title": "Merge two complex JSON objects with arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1548215448,
        "creation_date": 1548153107,
        "last_edit_date": 1548159620,
        "question_id": 54306265,
        "body_markdown": "I have the two following json as input:\r\n```json\r\n{\r\n  &quot;one&quot;: {\r\n    &quot;vars&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;a&quot;,\r\n        &quot;value&quot;: &quot;a&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;b&quot;,\r\n        &quot;value&quot;: &quot;b&quot;\r\n      }\r\n    ]\r\n  },\r\n  &quot;two&quot;: {\r\n    &quot;vars&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;c&quot;,\r\n        &quot;value&quot;: &quot;c&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;d&quot;,\r\n        &quot;value&quot;: &quot;d&quot;\r\n      }\r\n    ]\r\n  },\r\n  &quot;extras&quot;: &quot;whatever&quot;\r\n}\r\n```\r\n\r\n```json\r\n{\r\n  &quot;one&quot;: {\r\n    &quot;vars&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;e&quot;,\r\n        &quot;value&quot;: &quot;e&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;f&quot;,\r\n        &quot;value&quot;: &quot;f&quot;\r\n      }\r\n    ]\r\n  },\r\n  &quot;two&quot;: {\r\n    &quot;vars&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;g&quot;,\r\n        &quot;value&quot;: &quot;g&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;h&quot;,\r\n        &quot;value&quot;: &quot;h&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nAnd I&#39;d like to merge them in order to obtain the following result where each of the `vars` array of each section are merged together:\r\n```\r\n{\r\n  &quot;one&quot;: {\r\n    &quot;vars&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;a&quot;,\r\n        &quot;value&quot;: &quot;a&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;b&quot;,\r\n        &quot;value&quot;: &quot;b&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;e&quot;,\r\n        &quot;value&quot;: &quot;e&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;f&quot;,\r\n        &quot;value&quot;: &quot;f&quot;\r\n      }\r\n    ]\r\n  },\r\n  &quot;two&quot;: {\r\n    &quot;vars&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;c&quot;,\r\n        &quot;value&quot;: &quot;c&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;d&quot;,\r\n        &quot;value&quot;: &quot;d&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;g&quot;,\r\n        &quot;value&quot;: &quot;g&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;h&quot;,\r\n        &quot;value&quot;: &quot;h&quot;\r\n      }\r\n    ]\r\n  },\r\n  &quot;extras&quot;: &quot;whatever&quot;\r\n}\r\n```\r\n\r\nIdeally but not mandatory:\r\n\r\n - the keys (here `one` and `two`) would be arbitrary and an undefined number of them could be present.\r\n - the `vars` array would not contain duplicate (based on `name`) and right precedence would be applied to override values from the first array.\r\n\r\nI managed to merge the two objects and only 1 array with the following command but the key is hardcoded and I&#39;m a bit stuck from there:\r\n```\r\njq -s &#39;.[0].one.vars=([.[].one.vars]|flatten)|.[0]&#39; file1.json file2.json\r\n```",
        "link": "https://stackoverflow.com/questions/54306265/merge-two-complex-json-objects-with-arrays",
        "title": "Merge two complex JSON objects with arrays"
    },
    {
        "tags": [
            "json",
            "bash",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1548166259,
                "creation_date": 1548166259,
                "answer_id": 54310130,
                "question_id": 54309985,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    echo &quot;$objects&quot; | jq &#39;select(.name == &quot;thing2&quot;)&#39;",
                "title": "Get JSON Object by property with jq / bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1548171394,
        "creation_date": 1548165784,
        "last_edit_date": 1548171394,
        "question_id": 54309985,
        "body_markdown": "I have some JSON objects that looks like this\r\n\r\n    {\r\n     &quot;name&quot;: &quot;thing1&quot;,\r\n     &quot;important_value&quot;: &quot;42&quot;,\r\n     &quot;other_value&quot;: &quot;27&quot;\r\n    }\r\n    {\r\n     &quot;name&quot;: &quot;thing2&quot;,\r\n     &quot;important_value&quot;: &quot;13&quot;,\r\n     &quot;other_value&quot;: &quot;5&quot;\r\n    }\r\n    {\r\n     &quot;name&quot;: &quot;thing3&quot;,\r\n     &quot;important_value&quot;: &quot;788&quot;,\r\n     &quot;other_value&quot;: &quot;58&quot;\r\n    }\r\n\r\nI need to get the value from only one of these object, but I only know the &quot;name&quot; value. I&#39;ve tried somthing like this:\r\n\r\n    echo $objects | jq &#39;.name == &quot;thing2&quot;&#39;\r\n\r\nI then get \r\n\r\n    false\r\n    true\r\n    false\r\nBut I need to get the values from this object, how do I achive this?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54309985/get-json-object-by-property-with-jq-bash",
        "title": "Get JSON Object by property with jq / bash"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1548274898,
                "post_id": 54332521,
                "comment_id": 95487501,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2705066,
                    "reputation": 329,
                    "user_id": 2334833,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a2b63e032d5bedffa0a2519ed94d4ea1?s=256&d=identicon&r=PG",
                    "display_name": "Aksanth",
                    "link": "https://stackoverflow.com/users/2334833/aksanth"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1548276512,
                "post_id": 54332521,
                "comment_id": 95488163,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1678474439,
                "post_id": 54332521,
                "comment_id": 133545980,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1678474789,
                "last_edit_date": 1678474789,
                "creation_date": 1548267015,
                "answer_id": 54333221,
                "question_id": 54332521,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The question seems to me self-inconsistent, but under all the interpretations I can think of, the key is to use `|=`:\r\n```\r\n.amazon\r\n| .items[] |= (if (.name | contains (&quot;shoes&quot;)) and .status == null \r\n               then .status=&quot;IN PROCESS&quot; else . end)\r\n```\r\n\r\nor to select the items with .name containing &quot;shoes&quot;:\r\n```\r\n.amazon\r\n| .items |= map(select(.name | contains (&quot;shoes&quot;))\r\n                | if .status == null then .status=&quot;IN PROCESS&quot;\r\n                  else . end)\r\n```\r\n\r\nEtc.",
                "title": "How to check for null or empty in jq and substitute for empty string in jq transformation"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1678474789,
        "creation_date": 1548264094,
        "last_edit_date": 1548276351,
        "question_id": 54332521,
        "body_markdown": "How to check for null or empty in jq and substitute for empty string in jq transformation.\r\n\r\nExample in below JSON, this is the JQ \r\n\r\nJQ:\r\n       \r\n       .amazon.items[] | select(.name | contains (&quot;shoes&quot;)) as $item |\r\n       {\r\n            activeItem: .amazon.activeitem,\r\n            item : {\r\n             id : $item.id,\r\n             state : $item.state,\r\n             status : if [[ $item.status = &quot;&quot; or $item.status = null ]]; \r\n            then &#39;IN PROCESS&#39; ; else $item.status end\r\n             }  \r\n       }\r\n\r\n\r\nJSON:\r\n\r\n      {\r\n        &quot;amazon&quot;: {\r\n          &quot;activeitem&quot;: 2,\r\n          &quot;items&quot;: [\r\n            {\r\n              &quot;id&quot;: 1,\r\n              &quot;name&quot;: &quot;harry potter&quot;,\r\n              &quot;state&quot;: &quot;sold&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: 2,\r\n              &quot;name&quot;: &quot;adidas shoes&quot;,\r\n              &quot;state&quot;: &quot;in inventory&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: 3,\r\n              &quot;name&quot;: &quot;watch&quot;,\r\n              &quot;state&quot;: &quot;returned&quot;\r\n            },{\r\n              &quot;id&quot;: 4,\r\n              &quot;name&quot;: &quot;Nike shoes&quot;,\r\n              &quot;state&quot;: &quot;in inventory&quot;\r\n            }\r\n          ]\r\n        }\r\n      } \r\n\r\nI want to add a default string &quot;In Process&quot; if the status is empty or Null.\r\n\r\nBased on Item condition, using the query below and take the first object from the filtered results.\r\n\r\n`code`\r\n       .amazon.items[] | select(.name | contains (&quot;shoes&quot;))\r\n`code`\r\n\r\nExpected Output:\r\n\r\n    {\r\n        &quot;activeitem&quot;: 2,\r\n        &quot;item&quot;: {\r\n          &quot;id&quot;: 2,\r\n          &quot;name&quot;: &quot;adidas shoes&quot;,\r\n          &quot;state&quot;: &quot;in inventory&quot;,\r\n          &quot;status&quot;: &quot;IN PROCESS&quot;\r\n        }\r\n      }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54332521/how-to-check-for-null-or-empty-in-jq-and-substitute-for-empty-string-in-jq-trans",
        "title": "How to check for null or empty in jq and substitute for empty string in jq transformation"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1548385645,
                "last_edit_date": 1548385645,
                "creation_date": 1548312416,
                "answer_id": 54340798,
                "question_id": 54333170,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a simple solution that takes into account leap years:\r\n\r\n    # Input and output are both in milliseconds since the epoch; \r\n    # the output time is later than the input time by $n units, where\r\n    # the units are determined by $unit, one of the strings in `dict`.\r\n    def later($n; $unit):\r\n      def dict: { YEAR:0, MONTH:1, DAY:2, HOUR:3, MINUTE:4, SECOND:5, MIN:4, SEC:5};\r\n      gmtime\r\n      | .[dict[$unit]] += $n\r\n      | mktime ;\r\n\r\n## Testing\r\n\r\n    (&quot;2019-01-24&quot; | strptime(&quot;%Y-%m-%d&quot;) | mktime)\r\n    | (later(2; &quot;YEAR&quot;), later(731; &quot;DAY&quot;))\r\n    | strftime(&quot;%Y-%m-%d&quot;)\r\n\r\nOutput is as expected (as 2020 is a leap year):\r\n\r\n    &quot;2021-01-24&quot;\r\n    &quot;2021-01-24&quot;\r\n\r\n---\r\n&lt;sub&gt;keyword: addTime&lt;/sub&gt;\r\n",
                "title": "How to add a duration which can be in any time unit to a given timestamp in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1548385645,
        "creation_date": 1548266758,
        "last_edit_date": 1548268709,
        "question_id": 54333170,
        "body_markdown": "    {\r\n    \t&quot;applicationDuration&quot;: {\r\n    \t&quot;duration&quot;: 4,\r\n    \t&quot;unit&quot;: &quot;DAY&quot;\r\n    \t},\r\n    \t&quot;startTime&quot;: {\r\n    \t&quot;long&quot;: 1539196595567\r\n    \t}\r\n    }\r\n\r\nI am writing a jq script which takes a json with the fields similar to above. The goal is to increment the `startTime` by adding the given `duration`. `startTime` is in milliseconds whereas `duration` can be any time unit (ms, sec, min, hr, day, week, month, year) which is provided with `unit`. Is it possible to do something like below?\r\n\r\n    startTime = ToMillis(FOO(startTime) + BAR(duration, unit))\r\n\r\nSimilar to java`s: https://www.javacodex.com/Date-and-Time/Add-Time-To-A-Timestamp",
        "link": "https://stackoverflow.com/questions/54333170/how-to-add-a-duration-which-can-be-in-any-time-unit-to-a-given-timestamp-in-jq",
        "title": "How to add a duration which can be in any time unit to a given timestamp in jq?"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1548285384,
                "creation_date": 1548285384,
                "answer_id": 54337162,
                "question_id": 54334293,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To edit &quot;in-place&quot; you could write:\r\n\r\n    .amazon\r\n    | .items |= map(select(.name | contains (&quot;shoes&quot;)))[0]\r\n\r\n\r\nIf you really want to change the name &#39;items&#39; to &#39;item&#39;, you could tweak the above as follows:\r\n\r\n    .amazon\r\n    | .item = (.items | map(select(.name | contains (&quot;shoes&quot;)))[0])\r\n    | del(.items)\r\n\r\n",
                "title": "Selecting in JQ with Contains in a Array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1627343494,
        "creation_date": 1548271420,
        "last_edit_date": 1627343494,
        "question_id": 54334293,
        "body_markdown": "I want to select the particular item from the array using `contains` and get the first item using JQ.\r\n\r\nJQ:\r\n\r\n    .amazon.items[] | select(.name | contains (&quot;shoes&quot;)) \r\n\r\nJSON:\r\n\r\n    {\r\n      &quot;amazon&quot;: {\r\n        &quot;activeitem&quot;: 2,\r\n        &quot;items&quot;: [\r\n          {\r\n            &quot;id&quot;: 1,\r\n            &quot;name&quot;: &quot;harry potter&quot;,\r\n            &quot;state&quot;: &quot;sold&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: 2,\r\n            &quot;name&quot;: &quot;adidas shoes&quot;,\r\n            &quot;state&quot;: &quot;in inventory&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: 3,\r\n            &quot;name&quot;: &quot;watch&quot;,\r\n            &quot;state&quot;: &quot;returned&quot;\r\n          },{\r\n            &quot;id&quot;: 4,\r\n            &quot;name&quot;: &quot;adidas shoes&quot;,\r\n            &quot;state&quot;: &quot;in inventory&quot;\r\n          }\r\n        ]\r\n      }\r\n    } \r\n\r\n\r\nExpected Result:\r\n\r\n    {\r\n      &quot;activeitem&quot;: 2,\r\n      &quot;item&quot;: {\r\n        &quot;id&quot;: 2,\r\n        &quot;name&quot;: &quot;adidas shoes&quot;,\r\n        &quot;state&quot;: &quot;in inventory&quot;\r\n      }\r\n    }\r\n\r\n\r\n\r\nActual :\r\n\r\nTried various options like but not getting the Intended response .\r\n\r\n1. `.amazon.items[] |  select(.name | contains (&quot;shoes&quot;))` \r\n2. `.amazon.items |  select(.[].name | contains (&quot;shoes&quot;)) | .[0]`\r\n\r\nAlso when I try to combine `activeitem` and `item`, I get something like this, which is also wrong.\r\n\r\n    {\r\n      &quot;activeitem&quot;: 2,\r\n      &quot;item&quot;: {\r\n        &quot;id&quot;: 2,\r\n        &quot;name&quot;: &quot;adidas shoes&quot;,\r\n        &quot;state&quot;: &quot;in inventory&quot;\r\n      }\r\n    },\r\n      {\r\n      &quot;activeitem&quot;: 2,\r\n      &quot;item&quot;: {\r\n        &quot;id&quot;: 2,\r\n        &quot;name&quot;: &quot;adidas shoes&quot;,\r\n        &quot;state&quot;: &quot;in inventory&quot;\r\n      }\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/54334293/selecting-in-jq-with-contains-in-a-array",
        "title": "Selecting in JQ with Contains in a Array"
    },
    {
        "tags": [
            "arrays",
            "json",
            "object",
            "addition",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1548346857,
                "creation_date": 1548346857,
                "answer_id": 54351099,
                "question_id": 54350532,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The key to a simple solution is `transpose`:\r\n\r\n    [.a, .h]\r\n    | transpose\r\n    | map(add)\r\n    | {l: .}",
                "title": "JQ how to merge multiple objects in an array into one"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1548347021,
        "creation_date": 1548344984,
        "last_edit_date": 1548347021,
        "question_id": 54350532,
        "body_markdown": "A little more sophisticated as my question mentioned below.\r\nI learned to use arrays more, but it screws things up too.\r\n\r\nInput:\r\n\r\n    {\r\n      &quot;a&quot;: [\r\n        {\r\n          &quot;b&quot;: &quot;c&quot;,\r\n          &quot;d&quot;: &quot;e&quot;\r\n        },\r\n        {\r\n          &quot;b&quot;: &quot;f&quot;,\r\n          &quot;d&quot;: &quot;g&quot;\r\n        }\r\n      ],\r\n      &quot;h&quot;: [\r\n        {\r\n          &quot;b&quot;: &quot;c&quot;,\r\n          &quot;i&quot;: &quot;j&quot;\r\n        },\r\n        {\r\n          &quot;b&quot;: &quot;f&quot;,\r\n          &quot;i&quot;: &quot;k&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\ndesired output:\r\n\r\n    {\r\n      &quot;l&quot;: [\r\n        {\r\n          &quot;b&quot;: &quot;c&quot;,\r\n          &quot;d&quot;: &quot;e&quot;,\r\n          &quot;i&quot;: &quot;j&quot;\r\n        },\r\n        {\r\n          &quot;b&quot;: &quot;f&quot;,\r\n          &quot;d&quot;: &quot;g&quot;,\r\n          &quot;i&quot;: &quot;k&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nThings that I&#39;ve tried, based up on [https://stackoverflow.com/questions/51491317/jq-how-to-merge-multiple-objects-into-one][1]\r\n\r\n    { x: [ inputs | .a[] | { (.h[]): .i } ] | add}\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/51491317/jq-how-to-merge-multiple-objects-into-one",
        "link": "https://stackoverflow.com/questions/54350532/jq-how-to-merge-multiple-objects-in-an-array-into-one",
        "title": "JQ how to merge multiple objects in an array into one"
    },
    {
        "tags": [
            "json",
            "bash",
            "validation",
            "logging",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1548348412,
                "post_id": 54351510,
                "comment_id": 95518497,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14500772,
                    "reputation": 91,
                    "user_id": 10474032,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9a2a6bae2280635de869ee7eba1798ba?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Hustlin",
                    "link": "https://stackoverflow.com/users/10474032/hustlin"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1548349861,
                "post_id": 54351510,
                "comment_id": 95519357,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1548351003,
                "post_id": 54351510,
                "comment_id": 95519940,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1548353807,
                "last_edit_date": 1548353807,
                "creation_date": 1548349387,
                "answer_id": 54351912,
                "question_id": 54351510,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The first problem, as @Inian pointed out, is that there should be no space between &quot;--&quot; and &quot;arg&quot;.\r\n\r\nThe second problem is that there should be no spaces after the backslash when it is used (as here) for line-continuation: for the backslash to serve as a line-continuation character, it must escape (i.e. immediately precede) the newline.\r\n\r\nOtherwise, except possibly for some oddities such as `$(XXX version)`, you should be good to go, which is not to say there aren&#39;t better ways to create the JSON object.  See the next section for an illustration of an alternative approach.\r\n\r\n## Illustration of an alternative approach\r\n\r\nThe following approach can be used even if the keys and/or values contain control characters:\r\n\r\n    FMT=&quot;%s\\0%s\\0&quot;\r\n    (\r\n    printf $FMT systemTime $(date +%d-%m-%Y_%H:%M:%S)\r\n    printf $FMT newline &quot;$(echo a; echo b)&quot;\r\n    ) | jq -sR &#39;[split(&quot;\\u0000&quot;) | range(0;length;2) as $i | {(.[$i]): .[$i + 1]}] | add&#39;\r\n\r\nIf it is known that no keys or values contain literal newline characters, the following variant, which has the main advantage of not requiring the &quot;-s&quot; option, could be used:\r\n\r\n    (\r\n    echo systemTime\r\n    date +%d-%m-%Y_%H:%M:%S\r\n    echo uname\r\n    uname -a\r\n    echo softVersion\r\n    echo XXX version\r\n    ) | jq -nR &#39;[inputs as $key | {($key): input}] | add&#39;\r\n\r\n\r\n",
                "title": "JQ JSON Creation"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1548351422,
                "creation_date": 1548351422,
                "answer_id": 54352441,
                "question_id": 54351510,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use an array to store the arguments *before* calling `jq`; it&#39;s easier to spread the arguments across multiple lines in an array assignment, as the backslashes aren&#39;t necessary.\r\n\r\n    jq_args=(\r\n       --arg systemTime &quot;$systemTime&quot;\r\n       --arg sensorType &quot;$sensorType&quot;\r\n       --arg sensorLocation &quot;$sensorLocation&quot;\r\n       --arg sensorCommand &quot;$sensorCommand&quot;\r\n       --arg kernalName &quot;$kernalName&quot;\r\n       --arg nodeName &quot;$nodeName&quot;\r\n       --arg kernalRelease &quot;$kernalRelease&quot;\r\n       --arg kernalVersion &quot;$kernalVersion&quot; \r\n       --arg machine &quot;$machine&quot;\r\n       --arg processor &quot;$processor&quot;\r\n       --arg hardwarePlatform &quot;$hardwarePlatform&quot;\r\n       --arg operatingSystem &quot;$operatingSystem&quot;\r\n       --arg timeup &quot;$timeup&quot;\r\n       --arg softVersion &quot;$softVersion&quot;\r\n    )\r\n    JSON_STRING=$( jq -n &quot;${jq_args[@]}&quot; &#39;{\r\n       systemTime: $systemTime,\r\n       sensorType: $sensorType,\r\n       sensorLocation: $sensorLocation,\r\n       kernalName: $kernalName,\r\n       nodeName: $nodeName,\r\n       kernalRelease: $kernalRelease,\r\n       machine: $machine,\r\n       processor: $processor,\r\n       hardwarePlatform: $hardwarePlatform,\r\n       operatingSystem: $operatingSystem,\r\n       timeup: $timeup,\r\n       softVersion: $softVersion \r\n     }&#39; )\r\n\r\nIf you are using a version of `bash` that supports associative arrays, you can further simply the building of `jq_args`:\r\n\r\n    declare -A x\r\n    x=([systemTime]=&quot;$systemTime&quot;\r\n       [sensorType]=&quot;$sensorType&quot;\r\n       # etc\r\n      )\r\n\r\n    declare -a jq_args\r\n    for k in &quot;${!x[@]}&quot;; do\r\n      jq_args+=(--arg &quot;$k&quot; &quot;${x[$k]}&quot;)\r\n    done\r\n\r\n    JSON_STRING=$( jq -n &quot;${jq_args[@]}&quot; ... )",
                "title": "JQ JSON Creation"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1548353089,
                "creation_date": 1548353089,
                "answer_id": 54352887,
                "question_id": 54351510,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Not sure if this is the most efficient way of using JQ\r\n\r\nHere are two alternative approaches. The first is based on the TSV format, and the second the CSV format.\r\n\r\n## Using the TSV format\r\n\r\nThe following assumes that neither literal tabs nor literal newlines appear within keys or values.\r\n\r\n    FMT=&quot;%s\\t%s\\n&quot;\r\n    (\r\n    printf $FMT systemTime $(date +%d-%m-%Y_%H:%M:%S)\r\n    printf $FMT uname &quot;$(uname -a)&quot;\r\n    printf $FMT softVersion &quot;XXX version&quot;\r\n    ) | jq -nR &#39;[inputs | split(&quot;\\t&quot;) | {(.[0]): .[1]}] | add&#39;\r\n\r\n## Using a CSV-to-JSON utility\r\n\r\nThe approach illustrated here is probably mainly of interest if one starts with a CSV file of key-value pairs.\r\n\r\nIn the following, we&#39;ll use the excellent csv2json utility at https://github.com/fadado/CSV  There are actually two executables provided there.  Both convert each CSV row to a JSON array. We&#39;ll use `extended` symlinked to `csv2json`.\r\n\r\n    (\r\n    echo systemTime, $(date +%d-%m-%Y_%H:%M:%S)\r\n    echo uname, &quot;$(uname -a)&quot;\r\n    echo softVersion, XXX version\r\n    ) | csv2json \r\n      | jq -n &#39;[inputs as [$key, $value] | {($key): $value}] | add&#39;\r\n\r\n\r\n",
                "title": "JQ JSON Creation"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1548461883,
                "last_edit_date": 1548461883,
                "creation_date": 1548460940,
                "answer_id": 54374391,
                "question_id": 54351510,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you have all the values as environment variables, you could just utilize the `env` object to get the values. The syntax then becomes trivial.\r\n\r\n    systemTime=$(date +%d-%m-%Y_%H:%M:%S) \\\r\n    kernalName=$(uname -s) \\\r\n    nodeName=$(uname -i) \\\r\n    kernalRelease=$(uname -r) \\\r\n    kernalVersion=$(uname -v) \\\r\n    machine=$(uname -m) \\\r\n    processor=$(uname -p) \\\r\n    hardwarePlatform=$(uname -i) \\\r\n    operatingSystem=$(uname -o) \\\r\n    timeup=$(uptime) \\\r\n    jq -n &#39;env | {\r\n        systemTime,\r\n        sensorType,\r\n        sensorLocation,\r\n        kernalName,\r\n        nodeName,\r\n        kernalRelease,\r\n        machine,\r\n        processor,\r\n        hardwarePlatform,\r\n        operatingSystem,\r\n        timeup,\r\n        softVersion \r\n    }&#39;\r\n\r\n\r\n",
                "title": "JQ JSON Creation"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1548461883,
        "creation_date": 1548348187,
        "question_id": 54351510,
        "body_markdown": "New to JSON creation, decided to try JQ from [this question][1]. However, when I tried implementing it, all I received was the help page for JQ and these types of errors: `./test.sh: line 43: --: command not found` for the last three lines. \r\n\r\n```bash\r\n#!/bin/bash\r\n\r\necho Starting\r\n\r\nsensorType=&quot;XXX&quot;\r\nsensorLocation=&quot;XXX&quot;\r\nsensorCommand=&quot;XXXXX&quot;\r\n\r\n# Hardware information. \r\nsystemTime=$(date +%d-%m-%Y_%H:%M:%S)\r\nkernalName=$(uname -s)\r\nnodeName=$(uname -i)\r\nkernalRelease=$(uname -r)\r\nkernalVersion=$(uname -v)\r\nmachine=$(uname -m)\r\nprocessor=$(uname -p)\r\nhardwarePlatform=$(uname -i)\r\noperatingSystem=$(uname -o)\r\ntimeup=$(uptime)\r\n\r\n# Software information.\r\nsoftVersion=$(XXX version)\r\n\r\nJSON_STRING=$( jq -n \\\r\n                -- arg systemTime &quot;$systemTime&quot; \\\r\n                -- arg sensorType &quot;$sensorType&quot; \\\r\n                -- arg sensorLocation &quot;$sensorLocation&quot; \\\r\n                -- arg sensorCommand &quot;$sensorCommand&quot; \\\r\n                -- arg kernalName &quot;$kernalName&quot; \\\r\n                -- arg nodeName &quot;$nodeName&quot; \\\r\n                -- arg kernalRelease &quot;$kernalRelease&quot; \\\r\n                -- arg kernalVersion &quot;$kernalVersion&quot; \\ \r\n                -- arg machine &quot;$machine&quot; \\ \r\n                -- arg processor &quot;$processor&quot;\r\n                -- arg hardwarePlatform &quot;$hardwarePlatform&quot; \\\r\n                -- arg operatingSystem &quot;$operatingSystem&quot; \\\r\n                -- arg timeup &quot;$timeup&quot; \\\r\n                -- arg softVersion &quot;$softVersion&quot; \\\r\n                &#39;{systemTime: $systemTime, sensorType: $sensorType, sensorLocation: $sensorLocation, kernalName: $kernalName, nodeName: $nodeName, kernalRelease: $kernalRelease, machine: $machine, processor: $processor, hardwarePlatform: $hardwarePlatform, operatingSystem: $operatingSystem, timeup: $timeup, softVersion: $softVersion }&#39; )\r\n\r\necho $JSON_STRING\r\n\r\n```\r\n\r\nNot sure if this is the most efficient way of using JQ or if there is a better way to implement it. But I would love to hear if there is a more efficient / easier way to accomplish this. \r\n\r\n  [1]: https://stackoverflow.com/questions/48470049/build-a-json-string-with-bash-variables?noredirect=1&amp;lq=1",
        "link": "https://stackoverflow.com/questions/54351510/jq-json-creation",
        "title": "JQ JSON Creation"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1548368530,
                "last_edit_date": 1548368530,
                "creation_date": 1548357046,
                "answer_id": 54353762,
                "question_id": 54353243,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following filter meets the stated requirements:\r\n\r\n    .SecurityGroups[]\r\n    | select( any(.IpPermissions[].IpRanges[];\r\n                  .CidrIp | startswith(&quot;11.11.11.11/&quot;) ) )\r\n    | .GroupId\r\n\r\nIn particular, with your input it yields the required value:\r\n\r\n    &quot;sg-3jf32kj3j&quot;\r\n\r\nYou might want to consider more sophisticated pattern-matching, perhaps using:\r\n\r\n    test(&quot;^11.11.11.11($|/)&quot;)\r\n\r\nIf you want the quotation marks to be dropped, consider using the -r command-line option of jq.\r\n\r\n## Using ..\r\n\r\nHere&#39;s another solution, but please note that it has completely different semantics:\r\n\r\n    ..\r\n    | select( .. |  test(&quot;^11.11.11.11($|/)&quot;)? )\r\n    | .GroupId? // empty\r\n\r\n",
                "title": "jq iteration and conditions"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1548367259,
                "creation_date": 1548367259,
                "answer_id": 54355964,
                "question_id": 54353243,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "may I offer you an alternative solution to your ask? this is how it looks like with the unix utility `jtc` I have developed recently:\r\n\r\n    bash $ cat file.json | jtc -w&#39;&lt;^11.11.11.11\\/&gt;R: [-5] [GroupId]&#39; \r\n    &quot;sg-3jf32kj3j&quot;\r\n    bash $\r\n\r\nit will also display all groups where this ip address shows up. If you like it, you can find the utility on github.com or google it up with `jtc` and `json` keywords\r\n",
                "title": "jq iteration and conditions"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1548391392,
        "creation_date": 1548354572,
        "last_edit_date": 1548391392,
        "question_id": 54353243,
        "body_markdown": "I have some json that I need to parse using jq. I am trying to extract the \r\nSecurityGroups&gt;GroupId if any of the SecurityGroups&gt;IpPermissions&gt;IpRanges&gt;CidrIp matches a certain IP. \r\n\r\nFor instance, searching for 11.11.11.11 should return sg-3jf32kj3j. There is a possibility that multiple SecurityGroups will contain that IP. I need to return every GroupId that does.\r\n\r\nIs this even possible with jq alone or will it require bash as well?\r\n\r\nI&#39;m finding jq syntax confusing compared to just doing this with something like Python.\r\n\r\n\r\n    {\r\n\t&quot;SecurityGroups&quot;: [{\r\n\t\t\t&quot;OwnerId&quot;: &quot;111111111&quot;,\r\n\t\t\t&quot;Description&quot;: &quot;default VPC security group&quot;,\r\n\t\t\t&quot;GroupId&quot;: &quot;sg-1a1a1a1a1&quot;,\r\n\t\t\t&quot;VpcId&quot;: &quot;vpc-1a1a1a1a1&quot;,\r\n\t\t\t&quot;IpPermissionsEgress&quot;: [{\r\n\t\t\t\t&quot;IpProtocol&quot;: &quot;-1&quot;,\r\n\t\t\t\t&quot;PrefixListIds&quot;: [],\r\n\t\t\t\t&quot;Ipv6Ranges&quot;: [],\r\n\t\t\t\t&quot;UserIdGroupPairs&quot;: [],\r\n\t\t\t\t&quot;IpRanges&quot;: [{\r\n\t\t\t\t\t&quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n\t\t\t\t}]\r\n\t\t\t}],\r\n\t\t\t&quot;GroupName&quot;: &quot;default&quot;,\r\n\t\t\t&quot;IpPermissions&quot;: [{\r\n\t\t\t\t&quot;IpProtocol&quot;: &quot;-1&quot;,\r\n\t\t\t\t&quot;PrefixListIds&quot;: [],\r\n\t\t\t\t&quot;Ipv6Ranges&quot;: [],\r\n\t\t\t\t&quot;UserIdGroupPairs&quot;: [{\r\n\t\t\t\t\t&quot;GroupId&quot;: &quot;sg-5df45d5d5&quot;,\r\n\t\t\t\t\t&quot;UserId&quot;: &quot;234234234&quot;\r\n\t\t\t\t}],\r\n\t\t\t\t&quot;IpRanges&quot;: []\r\n\t\t\t}]\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;OwnerId&quot;: &quot;22222222222&quot;,\r\n\t\t\t&quot;Description&quot;: &quot;EC2 Security Group&quot;,\r\n\t\t\t&quot;Tags&quot;: [{\r\n\t\t\t\t\t&quot;Key&quot;: &quot;aws:cloudformation:logical-id&quot;,\r\n\t\t\t\t\t&quot;Value&quot;: &quot;EC2SecurityGroup&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;Key&quot;: &quot;aws:cloudformation:stack-id&quot;,\r\n\t\t\t\t\t&quot;Value&quot;: &quot;arn:aws:cloudformation:us-west-2:111111111:stack/blah-prod-vpc/asdfsdf-j3j3-22j1-39fj-sadfsadf&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;Key&quot;: &quot;Name&quot;,\r\n\t\t\t\t\t&quot;Value&quot;: &quot;blah-production-EC2&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;Key&quot;: &quot;Owner&quot;,\r\n\t\t\t\t\t&quot;Value&quot;: &quot;blah@blah.com&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;Key&quot;: &quot;aws:cloudformation:stack-name&quot;,\r\n\t\t\t\t\t&quot;Value&quot;: &quot;prod-vpc&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;Key&quot;: &quot;Created&quot;,\r\n\t\t\t\t\t&quot;Value&quot;: &quot;2018-05-21T09:40:55-07:00&quot;\r\n\t\t\t\t}\r\n\t\t\t],\r\n\t\t\t&quot;GroupId&quot;: &quot;sg-3jf32kj3j&quot;,\r\n\t\t\t&quot;VpcId&quot;: &quot;vpc-3kj3f2kj3&quot;,\r\n\t\t\t&quot;IpPermissionsEgress&quot;: [{\r\n\t\t\t\t&quot;IpProtocol&quot;: &quot;-1&quot;,\r\n\t\t\t\t&quot;PrefixListIds&quot;: [],\r\n\t\t\t\t&quot;Ipv6Ranges&quot;: [],\r\n\t\t\t\t&quot;UserIdGroupPairs&quot;: [],\r\n\t\t\t\t&quot;IpRanges&quot;: [{\r\n\t\t\t\t\t&quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n\t\t\t\t}]\r\n\t\t\t}],\r\n\t\t\t&quot;GroupName&quot;: &quot;blah-prod-vpc-EC2SecurityGroup-SJHS78F78SSH&quot;,\r\n\t\t\t&quot;IpPermissions&quot;: [{\r\n\t\t\t\t\t&quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n\t\t\t\t\t&quot;ToPort&quot;: 80,\r\n\t\t\t\t\t&quot;UserIdGroupPairs&quot;: [],\r\n\t\t\t\t\t&quot;IpRanges&quot;: [{\r\n\t\t\t\t\t\t&quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n\t\t\t\t\t}],\r\n\t\t\t\t\t&quot;FromPort&quot;: 80,\r\n\t\t\t\t\t&quot;PrefixListIds&quot;: [],\r\n\t\t\t\t\t&quot;Ipv6Ranges&quot;: []\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;IpProtocol&quot;: &quot;icmp&quot;,\r\n\t\t\t\t\t&quot;ToPort&quot;: 0,\r\n\t\t\t\t\t&quot;UserIdGroupPairs&quot;: [],\r\n\t\t\t\t\t&quot;IpRanges&quot;: [{\r\n\t\t\t\t\t\t&quot;CidrIp&quot;: &quot;11.11.11.11/32&quot;\r\n\t\t\t\t\t}],\r\n\t\t\t\t\t&quot;FromPort&quot;: 0,\r\n\t\t\t\t\t&quot;PrefixListIds&quot;: [],\r\n\t\t\t\t\t&quot;Ipv6Ranges&quot;: []\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;IpProtocol&quot;: &quot;-1&quot;,\r\n\t\t\t\t\t&quot;PrefixListIds&quot;: [],\r\n\t\t\t\t\t&quot;Ipv6Ranges&quot;: [],\r\n\t\t\t\t\t&quot;UserIdGroupPairs&quot;: [],\r\n\t\t\t\t\t&quot;IpRanges&quot;: [{\r\n\t\t\t\t\t\t\t&quot;CidrIp&quot;: &quot;22.22.22.22/16&quot;\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t&quot;CidrIp&quot;: &quot;33.33.33.33/32&quot;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t]\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n\t\t\t\t\t&quot;ToPort&quot;: 22,\r\n\t\t\t\t\t&quot;UserIdGroupPairs&quot;: [],\r\n\t\t\t\t\t&quot;IpRanges&quot;: [{\r\n\t\t\t\t\t\t&quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n\t\t\t\t\t}],\r\n\t\t\t\t\t&quot;FromPort&quot;: 22,\r\n\t\t\t\t\t&quot;PrefixListIds&quot;: [],\r\n\t\t\t\t\t&quot;Ipv6Ranges&quot;: [{\r\n\t\t\t\t\t\t&quot;CidrIpv6&quot;: &quot;::/0&quot;\r\n\t\t\t\t\t}]\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n\t\t\t\t\t&quot;ToPort&quot;: 443,\r\n\t\t\t\t\t&quot;UserIdGroupPairs&quot;: [],\r\n\t\t\t\t\t&quot;IpRanges&quot;: [{\r\n\t\t\t\t\t\t&quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n\t\t\t\t\t}],\r\n\t\t\t\t\t&quot;FromPort&quot;: 443,\r\n\t\t\t\t\t&quot;PrefixListIds&quot;: [],\r\n\t\t\t\t\t&quot;Ipv6Ranges&quot;: []\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;IpProtocol&quot;: &quot;icmp&quot;,\r\n\t\t\t\t\t&quot;ToPort&quot;: -1,\r\n\t\t\t\t\t&quot;UserIdGroupPairs&quot;: [],\r\n\t\t\t\t\t&quot;IpRanges&quot;: [{\r\n\t\t\t\t\t\t\t&quot;CidrIp&quot;: &quot;44.44.44.44/32&quot;\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t&quot;CidrIp&quot;: &quot;55.55.55.55/29&quot;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t],\r\n\t\t\t\t\t&quot;FromPort&quot;: -1,\r\n\t\t\t\t\t&quot;PrefixListIds&quot;: [],\r\n\t\t\t\t\t&quot;Ipv6Ranges&quot;: []\r\n\t\t\t\t}\r\n\t\t\t]\r\n\t\t}\r\n\t]}",
        "link": "https://stackoverflow.com/questions/54353243/jq-iteration-and-conditions",
        "title": "jq iteration and conditions"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1548477956,
                "last_edit_date": 1548477956,
                "creation_date": 1548418520,
                "answer_id": 54365173,
                "question_id": 54361098,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the alternative operator `//`. The expression `E // &quot;&quot;` will produce the empty string if E is empty or `null` or `false`:\r\n\r\n    &lt;file jq &#39;.results[0]|{label:&quot;a&quot;,test:((.address_components[].types|select(.[0]| contains(&quot;administrative_area_level_3&quot;))|.[1])//&quot;&quot;)}&#39;\r\n\r\nNotice that in the present case you don&#39;t need the `?` operator.\r\n",
                "title": "How to manage empty select results"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1561098782,
                "last_edit_date": 1561098782,
                "creation_date": 1548468501,
                "answer_id": 54375084,
                "question_id": 54361098,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "if you&#39;re not limited to the jq, may I kindly offer you an alternative tool I recently developed - `jtc`, with that tool your ask would look like (assuming your json is in `file.json`):\r\n\r\n    bash $ echo &#39;{ &quot;label&quot;: &quot;a&quot;, &quot;test&quot;: &quot;&quot; }&#39; | jtc -w&#39;&lt;test&gt;l&#39; -eu jtc -w&#39;&lt;administrative_area_level_2&gt; [-1] [1]&#39; file.json \\;  \r\n    {\r\n       &quot;label&quot;: &quot;a&quot;,\r\n       &quot;test&quot;: &quot;political&quot;\r\n    }\r\n    bash $ echo &#39;{ &quot;label&quot;: &quot;a&quot;, &quot;test&quot;: &quot;&quot; }&#39; | jtc -w&#39;&lt;test&gt;l&#39; -eu jtc -w&#39;&lt;administrative_area_level_3&gt; [-1] [1]&#39; file.json \\;  \r\n    {\r\n       &quot;label&quot;: &quot;a&quot;,\r\n       &quot;test&quot;: &quot;&quot;\r\n    }\r\n    bash $ \r\n\r\nUPDATE: starting from `jtc` *v.167*, the cli argument (of `-eu`) requires additional quoting, e.g.:\r\n\r\n    bash $ echo &#39;{ &quot;label&quot;: &quot;a&quot;, &quot;test&quot;: &quot;&quot; }&#39; | jtc -w&#39;&lt;test&gt;l&#39; -eu jtc -w&quot;&#39;&lt;administrative_area_level_2&gt; [-1] [1]&#39;&quot; file.json \\;\r\n    {\r\n       &quot;label&quot;: &quot;a&quot;,\r\n       &quot;test&quot;: &quot;political&quot;\r\n    }\r\n    bash $ \r\n\r\nPS. you may find `jtc` on github.com, or google up with keywords jtc and json\r\n",
                "title": "How to manage empty select results"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1561098782,
        "creation_date": 1548403035,
        "last_edit_date": 1548404169,
        "question_id": 54361098,
        "body_markdown": "I have this input JSON\r\n\r\n    {\r\n       &quot;results&quot; : [\r\n          {\r\n             &quot;address_components&quot; : [\r\n                {\r\n                   &quot;long_name&quot; : &quot;Amsterdam&quot;,\r\n                   &quot;short_name&quot; : &quot;Amsterdam&quot;,\r\n                   &quot;types&quot; : [ &quot;locality&quot;, &quot;political&quot; ]\r\n                },\r\n                {\r\n                   &quot;long_name&quot; : &quot;Government of Amsterdam&quot;,\r\n                   &quot;short_name&quot; : &quot;Government of Amsterdam&quot;,\r\n                   &quot;types&quot; : [ &quot;administrative_area_level_2&quot;, &quot;political&quot; ]\r\n                }\r\n             ]\r\n          }\r\n       ]\r\n    }\r\n\r\nIf I apply this filter with jq\r\n\r\n    .results[0]|{label:&quot;a&quot;,test:(.address_components[].types|select(.[0]| contains(&quot;administrative_area_level_2&quot;))|.[1]?)}\r\n\r\nI have a result\r\n\r\n    {\r\n      &quot;label&quot;: &quot;a&quot;,\r\n      &quot;test&quot;: &quot;political&quot;\r\n    }\r\n\r\n\r\nIf I modify the filter in (it&#39;s an empty selection)\r\n\r\n    .results[0]|{label:&quot;a&quot;,test:(.address_components[].types|select(.[0]| contains(&quot;administrative_area_level_3&quot;))|.[1]?)}\r\n\r\nI have a completely [empty result](https://jqplay.org/s/Wdqyvx-ZBS).\r\n\r\nHow to obtain something like\r\n\r\n    {\r\n      &quot;label&quot;: &quot;a&quot;,\r\n      &quot;test&quot;: &quot;&quot;\r\n    }\r\n\r\nHow to manage it with jq?",
        "link": "https://stackoverflow.com/questions/54361098/how-to-manage-empty-select-results",
        "title": "How to manage empty select results"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1548481101,
                "creation_date": 1548481101,
                "answer_id": 54375957,
                "question_id": 54375937,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [tag:jq] to parse &amp; manipulate JSON data from command line.\r\n\r\n    $ echo &#39;[&quot;test1&quot;, &quot;test2&quot;, &quot;test3&quot;]&#39; | jq -r &#39;.[]&#39;\r\n    test1\r\n    test2\r\n    test3\r\n",
                "title": "Convert string array from curl to separate new lines in a file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1548525907,
                "creation_date": 1548525907,
                "answer_id": 54381199,
                "question_id": 54375937,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If for some reason you cannot install [tag:jq], you can try something like:\r\n\r\n    $ echo &#39;[&quot;test1, &quot;test2&quot;, &quot;test3&quot;]&#39; |  sed &#39;s/[]\\[&quot;,]/\\n/g&#39; | grep -v &#39;^\\ *$&#39;\r\n    test1\r\n    test2\r\n    test3\r\n\r\ni.e.:\r\n\r\n    $ curl localhost:8080/api | sed &#39;s/[]\\[&quot;,]/\\n/g&#39; | grep -v &#39;^\\ *$&#39; &gt;&gt;&gt; file.txt\r\n\r\n    ",
                "title": "Convert string array from curl to separate new lines in a file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1623272506,
                "creation_date": 1623272506,
                "answer_id": 67911661,
                "question_id": 54375937,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of `curl` *and* `jq` you could give [tag:xidel] a try. It&#39;s a JSON parser (unlike `sed`!) and it can open all sorts of online sources. You could try:\r\n```\r\nxidel -s &quot;localhost:8080/api&quot; -e &#39;$json()&#39; &gt; file.txt\r\n```\r\nor\r\n```\r\nxidel -s &quot;localhost:8080/api&quot; -e &#39;file:write-text-lines(&quot;file.txt&quot;,$json())&#39;\r\n```",
                "title": "Convert string array from curl to separate new lines in a file"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1666425080,
        "creation_date": 1548480854,
        "last_edit_date": 1666425080,
        "question_id": 54375937,
        "body_markdown": "Calling `curl localhost:8080/api` returns something like `[&quot;test1, &quot;test2&quot;, &quot;test3&quot;]`\r\n\r\nI wanted to convert it to:\r\n\r\n    test1\r\n    test2\r\n    test3\r\n\r\nand then add it to a file\r\n\r\nI am trying things like:\r\n\r\n    curl localhost:8080/api | printf &quot;%s\\n&quot; &gt;&gt;&gt; file.txt\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54375937/convert-string-array-from-curl-to-separate-new-lines-in-a-file",
        "title": "Convert string array from curl to separate new lines in a file"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "sed",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1548683886,
                "creation_date": 1548683886,
                "answer_id": 54403555,
                "question_id": 54402890,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The output from `jq` contains spaces, you need to quote them to prevent the shell from tokenizing them.\r\n\r\n    sed -i &#39;s/$CONTENT/&#39;&quot;$(jq -c &#39;.content&#39; sample.json)/&quot; template.json\r\n\r\nSee further https://stackoverflow.com/questions/10067266/when-to-wrap-quotes-around-a-shell-variable ",
                "title": "Replace a keyword with the content of the file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1548689268,
                "last_edit_date": 1548689268,
                "creation_date": 1548688907,
                "answer_id": 54405071,
                "question_id": 54402890,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With GNU sed: \r\n\r\n`sed &#39;/$CONTENT/{s/.*/jq -c &quot;.content&quot; sample.json/e}&#39;`\r\n\r\nReplace the entire line with your command and `e` ([GNU only](https://www.gnu.org/software/sed/manual/sed.html#Extended-Commands)) to execute the command and replace sed&#39;s pattern space with the output of the command.",
                "title": "Replace a keyword with the content of the file"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1548706907,
                "last_edit_date": 1548706907,
                "creation_date": 1548690540,
                "answer_id": 54405617,
                "question_id": 54402890,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The jq Cookbook has a section on using jq with templates: https://github.com/stedolan/jq/wiki/Cookbook#using-jq-as-a-template-engine\r\n\r\nIn the present case, the first technique (&quot;Using jq variables as template variables&quot;) matches the already-defined template file (except for the dangling comma), so you could for example write:\r\n\r\n    jq -n --arg CONTENT &quot;$(jq -c .content sample.json)&quot; &#39;\r\n      {&quot;subject&quot;: &quot;Some subject line&quot;, &quot;content&quot;: $CONTENT}&#39;\r\n\r\nor use the format:\r\n\r\n    jq -n --arg CONTENT &quot;$(jq -c .content sample.json)&quot; -f template.jq\r\n\r\n(I&#39;d only use the .json suffix for files that hold JSON or JSON streams.)\r\n",
                "title": "Replace a keyword with the content of the file"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1548706907,
        "creation_date": 1548681479,
        "last_edit_date": 1548701595,
        "question_id": 54402890,
        "body_markdown": "I have a templatized json file called **template.json** as below:\r\n    \r\n    {\r\n      &quot;subject&quot;: &quot;Some subject line&quot;,\r\n      &quot;content&quot;: $CONTENT,\r\n    }\r\n\r\nI have another file called **sample.json** with the json content as below:\r\n\r\n    {\r\n\t&quot;status&quot;: &quot;ACTIVE&quot;,\r\n\t&quot;id&quot;: 217,\r\n\t&quot;type&quot;: &quot;TEXT&quot;,\r\n\t&quot;name&quot;: &quot;string&quot;,\r\n\t&quot;subject&quot;: &quot;string&quot;,\r\n\t&quot;url&quot;: &quot;contenttemplates/217&quot;,\r\n\t&quot;content&quot;: {\r\n\t\t&quot;text&quot;: &quot;hello ${user_name}&quot;,\r\n\t\t&quot;variables&quot;: [{\r\n\t\t\t&quot;key&quot;: &quot;${user_name}&quot;,\r\n\t\t\t&quot;value&quot;: null\r\n\t\t}]\r\n\t},\r\n\t&quot;content_footer&quot;: null,\r\n\t&quot;audit&quot;: {\r\n\t\t&quot;creator&quot;: &quot;1000&quot;,\r\n\t\t&quot;timestamp&quot;: 1548613800000,\r\n\t\t&quot;product&quot;: &quot;2&quot;,\r\n\t\t&quot;channel&quot;: &quot;10&quot;,\r\n\t\t&quot;party&quot;: null,\r\n\t\t&quot;event&quot;: {\r\n\t\t\t&quot;type&quot;: null,\r\n\t\t\t&quot;type_id&quot;: &quot;0&quot;,\r\n\t\t\t&quot;txn_id&quot;: &quot;0&quot;\r\n\t\t},\r\n\t\t&quot;client_key&quot;: &quot;pk6781gsfr5&quot;\r\n\t}\r\n}\r\n\r\nI want to replace `$CONTENT` from template.json with the content under the tag &quot;content&quot; from the content.json file . I have tried with below sed commands:\r\n    \r\n    sed -i &#39;s/$CONTENT/&#39;$(jq -c &#39;.content&#39; sample.json)&#39;/&#39; template.json\r\n    \r\nI am getting below error:\r\n    \r\n    sed: -e expression #1, char 15: unterminated `s&#39; command\r\n\r\nCan someone please help me to get the right sed command (or any other alternative)?",
        "link": "https://stackoverflow.com/questions/54402890/replace-a-keyword-with-the-content-of-the-file",
        "title": "Replace a keyword with the content of the file"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1548697798,
                "post_id": 54407540,
                "comment_id": 95626055,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1548697963,
                "post_id": 54407540,
                "comment_id": 95626141,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1548698098,
                "post_id": 54407540,
                "comment_id": 95626206,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1548697665,
        "creation_date": 1548697571,
        "last_edit_date": 1548697665,
        "question_id": 54407540,
        "body_markdown": "I am trying to extract value from a JSON file using `jq` on Ubuntu. When I `echo` out directly, it works and returns the value to the console. But when I try to assign the extracted value to a variable and `echo` out, returns nothing to console.\r\n\r\nThe following works:\r\n\r\n    #!/bin/sh\r\n    echo &#39;{&quot;USERNAME&quot;:&quot;TRX-101&quot;,&quot;PASSWORD&quot;:&quot;:g&amp;fg#/H&quot;}&#39; | jq .PASSWORD\r\n\r\nThe following does NOT work:\r\n\r\n    #!/bin/sh\r\n    VAR = &#39;{&quot;USERNAME&quot;:&quot;TRX-101&quot;,&quot;PASSWORD&quot;:&quot;:g&amp;fg#/H&quot;}&#39; | jq .PASSWORD\r\n    echo $VAR\r\n\r\nMy ultimate goal is to use the value from `$VAR` to do other operations within the shell script (ex: send the value to a XML file etc.)",
        "link": "https://stackoverflow.com/questions/54407540/jq-to-extract-value-from-json-file-and-assign-to-a-variable",
        "title": "JQ to extract value from JSON file and assign to a variable"
    },
    {
        "tags": [
            "java",
            "python",
            "pandas",
            "jq",
            "flatten"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1548791633,
                "post_id": 54426122,
                "comment_id": 95667417,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1548820365,
                "last_edit_date": 1548820365,
                "creation_date": 1548788831,
                "answer_id": 54428056,
                "question_id": 54426122,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem is that your &quot;rule&quot; creates a Cartesian product, whereas in effect you want nested iteration.\r\n\r\nWith your input, the following jq expression, which makes the nested iteration reasonably clear, produces the output as shown:\r\n\r\n    .id as $id\r\n    | .things[] as $thing\r\n    | $thing.objs[]\r\n    | [$id, .this, $thing.tId]\r\n    | @tsv\r\n\r\n## Output\r\n\r\n    1\t99\t1\r\n    1\t100\t1\r\n    1\t222\t2\r\n    1\t22222\t2\r\n\r\n## Rule\r\nSo presumably your rule should look something like this:\r\n\r\n    [{id} + (.things[] | {tid: .tId} + (.objs[] | {this}))]\r\n\r\nor if you want to make the nested iteration clearer:\r\n\r\n    [ .id as $id\r\n      | .things[] as $thing\r\n      | $thing.objs[]\r\n      | {id: $id, this, tid: $thing.tId} ]\r\n\r\n\r\n## Running jq in java\r\n\r\nBesides `processBuilder`, you might like to take a look at these wrappers:\r\n\r\n* https://github.com/eiiches/jackson-jq\r\n* https://github.com/arakelian/java-jq\r\n\r\n",
                "title": "Flattening JSON data into individual rows"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1548820365,
        "creation_date": 1548781366,
        "last_edit_date": 1548791890,
        "question_id": 54426122,
        "body_markdown": "I am interested in flattening JSON with multiple layers of nested arrays of object. I would ideally like to do this in Java but it seems like the Pandas library in python might be good for this.  \r\n\r\nDoes anyone know a good java library for this?\r\n\r\nI found this article (https://stackoverflow.com/questions/21494030/create-a-pandas-dataframe-from-deeply-nested-json) using `pandas` and `jq` and my solution almost works but the output I am receiving is not quite as expected.  Here is my code sample \r\n\r\n    json_data = &#39;&#39;&#39;{ &quot;id&quot;: 1,\r\n\t&quot;things&quot;: [\r\n\t\t{\r\n\t\t\t&quot;tId&quot;: 1,\r\n\t\t\t&quot;objs&quot;: [{&quot;this&quot;: 99},{&quot;this&quot;: 100}]\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;tId&quot;: 2,\r\n\t\t\t&quot;objs&quot;: [{&quot;this&quot;: 222},{&quot;this&quot;: 22222}]\r\n\t\t}\r\n\t]\r\n     }&#39;&#39;&#39;\r\n\r\n    rule = &quot;&quot;&quot;[{id: .id, \r\n            tid: .things[].tId,\r\n            this: .things[].objs[].this}]&quot;&quot;&quot;\r\n    out = jq(rule, _in=json_data).stdout\r\n    res = pd.DataFrame(json.loads(out))\r\n\r\n\r\nThe problem is the output I am receiving is this:\r\n\r\n       id   this  tid\r\n    0   1     99    1\r\n    1   1    100    1\r\n    2   1    222    1\r\n    3   1  22222    1\r\n    4   1     99    2\r\n    5   1    100    2\r\n    6   1    222    2\r\n    7   1  22222    2\r\n\r\nI am expecting to see\r\n\r\n       id   this  tid\r\n    0   1     99    1\r\n    1   1    100    1\r\n    3   1    222    2\r\n    4   1  22222    2\r\n\r\n\r\nAny tips on how to make this work, different solutions, or a java option would be great!\r\n\r\nThanks in advance!\r\n\r\nCraig",
        "link": "https://stackoverflow.com/questions/54426122/flattening-json-data-into-individual-rows",
        "title": "Flattening JSON data into individual rows"
    },
    {
        "tags": [
            "arrays",
            "json",
            "object",
            "addition",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1548845433,
                "last_edit_date": 1548845433,
                "creation_date": 1548841216,
                "answer_id": 54437442,
                "question_id": 54436748,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `group_by` to group array elements by a filter&#39;s output (`.b` in this case):\r\n\r\n    jq &#39;{ q : [ add | group_by(.b)[] | add ] }&#39; file",
                "title": "JQ how to merge multiple objects in an array into one (2)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1548865332,
                "last_edit_date": 1548865332,
                "creation_date": 1548864900,
                "answer_id": 54444902,
                "question_id": 54436748,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution using the generic function `aggregate_by`, defined as follows:\r\n\r\n    def aggregate_by(s; f; g):\r\n      reduce s as $x  (null; .[$x|f] += [$x|g]);\r\n\r\nFirst, notice that with this def:\r\n\r\n    aggregate_by(.a[], .h[]; .b|tostring; .)[]\r\n    | add\r\n\r\nproduces the desired array except for the ordering of elements.  If the ordering of elements in the output array is unimportant, then the above could be tweaked to provide a simple solution that does not involve `group_by`, which entails sorting.\r\n\r\nTo produce the desired (sorted-by-b) output, we could tweak the above as follows:\r\n\r\n    {q: [aggregate_by(.a[], .h[]; .b|tostring; .)[]]\r\n        | map(add)\r\n        | sort_by(.b) }\r\n\r\n\r\n",
                "title": "JQ how to merge multiple objects in an array into one (2)"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1548865332,
        "creation_date": 1548838829,
        "question_id": 54436748,
        "body_markdown": "A little more sophisticated as my [previous question][1]. Missing indexes mess things up too.\r\n\r\nInput:\r\n\r\n    {\r\n      &quot;a&quot;: [\r\n        { &quot;b&quot;: 1, &quot;d&quot;: &quot;p&quot; },\r\n    \r\n        { &quot;b&quot;: 3, &quot;d&quot;: &quot;r&quot; },\r\n        { &quot;b&quot;: 4, &quot;d&quot;: &quot;s&quot; }\r\n      ],\r\n      &quot;h&quot;: [\r\n        { &quot;b&quot;: 1, &quot;i&quot;: &quot;k&quot; },\r\n        { &quot;b&quot;: 2, &quot;i&quot;: &quot;l&quot; },\r\n    \r\n        { &quot;b&quot;: 4, &quot;i&quot;: &quot;n&quot; }\r\n      ]\r\n    }\r\n\r\nDesired output:\r\n\r\n    {\r\n      &quot;q&quot;: [\r\n        { &quot;b&quot;: 1, &quot;d&quot;: &quot;p&quot;, &quot;i&quot;: &quot;k&quot; },\r\n        { &quot;b&quot;: 2, &quot;i&quot;: &quot;l&quot; },\r\n        { &quot;b&quot;: 3, &quot;d&quot;: &quot;r&quot; },\r\n        { &quot;b&quot;: 4, &quot;d&quot;: &quot;s&quot;, &quot;i&quot;: &quot;n&quot; }\r\n      ]\r\n    }\r\n\r\nTried:\r\n\r\n    jq &#39;[.a, .h ] | transpose | map(add)| {l: .}&#39;\r\n    jq &#39;[ .a[] , .h[] ] | unique_by(.b) | { l: sort_by(.b) }&#39;\r\n    jq &#39;[ .a[] + .h[] ] | unique_by(.b) | { l: sort_by(.b) }&#39;\r\n    jq &#39;[ .a[] * .h[] ] | unique_by(.b) | { l: sort_by(.b) }&#39;\r\n\r\n  [1]: https://stackoverflow.com/questions/54350532/jq-how-to-merge-multiple-objects-in-an-array-into-one",
        "link": "https://stackoverflow.com/questions/54436748/jq-how-to-merge-multiple-objects-in-an-array-into-one-2",
        "title": "JQ how to merge multiple objects in an array into one (2)"
    },
    {
        "tags": [
            "json",
            "file",
            "split",
            "jq",
            "data-partitioning"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1548890741,
                "last_edit_date": 1548890741,
                "creation_date": 1548889909,
                "answer_id": 54450974,
                "question_id": 54450909,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use a little shell loop:\r\n\r\n       \r\n    #!/bin/bash\r\n    jq -r &#39;.[].symbol&#39; stockprices.json | while read -r symbol ; do\r\n        jq --arg s &quot;${symbol}&quot; \\\r\n            &#39;map(if .symbol == $s then . else empty end)&#39; \\\r\n        stockprices.json &gt; &quot;${symbol}&quot;.json\r\n    done ",
                "title": "Is there a way to use jq to split a JSON file by its common keys?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1548918899,
                "last_edit_date": 1548918899,
                "creation_date": 1548891714,
                "answer_id": 54451262,
                "question_id": 54450909,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a one-pass solution that assumes your RAM is big enough. The solution eschews using `group_by`, as that entails a sort operation, which is unnecessary and potentially costly in terms of time and memory.  \r\n\r\nTo create the output files, `awk` is used here for efficiency, but is inessential to the approach.\r\n\r\n## split.jq\r\n\r\n    def aggregate_by(s; f; g):\r\n      reduce s as $x  (null; .[$x|f] += [$x|g]);\r\n    \r\n    aggregate_by(.[]; .symbol; .)\r\n    | keys_unsorted[] as $k\r\n    | $k, .[$k]\r\n\r\n## Invocation using awk\r\n\r\n    jq -f split.jq stockprices.json | awk &#39;\r\n      substr($0,1,1) == &quot;\\&quot;&quot; {\r\n        if (fn) {close(fn)};\r\n        gsub(/^&quot;|&quot;$/,&quot;&quot;,$0); fn=$0 &quot;.json&quot;; next;\r\n      }\r\n      {print &gt;&gt; fn}&#39;\r\n\r\n",
                "title": "Is there a way to use jq to split a JSON file by its common keys?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1548899252,
                "creation_date": 1548899252,
                "answer_id": 54452191,
                "question_id": 54450909,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You would need a loop, but it could be done in a single invocation:\r\n\r\n    jq -rc &#39;group_by(.symbol)[] | &quot;\\(.[0].symbol)\\t\\(.)&quot;&#39; stockprices.json |\r\n    while IFS=$&#39;\\t&#39; read -r symbol content; do\r\n        echo &quot;${content}&quot; &gt; &quot;${symbol}.json&quot;\r\n    done\r\n\r\n",
                "title": "Is there a way to use jq to split a JSON file by its common keys?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1548918899,
        "creation_date": 1548889516,
        "last_edit_date": 1548896336,
        "question_id": 54450909,
        "body_markdown": "I have a set of pricing data for a lot of stocks (around 1.1 million lines).\r\n\r\n\r\n\r\nI&#39;m having trouble parsing all of this data in memory so I&#39;d like to split it by stock symbol into individual files and only import the data as it is needed.\r\n\r\nFrom:\r\n\r\n    stockprices.json\r\n\r\nTo:\r\n\r\n    AAPL.json\r\n    ACN.json\r\n    ...\r\netc.\r\n\r\nstockprices.json has this structure currently:\r\n\r\n    [{\r\n\t\t&quot;date&quot;: &quot;2016-03-22 00:00:00&quot;,\r\n\t\t&quot;symbol&quot;: &quot;ACN&quot;,\r\n\t\t&quot;open&quot;: &quot;121.029999&quot;,\r\n\t\t&quot;close&quot;: &quot;121.470001&quot;,\r\n\t\t&quot;low&quot;: &quot;120.720001&quot;,\r\n\t\t&quot;high&quot;: &quot;122.910004&quot;,\r\n\t\t&quot;volume&quot;: &quot;711400.0&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;date&quot;: &quot;2016-03-23 00:00:00&quot;,\r\n\t\t&quot;symbol&quot;: &quot;AAPL&quot;,\r\n\t\t&quot;open&quot;: &quot;121.470001&quot;,\r\n\t\t&quot;close&quot;: &quot;119.379997&quot;,\r\n\t\t&quot;low&quot;: &quot;119.099998&quot;,\r\n\t\t&quot;high&quot;: &quot;121.470001&quot;,\r\n\t\t&quot;volume&quot;: &quot;444200.0&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;date&quot;: &quot;2016-03-24 00:00:00&quot;,\r\n\t\t&quot;symbol&quot;: &quot;AAPL&quot;,\r\n\t\t&quot;open&quot;: &quot;118.889999&quot;,\r\n\t\t&quot;close&quot;: &quot;119.410004&quot;,\r\n\t\t&quot;low&quot;: &quot;117.639999&quot;,\r\n\t\t&quot;high&quot;: &quot;119.440002&quot;,\r\n\t\t&quot;volume&quot;: &quot;534100.0&quot;\r\n\t},\r\n    ...{}....]\r\n\r\nI believe that jq is the right tool for the job but I&#39;m having trouble understanding it.\r\n\r\nHow would I take the data above and use jq to split it by the symbol field?\r\n\r\nFor example I&#39;d like to end up with:\r\n\r\nAAPL.json:\r\n\r\n\r\n\t[{\r\n\t\t&quot;date&quot;: &quot;2016-03-23 00:00:00&quot;,\r\n\t\t&quot;symbol&quot;: &quot;AAPL&quot;,\r\n\t\t&quot;open&quot;: &quot;121.470001&quot;,\r\n\t\t&quot;close&quot;: &quot;119.379997&quot;,\r\n\t\t&quot;low&quot;: &quot;119.099998&quot;,\r\n\t\t&quot;high&quot;: &quot;121.470001&quot;,\r\n\t\t&quot;volume&quot;: &quot;444200.0&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;date&quot;: &quot;2016-03-24 00:00:00&quot;,\r\n\t\t&quot;symbol&quot;: &quot;AAPL&quot;,\r\n\t\t&quot;open&quot;: &quot;118.889999&quot;,\r\n\t\t&quot;close&quot;: &quot;119.410004&quot;,\r\n\t\t&quot;low&quot;: &quot;117.639999&quot;,\r\n\t\t&quot;high&quot;: &quot;119.440002&quot;,\r\n\t\t&quot;volume&quot;: &quot;534100.0&quot;\r\n\t}]\r\n\r\nand ACN.json:\r\n\r\n    [{\r\n\t\t&quot;date&quot;: &quot;2016-03-22 00:00:00&quot;,\r\n\t\t&quot;symbol&quot;: &quot;ACN&quot;,\r\n\t\t&quot;open&quot;: &quot;121.029999&quot;,\r\n\t\t&quot;close&quot;: &quot;121.470001&quot;,\r\n\t\t&quot;low&quot;: &quot;120.720001&quot;,\r\n\t\t&quot;high&quot;: &quot;122.910004&quot;,\r\n\t\t&quot;volume&quot;: &quot;711400.0&quot;\r\n\t},\r\n        {\r\n\t\t&quot;date&quot;: &quot;2016-03-22 00:00:00&quot;,\r\n\t\t&quot;symbol&quot;: &quot;ACN&quot;,\r\n\t\t&quot;open&quot;: &quot;121.029999&quot;,\r\n\t\t&quot;close&quot;: &quot;121.470001&quot;,\r\n\t\t&quot;low&quot;: &quot;120.720001&quot;,\r\n\t\t&quot;high&quot;: &quot;122.910004&quot;,\r\n\t\t&quot;volume&quot;: &quot;711400.0&quot;\r\n\t}\r\n    ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54450909/is-there-a-way-to-use-jq-to-split-a-json-file-by-its-common-keys",
        "title": "Is there a way to use jq to split a JSON file by its common keys?"
    }
]