[
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11719268,
                    "reputation": 1965,
                    "user_id": 8578684,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ea58bdbaa27987e01887b7ace77ed9c4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "snap",
                    "link": "https://stackoverflow.com/users/8578684/snap"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1517331135,
                "post_id": 48526476,
                "comment_id": 84048138,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3166082,
                    "reputation": 567,
                    "user_id": 2676073,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/bnYGZ.jpg?s=256",
                    "display_name": "MostlyRquestions",
                    "link": "https://stackoverflow.com/users/2676073/mostlyrquestions"
                },
                "reply_to_user": {
                    "account_id": 11719268,
                    "reputation": 1965,
                    "user_id": 8578684,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ea58bdbaa27987e01887b7ace77ed9c4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "snap",
                    "link": "https://stackoverflow.com/users/8578684/snap"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1517331843,
                "post_id": 48526476,
                "comment_id": 84048561,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11719268,
                    "reputation": 1965,
                    "user_id": 8578684,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ea58bdbaa27987e01887b7ace77ed9c4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "snap",
                    "link": "https://stackoverflow.com/users/8578684/snap"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1517332112,
                "post_id": 48526476,
                "comment_id": 84048710,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3166082,
                    "reputation": 567,
                    "user_id": 2676073,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/bnYGZ.jpg?s=256",
                    "display_name": "MostlyRquestions",
                    "link": "https://stackoverflow.com/users/2676073/mostlyrquestions"
                },
                "reply_to_user": {
                    "account_id": 11719268,
                    "reputation": 1965,
                    "user_id": 8578684,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ea58bdbaa27987e01887b7ace77ed9c4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "snap",
                    "link": "https://stackoverflow.com/users/8578684/snap"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1517332446,
                "post_id": 48526476,
                "comment_id": 84048909,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1517341312,
                "last_edit_date": 1517341312,
                "creation_date": 1517339942,
                "answer_id": 48528977,
                "question_id": 48526476,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Unfortunately you have not followed the guidelines at http://stackoverflow.com/help/mcve so it is difficult to tell from your description what output you are expecting, but the simplest way to delete a key from an object is to use `del/1` as in the following:\r\n\r\n    .tracks\r\n    | map(select(.label==&quot;cucumber_ChineseLong_v2.gff3&quot;) \r\n          | del(.maxHeight))\r\n\r\nWith your JSON as input, the result of the above query is rather long, so I won&#39;t include it in this response -- the &quot;m&quot; in &quot;mcve&quot; stands for &quot;minimal&quot;.\r\n\r\n### Supplementary Q&amp;A\r\n&gt; Is it possible to return the original file with the &#39;maxHeight&#39; removed?\r\n\r\nFor &quot;editing&quot; (as opposed to extraction), the trick is to use `|=`. There are many variations possible, for example:\r\n\r\n    .tracks |=\r\n      map(if .label==&quot;cucumber_ChineseLong_v2.gff3&quot;\r\n          then del(.maxHeight)\r\n          else .\r\n          end)\r\n\r\nSome prefer the one-liner:\r\n\r\n    .tracks[] |= if .label==&quot;cucumber_ChineseLong_v2.gff3&quot; then del(.maxHeight) else . end",
                "title": "Manipulating a JSON file with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1587966893,
        "creation_date": 1517330623,
        "last_edit_date": 1587966893,
        "question_id": 48526476,
        "body_markdown": "I’m using jq to manipulate a JSON file. I need to run a single command that searches an array, finds an object that has a key that equals “someData”, and then delete a key that is in the object, for example, delete a “maxHeight” key from the object where key equals “someData”. Here is an example JSON file, I would like to search the ‘tracks’ array and find the object where label =“cucumber_ChineseLong_v2.gff3” and then remove the ‘maxHeight: “200px” ‘ from that object. Is this even possible to run in a single command using jq? \r\n\r\n**Update**: My desired output would be the original JSON file with that &#39;maxHeight&#39; key:value removed. \r\n\r\n**Update**: A few commands I&#39;ve tried..\r\n\r\n    jq &#39;. as $dot|[range(0;length)|select(.maxHeight == &quot;200px&quot;)|$dot[.]]&#39; trackList.json &gt; new.json\r\n\r\n    jq &#39;.tracks[]  | select(.label == &quot;cucumber_ChineseLong_v2.gff3&quot;)&#39; trackList.json &gt; test.json\r\n\r\n    \r\n\r\n* The Last command can isolate the correct Array, Now I need to know how to delete a key from a object using jq.\r\n\r\nJSON File\r\n\r\n    {\r\n      &quot;tracks&quot;: [\r\n        {\r\n          &quot;storeClass&quot;: &quot;JBrowse/Store/Sequence/StaticChunked&quot;,\r\n          &quot;chunkSize&quot;: 20000,\r\n          &quot;urlTemplate&quot;: &quot;seq/{refseq_dirpath}/{refseq}-&quot;,\r\n          &quot;label&quot;: &quot;DNA&quot;,\r\n          &quot;type&quot;: &quot;SequenceTrack&quot;,\r\n          &quot;category&quot;: &quot;Reference sequence&quot;,\r\n          &quot;seqType&quot;: &quot;dna&quot;,\r\n          &quot;key&quot;: &quot;Reference sequence&quot;\r\n        },\r\n        {\r\n          &quot;style&quot;: {\r\n            &quot;className&quot;: &quot;feature&quot;,\r\n            &quot;showLabels&quot;: false,\r\n            &quot;arrowheadClass&quot;: null,\r\n            &quot;featureCss&quot;: &quot;padding:3px;&quot;\r\n          },\r\n          &quot;menuTemplate&quot;: [\r\n            {\r\n              &quot;label&quot;: &quot;View details&quot;\r\n            },\r\n            {\r\n              &quot;label&quot;: &quot;Highlight a gene&quot;\r\n            },\r\n            {\r\n              &quot;iconClass&quot;: &quot;dijitIconBookmark&quot;,\r\n              &quot;content&quot;: &quot;function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( feature[2] ) }&quot;,\r\n              &quot;action&quot;: &quot;contentDialog&quot;,\r\n              &quot;title&quot;: &quot;(feature{name})&quot;,\r\n              &quot;label&quot;: &quot;Create Note&quot;\r\n            }\r\n          ],\r\n          &quot;hooks&quot;: {\r\n            &quot;modify&quot;: &quot; function(track,feature,div){ var checkArr=[\\&quot;Reference\\&quot;,\\&quot;Missing\\&quot;,\\&quot;Heterozygous\\&quot;,\\&quot;NonReference\\&quot;];for(var i=0;i&lt;feature.length;i++){for(var j=0;j&lt;checkArr.length;j++){  if( i&gt;3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\\&quot;NonReference\\&quot;){div.style.backgroundColor=\\&quot;red\\&quot;}else if(feature[i]==\\&quot;Reference\\&quot;){div.style.backgroundColor=\\&quot;green\\&quot;}else if(feature[i]==\\&quot;Heterozygous\\&quot;){div.style.backgroundColor=\\&quot;orange\\&quot;}else if(feature[i]==\\&quot;Missing\\&quot;){div.style.backgroundColor=\\&quot;grey\\&quot;} }}}}} &quot;\r\n          },\r\n          &quot;key&quot;: &quot;CG0001.gff&quot;,\r\n          &quot;storeClass&quot;: &quot;JBrowse/Store/SeqFeature/NCList&quot;,\r\n          &quot;trackType&quot;: null,\r\n          &quot;maxHeight&quot;: &quot;200px&quot;,\r\n          &quot;urlTemplate&quot;: &quot;tracks/CG0001.gff/{refseq}/trackData.json&quot;,\r\n          &quot;compress&quot;: 0,\r\n          &quot;label&quot;: &quot;CG0001.gff&quot;,\r\n          &quot;type&quot;: &quot;FeatureTrack&quot;\r\n        },\r\n        {\r\n          &quot;style&quot;: {\r\n            &quot;className&quot;: &quot;feature&quot;,\r\n            &quot;showLabels&quot;: false,\r\n            &quot;arrowheadClass&quot;: null,\r\n            &quot;featureCss&quot;: &quot;padding:3px;&quot;\r\n          },\r\n          &quot;menuTemplate&quot;: [\r\n            {\r\n              &quot;label&quot;: &quot;View details&quot;\r\n            },\r\n            {\r\n              &quot;label&quot;: &quot;Highlight a gene&quot;\r\n            },\r\n            {\r\n              &quot;iconClass&quot;: &quot;dijitIconBookmark&quot;,\r\n              &quot;content&quot;: &quot;function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( feature[2] ) }&quot;,\r\n              &quot;action&quot;: &quot;contentDialog&quot;,\r\n              &quot;title&quot;: &quot;(feature{name})&quot;,\r\n              &quot;label&quot;: &quot;Create Note&quot;\r\n            }\r\n          ],\r\n          &quot;hooks&quot;: {\r\n            &quot;modify&quot;: &quot; function(track,feature,div){ var checkArr=[\\&quot;Reference\\&quot;,\\&quot;Missing\\&quot;,\\&quot;Heterozygous\\&quot;,\\&quot;NonReference\\&quot;];for(var i=0;i&lt;feature.length;i++){for(var j=0;j&lt;checkArr.length;j++){  if( i&gt;3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\\&quot;NonReference\\&quot;){div.style.backgroundColor=\\&quot;red\\&quot;}else if(feature[i]==\\&quot;Reference\\&quot;){div.style.backgroundColor=\\&quot;green\\&quot;}else if(feature[i]==\\&quot;Heterozygous\\&quot;){div.style.backgroundColor=\\&quot;orange\\&quot;}else if(feature[i]==\\&quot;Missing\\&quot;){div.style.backgroundColor=\\&quot;grey\\&quot;} }}}}} &quot;\r\n          },\r\n          &quot;key&quot;: &quot;CG0002.gff&quot;,\r\n          &quot;storeClass&quot;: &quot;JBrowse/Store/SeqFeature/NCList&quot;,\r\n          &quot;trackType&quot;: null,\r\n          &quot;maxHeight&quot;: &quot;200px&quot;,\r\n          &quot;urlTemplate&quot;: &quot;tracks/CG0002.gff/{refseq}/trackData.json&quot;,\r\n          &quot;compress&quot;: 0,\r\n          &quot;label&quot;: &quot;CG0002.gff&quot;,\r\n          &quot;type&quot;: &quot;FeatureTrack&quot;\r\n        },\r\n        {\r\n          &quot;style&quot;: {\r\n            &quot;className&quot;: &quot;feature&quot;,\r\n            &quot;showLabels&quot;: false,\r\n            &quot;arrowheadClass&quot;: null,\r\n            &quot;featureCss&quot;: &quot;padding:3px;&quot;\r\n          },\r\n          &quot;menuTemplate&quot;: [\r\n            {\r\n              &quot;label&quot;: &quot;View details&quot;\r\n            },\r\n            {\r\n              &quot;label&quot;: &quot;Highlight a gene&quot;\r\n            },\r\n            {\r\n              &quot;iconClass&quot;: &quot;dijitIconBookmark&quot;,\r\n              &quot;content&quot;: &quot;function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( feature[2] ) }&quot;,\r\n              &quot;action&quot;: &quot;contentDialog&quot;,\r\n              &quot;title&quot;: &quot;(feature{name})&quot;,\r\n              &quot;label&quot;: &quot;Create Note&quot;\r\n            }\r\n          ],\r\n          &quot;hooks&quot;: {\r\n            &quot;modify&quot;: &quot; function(track,feature,div){ var checkArr=[\\&quot;Reference\\&quot;,\\&quot;Missing\\&quot;,\\&quot;Heterozygous\\&quot;,\\&quot;NonReference\\&quot;];for(var i=0;i&lt;feature.length;i++){for(var j=0;j&lt;checkArr.length;j++){  if( i&gt;3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\\&quot;NonReference\\&quot;){div.style.backgroundColor=\\&quot;red\\&quot;}else if(feature[i]==\\&quot;Reference\\&quot;){div.style.backgroundColor=\\&quot;green\\&quot;}else if(feature[i]==\\&quot;Heterozygous\\&quot;){div.style.backgroundColor=\\&quot;orange\\&quot;}else if(feature[i]==\\&quot;Missing\\&quot;){div.style.backgroundColor=\\&quot;grey\\&quot;} }}}}} &quot;\r\n          },\r\n          &quot;key&quot;: &quot;CG0003.gff&quot;,\r\n          &quot;storeClass&quot;: &quot;JBrowse/Store/SeqFeature/NCList&quot;,\r\n          &quot;trackType&quot;: null,\r\n          &quot;maxHeight&quot;: &quot;200px&quot;,\r\n          &quot;urlTemplate&quot;: &quot;tracks/CG0003.gff/{refseq}/trackData.json&quot;,\r\n          &quot;compress&quot;: 0,\r\n          &quot;label&quot;: &quot;CG0003.gff&quot;,\r\n          &quot;type&quot;: &quot;FeatureTrack&quot;\r\n        },\r\n        {\r\n          &quot;style&quot;: {\r\n            &quot;className&quot;: &quot;feature&quot;,\r\n            &quot;showLabels&quot;: false,\r\n            &quot;arrowheadClass&quot;: null,\r\n            &quot;featureCss&quot;: &quot;padding:3px;&quot;\r\n          },\r\n          &quot;menuTemplate&quot;: [\r\n            {\r\n              &quot;label&quot;: &quot;View details&quot;\r\n            },\r\n            {\r\n              &quot;label&quot;: &quot;Highlight a gene&quot;\r\n            },\r\n            {\r\n              &quot;iconClass&quot;: &quot;dijitIconBookmark&quot;,\r\n              &quot;content&quot;: &quot;function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( feature[2] ) }&quot;,\r\n              &quot;action&quot;: &quot;contentDialog&quot;,\r\n              &quot;title&quot;: &quot;(feature{name})&quot;,\r\n              &quot;label&quot;: &quot;Create Note&quot;\r\n            }\r\n          ],\r\n          &quot;hooks&quot;: {\r\n            &quot;modify&quot;: &quot; function(track,feature,div){ var checkArr=[\\&quot;Reference\\&quot;,\\&quot;Missing\\&quot;,\\&quot;Heterozygous\\&quot;,\\&quot;NonReference\\&quot;];for(var i=0;i&lt;feature.length;i++){for(var j=0;j&lt;checkArr.length;j++){  if( i&gt;3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\\&quot;NonReference\\&quot;){div.style.backgroundColor=\\&quot;red\\&quot;}else if(feature[i]==\\&quot;Reference\\&quot;){div.style.backgroundColor=\\&quot;green\\&quot;}else if(feature[i]==\\&quot;Heterozygous\\&quot;){div.style.backgroundColor=\\&quot;orange\\&quot;}else if(feature[i]==\\&quot;Missing\\&quot;){div.style.backgroundColor=\\&quot;grey\\&quot;} }}}}} &quot;\r\n          },\r\n          &quot;key&quot;: &quot;CG0004.gff&quot;,\r\n          &quot;storeClass&quot;: &quot;JBrowse/Store/SeqFeature/NCList&quot;,\r\n          &quot;trackType&quot;: null,\r\n          &quot;maxHeight&quot;: &quot;200px&quot;,\r\n          &quot;urlTemplate&quot;: &quot;tracks/CG0004.gff/{refseq}/trackData.json&quot;,\r\n          &quot;compress&quot;: 0,\r\n          &quot;label&quot;: &quot;CG0004.gff&quot;,\r\n          &quot;type&quot;: &quot;FeatureTrack&quot;\r\n        },\r\n        {\r\n          &quot;style&quot;: {\r\n            &quot;className&quot;: &quot;feature&quot;,\r\n            &quot;showLabels&quot;: false,\r\n            &quot;arrowheadClass&quot;: null,\r\n            &quot;featureCss&quot;: &quot;padding:3px;&quot;\r\n          },\r\n          &quot;menuTemplate&quot;: [\r\n            {\r\n              &quot;label&quot;: &quot;View details&quot;\r\n            },\r\n            {\r\n              &quot;label&quot;: &quot;Highlight a gene&quot;\r\n            },\r\n            {\r\n              &quot;iconClass&quot;: &quot;dijitIconBookmark&quot;,\r\n              &quot;content&quot;: &quot;function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( feature[2] ) }&quot;,\r\n              &quot;action&quot;: &quot;contentDialog&quot;,\r\n              &quot;title&quot;: &quot;(feature{name})&quot;,\r\n              &quot;label&quot;: &quot;Create Note&quot;\r\n            }\r\n          ],\r\n          &quot;hooks&quot;: {\r\n            &quot;modify&quot;: &quot; function(track,feature,div){ var checkArr=[\\&quot;Reference\\&quot;,\\&quot;Missing\\&quot;,\\&quot;Heterozygous\\&quot;,\\&quot;NonReference\\&quot;];for(var i=0;i&lt;feature.length;i++){for(var j=0;j&lt;checkArr.length;j++){  if( i&gt;3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\\&quot;NonReference\\&quot;){div.style.backgroundColor=\\&quot;red\\&quot;}else if(feature[i]==\\&quot;Reference\\&quot;){div.style.backgroundColor=\\&quot;green\\&quot;}else if(feature[i]==\\&quot;Heterozygous\\&quot;){div.style.backgroundColor=\\&quot;orange\\&quot;}else if(feature[i]==\\&quot;Missing\\&quot;){div.style.backgroundColor=\\&quot;grey\\&quot;} }}}}} &quot;\r\n          },\r\n          &quot;key&quot;: &quot;CG0005.gff&quot;,\r\n          &quot;storeClass&quot;: &quot;JBrowse/Store/SeqFeature/NCList&quot;,\r\n          &quot;trackType&quot;: null,\r\n          &quot;maxHeight&quot;: &quot;200px&quot;,\r\n          &quot;urlTemplate&quot;: &quot;tracks/CG0005.gff/{refseq}/trackData.json&quot;,\r\n          &quot;compress&quot;: 0,\r\n          &quot;label&quot;: &quot;CG0005.gff&quot;,\r\n          &quot;type&quot;: &quot;FeatureTrack&quot;\r\n        },\r\n        {\r\n          &quot;style&quot;: {\r\n            &quot;className&quot;: &quot;feature&quot;,\r\n            &quot;showLabels&quot;: false,\r\n            &quot;arrowheadClass&quot;: null,\r\n            &quot;featureCss&quot;: &quot;padding:3px;&quot;\r\n          },\r\n          &quot;menuTemplate&quot;: [\r\n            {\r\n              &quot;label&quot;: &quot;View details&quot;\r\n            },\r\n            {\r\n              &quot;label&quot;: &quot;Highlight a gene&quot;\r\n            },\r\n            {\r\n              &quot;iconClass&quot;: &quot;dijitIconBookmark&quot;,\r\n              &quot;content&quot;: &quot;function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( feature[2] ) }&quot;,\r\n              &quot;action&quot;: &quot;contentDialog&quot;,\r\n              &quot;title&quot;: &quot;(feature{name})&quot;,\r\n              &quot;label&quot;: &quot;Create Note&quot;\r\n            }\r\n          ],\r\n          &quot;hooks&quot;: {\r\n            &quot;modify&quot;: &quot; function(track,feature,div){ var checkArr=[\\&quot;Reference\\&quot;,\\&quot;Missing\\&quot;,\\&quot;Heterozygous\\&quot;,\\&quot;NonReference\\&quot;];for(var i=0;i&lt;feature.length;i++){for(var j=0;j&lt;checkArr.length;j++){  if( i&gt;3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\\&quot;NonReference\\&quot;){div.style.backgroundColor=\\&quot;red\\&quot;}else if(feature[i]==\\&quot;Reference\\&quot;){div.style.backgroundColor=\\&quot;green\\&quot;}else if(feature[i]==\\&quot;Heterozygous\\&quot;){div.style.backgroundColor=\\&quot;orange\\&quot;}else if(feature[i]==\\&quot;Missing\\&quot;){div.style.backgroundColor=\\&quot;grey\\&quot;} }}}}} &quot;\r\n          },\r\n          &quot;key&quot;: &quot;CG0010.gff&quot;,\r\n          &quot;storeClass&quot;: &quot;JBrowse/Store/SeqFeature/NCList&quot;,\r\n          &quot;trackType&quot;: null,\r\n          &quot;maxHeight&quot;: &quot;200px&quot;,\r\n          &quot;urlTemplate&quot;: &quot;tracks/CG0010.gff/{refseq}/trackData.json&quot;,\r\n          &quot;compress&quot;: 0,\r\n          &quot;label&quot;: &quot;CG0010.gff&quot;,\r\n          &quot;type&quot;: &quot;FeatureTrack&quot;\r\n        },\r\n        {\r\n          &quot;style&quot;: {\r\n            &quot;className&quot;: &quot;feature&quot;,\r\n            &quot;showLabels&quot;: false,\r\n            &quot;color&quot;: &quot;function(feature, variableName, glyphObject, track){if(feature.get(\\&quot;type\\&quot;) === \\&quot;CDS\\&quot;){return \\&quot;#9CFBF5\\&quot;;} else if(feature.get(\\&quot;type\\&quot;) === \\&quot;exon\\&quot;){return \\&quot;#43A47F\\&quot;;} else if(feature.get(\\&quot;type\\&quot;) === \\&quot;intron\\&quot;){return \\&quot;#E8E8E8\\&quot;;} else if(feature.get(\\&quot;type\\&quot;) === \\&quot;five_prime_UTR\\&quot;){return \\&quot;#F192FE\\&quot;;} else if(feature.get(\\&quot;type\\&quot;) === \\&quot;three_prime_UTR\\&quot;){return \\&quot;#FEC892\\&quot;;} else {return \\&quot;#FF0000\\&quot;;}}&quot;,\r\n            &quot;arrowheadClass&quot;: null,\r\n            &quot;featureCss&quot;: &quot;padding:3px;&quot;\r\n          },\r\n          &quot;menuTemplate&quot;: [\r\n            {\r\n              &quot;label&quot;: &quot;View details&quot;\r\n            },\r\n            {\r\n              &quot;label&quot;: &quot;Highlight a gene&quot;\r\n            },\r\n            {\r\n              &quot;iconClass&quot;: &quot;dijitIconBookmark&quot;,\r\n              &quot;content&quot;: &quot;function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( feature[2] ) }&quot;,\r\n              &quot;action&quot;: &quot;contentDialog&quot;,\r\n              &quot;title&quot;: &quot;(feature{name})&quot;,\r\n              &quot;label&quot;: &quot;Create Note&quot;\r\n            }\r\n          ],\r\n          &quot;hooks&quot;: {\r\n            &quot;modify&quot;: &quot; function(track,feature,div){   var checkArr=[\\&quot;Reference\\&quot;,\\&quot;Missing\\&quot;,\\&quot;Heterozygous\\&quot;,\\&quot;NonReference\\&quot;];for(var i=0;i&lt;feature.length;i++){for(var j=0;j&lt;checkArr.length;j++){  if( i&gt;3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\\&quot;NonReference\\&quot;){div.style.backgroundColor=\\&quot;red\\&quot;}else if(feature[i]==\\&quot;Reference\\&quot;){div.style.backgroundColor=\\&quot;green\\&quot;}else if(feature[i]==\\&quot;Heterozygous\\&quot;){div.style.backgroundColor=\\&quot;orange\\&quot;}else if(feature[i]==\\&quot;Missing\\&quot;){div.style.backgroundColor=\\&quot;grey\\&quot;} }}}}} &quot;\r\n          },\r\n          &quot;key&quot;: &quot;cucumber_ChineseLong_v2.gff3&quot;,\r\n          &quot;storeClass&quot;: &quot;JBrowse/Store/SeqFeature/NCList&quot;,\r\n          &quot;trackType&quot;: null,\r\n          &quot;maxHeight&quot;: &quot;200px&quot;,\r\n          &quot;urlTemplate&quot;: &quot;tracks/cucumber_ChineseLong_v2.gff3/{refseq}/trackData.json&quot;,\r\n          &quot;compress&quot;: 0,\r\n          &quot;label&quot;: &quot;cucumber_ChineseLong_v2.gff3&quot;,\r\n          &quot;type&quot;: &quot;JBrowse/View/Track/CanvasFeatures&quot;\r\n        },\r\n        {\r\n          &quot;storeClass&quot;: &quot;JBrowse/Store/SeqFeature/VCFTabix&quot;,\r\n          &quot;urlTemplate&quot;: &quot;Cucumber115_chronly.vcf.gz&quot;,\r\n          &quot;maxHeight&quot;: &quot;200px&quot;,\r\n          &quot;type&quot;: &quot;CanvasVariants&quot;,\r\n          &quot;label&quot;: &quot;Cucumber115_chronly.vcf&quot;,\r\n          &quot;menuTemplate&quot;: [\r\n            {\r\n              &quot;label&quot;: &quot;View details&quot;\r\n            },\r\n            {\r\n              &quot;label&quot;: &quot;Zoom&quot;\r\n            },\r\n            {\r\n              &quot;iconClass&quot;: &quot;dijitIconFilter&quot;,\r\n              &quot;content&quot;: &quot;function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().selectSequence( div.f.data.end ) }&quot;,\r\n              &quot;action&quot;: &quot;contentDialog&quot;,\r\n              &quot;title&quot;: &quot;(feature{name})&quot;,\r\n              &quot;label&quot;: &quot;Select Sequence&quot;\r\n            },\r\n            {\r\n              &quot;iconClass&quot;: &quot;dijitIconBookmark&quot;,\r\n              &quot;content&quot;: &quot;function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( div.f.data.end ) }&quot;,\r\n              &quot;action&quot;: &quot;contentDialog&quot;,\r\n              &quot;title&quot;: &quot;(feature{name})&quot;,\r\n              &quot;label&quot;: &quot;Create Note&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;style&quot;: {\r\n            &quot;className&quot;: &quot;feature&quot;,\r\n            &quot;showLabels&quot;: false,\r\n            &quot;arrowheadClass&quot;: null,\r\n            &quot;featureCss&quot;: &quot;padding:7px;&quot;\r\n          },\r\n          &quot;hooks&quot;: {\r\n            &quot;modify&quot;: &quot; function(track,feature,div){ var checkArr=[\\&quot;Gene\\&quot;,\\&quot;Variant\\&quot;,\\&quot;Primer\\&quot;];for(var i=0;i&lt;feature.length;i++){for(var j=0;j&lt;checkArr.length;j++){  if( i&gt;3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\\&quot;Gene\\&quot;){div.style.backgroundColor=\\&quot;pink\\&quot;}else if(feature[i]==\\&quot;Variant\\&quot;){div.style.backgroundColor=\\&quot;purple\\&quot;}else if(feature[i]==\\&quot;Primer\\&quot;){div.style.backgroundColor=\\&quot;blue\\&quot;} }}}}} &quot;\r\n          },\r\n          &quot;key&quot;: &quot;Notes&quot;,\r\n          &quot;storeClass&quot;: &quot;JBrowse/Store/SeqFeature/NCList&quot;,\r\n          &quot;trackType&quot;: null,\r\n          &quot;maxHeight&quot;: &quot;200px&quot;,\r\n          &quot;urlTemplate&quot;: &quot;tracks/Notes/{refseq}/trackData.json&quot;,\r\n          &quot;compress&quot;: 0,\r\n          &quot;type&quot;: &quot;FeatureTrack&quot;,\r\n          &quot;label&quot;: &quot;Notes&quot;\r\n        }\r\n      ],\r\n      &quot;formatVersion&quot;: 1\r\n    }\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48526476/manipulating-a-json-file-with-jq",
        "title": "Manipulating a JSON file with jq"
    },
    {
        "tags": [
            "json",
            "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": 1,
                "creation_date": 1517332256,
                "post_id": 48526634,
                "comment_id": 84048804,
                "content_license": "CC BY-SA 3.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": 1517333211,
                "post_id": 48526634,
                "comment_id": 84049329,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1517333180,
                "creation_date": 1517333180,
                "answer_id": 48527213,
                "question_id": 48526634,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt;  I want all the values from this json, a, b, and c\r\n\r\n**`jq`** solution for valid JSON structure:\r\n\r\n    ... | jq &#39;[.a, .b, (.c | fromjson | .[])]&#39;\r\n\r\n- `.[]` - returns all the values of the array/object\r\n\r\nThe output:\r\n\r\n    [\r\n      &quot;foo&quot;,\r\n      &quot;bar&quot;,\r\n      &quot;world&quot;\r\n    ]\r\n\r\n",
                "title": "Parse JSON string within JSON and other fields"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 7,
        "last_activity_date": 1517368821,
        "creation_date": 1517331212,
        "last_edit_date": 1517368821,
        "question_id": 48526634,
        "body_markdown": "I have a file in `s3` which when unzipped has something of this format\r\n\r\n    {&quot;a&quot;: &quot;foo&quot;,\r\n     &quot;b&quot;: &quot;bar&quot;,\r\n     &quot;c&quot;: : &quot;{\\&quot;hello\\&quot;: \\&quot;world\\&quot;}&quot;}\r\n\r\nNow I know I can parse the value of `c` by doing `jq &#39;.c | fromjson | .hello&#39;`\r\n\r\nBut let&#39;s say I want all the values from this json, `a, b, and c`. This is the code snippet I currently have:\r\n\r\n    aws s3 cp s3://somebucket/somekey.gz - | gunzip | jq &#39;[.a, .b]&#39;\r\n\r\nHow do I incorporate grabbing the value from `c` into this expression?",
        "link": "https://stackoverflow.com/questions/48526634/parse-json-string-within-json-and-other-fields",
        "title": "Parse JSON string within JSON and other fields"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1517342876,
                "creation_date": 1517342876,
                "answer_id": 48529690,
                "question_id": 48529016,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There are two approaches: \r\n\r\n* the targeted approach, illustrated in an answer to your previous question at https://stackoverflow.com/questions/48526476/manipulating-a-json-file-with-jq\r\n\r\n* the global approach, that ignores the specific context.\r\n\r\nThe following illustrates the global approach:\r\n\r\n    walk(if type == &quot;object&quot; and has(&quot;maxHeight&quot;) then del(.maxHeight) else . end)\r\n\r\nThis in effect &quot;edits&quot; the input by updating whichever objects have the specified key.\r\n\r\nIf your jq does not have `walk/1` simply include its def (available e.g. from https://raw.githubusercontent.com/stedolan/jq/master/src/builtin.jq) before invoking it.\r\n\r\n\r\n",
                "title": "Remove a key:value from an JSON object using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1517344298,
                "creation_date": 1517344298,
                "answer_id": 48530030,
                "question_id": 48529016,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "For very large JSON documents, it may be preferable to use jq&#39;s &quot;streaming parser&quot; for this kind of problem, at least if the editing operations greatly reduce the size of the document.  At any rate, here is a solution that uses the `--stream` option:\r\n\r\n    jq --stream &#39;select(length == 2 and .[0][-1] == &quot;maxHeight&quot; | not)&#39; new.json |\r\n     jq -n &#39;fromstream(inputs)&#39;\r\n\r\nNote that the `-n` option must be used in the second call to jq.",
                "title": "Remove a key:value from an JSON object using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1533289453,
                "creation_date": 1533289453,
                "answer_id": 51669801,
                "question_id": 48529016,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is an example removing a couple of keys from an Electrum Wallet JSON file, this was tested in zsh and bash with a verison of jq that doesn&#39;t have `walk` built in:\r\n\r\n    jq -f &lt;(\r\n      curl https://raw.githubusercontent.com/stedolan/jq/master/src/builtin.jq\r\n      echo &#39;walk(&#39;\r\n      for i in transactions spent_outpoints verified_tx3 txo txi addresses addr_history; do\r\n        echo &#39;if type == &quot;object&quot; and has(&quot;&#39;&quot;$i&quot;&#39;&quot;) then del(.&#39;&quot;$i&quot;&#39;) else . end |&#39;\r\n      done\r\n      echo &#39;.)&#39;\r\n    )  ~/.electrum/testnet/wallets/default_wallet",
                "title": "Remove a key:value from an JSON object using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1549289479,
                "creation_date": 1549289479,
                "answer_id": 54517995,
                "question_id": 48529016,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I had a similar issue, but did not want to make a lot of code for this or spend too much time on it.\r\n\r\nI&#39;m assuming you fixed your reason for this. But for me, the following worked for a value that I did not have to recursively look for, i.e. only at the top level. Also, I did not care if a blank/null value was there:\r\n\r\n    jq &quot;if .maxHeight then .maxHeight = null else . end &quot;",
                "title": "Remove a key:value from an JSON object using jq"
            },
            {
                "up_vote_count": 47,
                "is_accepted": true,
                "score": 47,
                "last_activity_date": 1602657110,
                "last_edit_date": 1602657110,
                "creation_date": 1584451401,
                "answer_id": 60723320,
                "question_id": 48529016,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using jq-1.6, this deletes the key .maxHeight from the input (it doesn&#39;t even complain if it didn&#39;t exist before):\r\n\r\n    jq &#39;del(.maxHeight)&#39; new.json",
                "title": "Remove a key:value from an JSON object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 24,
        "last_activity_date": 1602657110,
        "creation_date": 1517340085,
        "last_edit_date": 1587966909,
        "question_id": 48529016,
        "body_markdown": "\r\nI’m trying to add and remove a &#39;key:value&#39; from a JSON object using jq. I’m new using jq and I do not understand the errors that jq is throwing at me, so any help pushing me in the correct direction is greatly appreciated. My specific issue is I have a JSON object (below) and I want to be able to add/remove the “maxHeight” key/value from the JSON object. \r\n\r\nSome commands I’ve tried with the errors I get…\r\n\r\n    jq &#39;recurse(.[]) |= del(.maxHeight)&#39; new.json   \r\n\r\n &gt; Cannot iterate over null (null)\r\n\r\n     jq &#39;recurse(.[]) |= {maxHeight}&#39; new.json\r\n\r\n &gt; Cannot iterate over string (&quot;feature&quot;)\r\n\r\n    jq &#39;recurse(.[]) |= .maxHeight&#39; new.json \r\n\r\n&gt;  Cannot index string with string &quot;style&quot;\r\n\r\nnew.json file looks like this...\r\n\r\n\r\n    {\r\n      &quot;style&quot;: {\r\n        &quot;className&quot;: &quot;feature&quot;,\r\n        &quot;showLabels&quot;: false,\r\n        &quot;color&quot;: &quot;function(feature, variableName, glyphObject, track){if(feature.get(\\&quot;type\\&quot;) === \\&quot;CDS\\&quot;){return \\&quot;#9CFBF5\\&quot;;} else if(feature.get(\\&quot;type\\&quot;) === \\&quot;exon\\&quot;){return \\&quot;#43A47F\\&quot;;} else if(feature.get(\\&quot;type\\&quot;) === \\&quot;intron\\&quot;){return \\&quot;#E8E8E8\\&quot;;} else if(feature.get(\\&quot;type\\&quot;) === \\&quot;five_prime_UTR\\&quot;){return \\&quot;#F192FE\\&quot;;} else if(feature.get(\\&quot;type\\&quot;) === \\&quot;three_prime_UTR\\&quot;){return \\&quot;#FEC892\\&quot;;} else {return \\&quot;#FF0000\\&quot;;}}&quot;,\r\n        &quot;arrowheadClass&quot;: null,\r\n        &quot;featureCss&quot;: &quot;padding:3px;&quot;\r\n      },\r\n      &quot;menuTemplate&quot;: [\r\n        {\r\n          &quot;label&quot;: &quot;View details&quot;\r\n        },\r\n        {\r\n          &quot;label&quot;: &quot;Highlight a gene&quot;\r\n        },\r\n        {\r\n          &quot;iconClass&quot;: &quot;dijitIconBookmark&quot;,\r\n          &quot;content&quot;: &quot;function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( feature[2] ) }&quot;,\r\n          &quot;action&quot;: &quot;contentDialog&quot;,\r\n          &quot;title&quot;: &quot;(feature{name})&quot;,\r\n          &quot;label&quot;: &quot;Create Note&quot;\r\n        }\r\n      ],\r\n      &quot;hooks&quot;: {\r\n        &quot;modify&quot;: &quot; function(track,feature,div){   var checkArr=[\\&quot;Reference\\&quot;,\\&quot;Missing\\&quot;,\\&quot;Heterozygous\\&quot;,\\&quot;NonReference\\&quot;];for(var i=0;i&lt;feature.length;i++){for(var j=0;j&lt;checkArr.length;j++){  if( i&gt;3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\\&quot;NonReference\\&quot;){div.style.backgroundColor=\\&quot;red\\&quot;}else if(feature[i]==\\&quot;Reference\\&quot;){div.style.backgroundColor=\\&quot;green\\&quot;}else if(feature[i]==\\&quot;Heterozygous\\&quot;){div.style.backgroundColor=\\&quot;orange\\&quot;}else if(feature[i]==\\&quot;Missing\\&quot;){div.style.backgroundColor=\\&quot;grey\\&quot;} }}}}} &quot;\r\n      },\r\n      &quot;key&quot;: &quot;cucumber_ChineseLong_v2.gff3&quot;,\r\n      &quot;storeClass&quot;: &quot;JBrowse/Store/SeqFeature/NCList&quot;,\r\n      &quot;trackType&quot;: null,\r\n      &quot;maxHeight&quot;: &quot;200px&quot;,\r\n      &quot;urlTemplate&quot;: &quot;tracks/cucumber_ChineseLong_v2.gff3/{refseq}/trackData.json&quot;,\r\n      &quot;compress&quot;: 0,\r\n      &quot;label&quot;: &quot;cucumber_ChineseLong_v2.gff3&quot;,\r\n      &quot;type&quot;: &quot;JBrowse/View/Track/CanvasFeatures&quot;\r\n    }\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48529016/remove-a-keyvalue-from-an-json-object-using-jq",
        "title": "Remove a key:value from an JSON object using jq"
    },
    {
        "tags": [
            "windows",
            "powershell",
            "syntax",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1517504851,
                "last_edit_date": 1517504851,
                "creation_date": 1517387767,
                "answer_id": 48537775,
                "question_id": 48536924,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "First, setting aside for the moment all the issues related to peculiarities of different shells, the jq filter you need is:\r\n\r\n    .[&quot;my test&quot;].path = &quot;success&quot;\r\n \r\n(If ever in doubt about using the `.foo` syntax, you can always fall back on the fundamental form: `.[&quot;key name&quot;]`.)\r\n\r\nSince you are evidently conversant with the transmogrification required by the mighty PowerShell, I&#39;ll just point out here that one can simply place the jq program in a file (say program.jq) and invoke jq with the -f option (jq -f program.jq ...).",
                "title": "jq assignment where the path contain space"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1517504851,
        "creation_date": 1517384434,
        "last_edit_date": 1517398333,
        "question_id": 48536924,
        "body_markdown": "This might be a simple question but I am struggling to figure out how jq work with spaces in elements. (The following is in windows powershell)\r\n\r\n    PS C:\\Users\\Home&gt; &quot;{}&quot; | jq &quot;.mytest.path = &quot;&quot;&quot;&quot;success&quot;&quot;&quot;&quot;&quot; \r\n    {\r\n      &quot;mytest&quot;: {\r\n        &quot;path&quot;: &quot;success&quot;\r\n      }\r\n    }\r\n\r\nNow, I want to make &quot;my test&quot; two separate words. My desired output is \r\n\r\n    {\r\n      &quot;my - test&quot;: {\r\n        &quot;path&quot;: &quot;success&quot;\r\n      }\r\n    }\r\n\r\nWhat query would I used? I tried the following:\r\n\r\n    PS C:\\Users\\Home&gt; &quot;{}&quot; | jq &quot;.&quot;&quot;my - test&quot;&quot;.path = &quot;&quot;&quot;&quot;success&quot;&quot;&quot;&quot;&quot; \r\n    jq : jq: error: Could not open file test.path = &quot;success&quot;: Invalid argument\r\n    At line:1 char:8\r\n    + &quot;{}&quot; | jq &quot;.&quot;&quot;my - test&quot;&quot;.path = &quot;&quot;&quot;&quot;success&quot;&quot;&quot;&quot;&quot;\r\n    +        ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\r\n        + CategoryInfo          : NotSpecified: (jq: error: Coul...nvalid argument:String) [], RemoteException\r\n        + FullyQualifiedErrorId : NativeCommandError\r\n\r\n    PS C:\\Users\\Home&gt; &quot;{}&quot; | jq --raw-output &quot;.&quot;&quot;my test&quot;&quot;.path = &quot;&quot;&quot;&quot;success&quot;&quot;&quot;&quot;&quot; \r\n    jq : jq: error: Could not open file test.path = &quot;success&quot;: Invalid argument\r\n    At line:1 char:8\r\n    + &quot;{}&quot; | jq --raw-output &quot;.&quot;&quot;my test&quot;&quot;.path = &quot;&quot;&quot;&quot;success&quot;&quot;&quot;&quot;&quot;\r\n    +        ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\r\n        + CategoryInfo          : NotSpecified: (jq: error: Coul...nvalid argument:String) [], RemoteException\r\n        + FullyQualifiedErrorId : NativeCommandError\r\n\r\nAny suggestions?",
        "link": "https://stackoverflow.com/questions/48536924/jq-assignment-where-the-path-contain-space",
        "title": "jq assignment where the path contain space"
    },
    {
        "tags": [
            "json",
            "shell",
            "md5",
            "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": 1517437568,
                "post_id": 48548580,
                "comment_id": 84101297,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1517427172,
                "last_edit_date": 1517427172,
                "creation_date": 1517424422,
                "answer_id": 48549392,
                "question_id": 48548580,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** + **`md5sum`** trick:\r\n\r\n    json_data=&#39;{&quot;first&quot;: &quot;John&quot;, &quot;last&quot;: &quot;Big&quot;}&#39;\r\n    jq -r &#39;.first + .last| @sh&#39; &lt;&lt;&lt;&quot;$json_data&quot; | md5sum | cut -d&#39; &#39; -f1 \\\r\n    | jq -R --argjson data &quot;$json_data&quot; &#39;$data + {id: .}&#39;\r\n\r\n\r\nSample output:\r\n\r\n    {\r\n      &quot;first&quot;: &quot;John&quot;,\r\n      &quot;last&quot;: &quot;Big&quot;,\r\n      &quot;id&quot;: &quot;f9e1e448a766870605b863e23d3fdbd8&quot;\r\n    }\r\n\r\n\r\n",
                "title": "shell-out value to md5 (crypto) function"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1517546460,
                "last_edit_date": 1517546460,
                "creation_date": 1517425798,
                "answer_id": 48549720,
                "question_id": 48548580,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using `tee` allows a pipeline to be used, e.g.:\r\n\r\n    echo &#39;{&quot;first&quot;: &quot;John&quot;, &quot;last&quot;: &quot;Big&quot;}&#39; |\r\n        tee &gt;( jq -r &#39;.first + .last&#39; | md5 | jq -R &#39;{id: .}&#39;) |\r\n        jq -s add\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;first&quot;: &quot;John&quot;,\r\n      &quot;last&quot;: &quot;Big&quot;,\r\n      &quot;id&quot;: &quot;cda5c2dd89a0ab28a598a6b22e5b88ce&quot;\r\n    }\r\n\r\n\r\n### Edit2:\r\n\r\nThe following uses a `while` loop to iterate through the elements of the array, but it calls jq twice at each iteration.  For a solution that does not call jq at all within the loop, see elsewhere on this page.\r\n\r\n    echo &#39;[{&quot;first&quot;: &quot;John&quot;, &quot;last&quot;: &quot;Big&quot;}, {&quot;first&quot;: &quot;Justin&quot;, &quot;last&quot;: &quot;Frozen&quot;}]&#39; |\r\n    jq -c .[] |\r\n    while read -r line ; do\r\n    \tjq -r &#39;[.[]]|add&#39;  &lt;&lt;&lt; &quot;$line&quot; | md5 |\r\n            jq  --argjson line &quot;$line&quot; -R &#39;$line + {id: .}&#39;\r\n    done\r\n\r\n",
                "title": "shell-out value to md5 (crypto) function"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1517429049,
                "creation_date": 1517429049,
                "answer_id": 48550571,
                "question_id": 48548580,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Looking around a little farther I ended up finding this: https://stackoverflow.com/questions/38739648/jq-json-parser-hash-the-field-value which was helpful in getting to my answer of:\r\n\r\n    echo &#39;[{&quot;first&quot;: &quot;John&quot;, &quot;last&quot;: &quot;Big&quot;}, {&quot;first&quot;: &quot;Justin&quot;, &quot;last&quot;: &quot;Frozen&quot;}]&#39; &gt; /tmp/testfile\r\n    \r\n    jsonfile=&quot;/tmp/testfile&quot;\r\n    jq -c .[] &quot;$jsonfile&quot; | while read -r jsonline ;\r\n    do\r\n      # quickly parse the JSON line and build the pre-ID out to get md5sum&#39;d and then store that in a variable\r\n      id=&quot;$(jq -s -j -r &#39;.[] | .first + .last&#39; &lt;&lt;&lt;&quot;$jsonline&quot; | md5sum | cut -d &#39; &#39; -f1)&quot;\r\n      # using the stored md5sum&#39;d ID we can use that as an argument for adding it to the existing jsonline\r\n      jq --arg id &quot;$id&quot; -s -c &#39;.[] | .id = &quot;\\($id)&quot;&#39; &lt;&lt;&lt;&quot;$jsonline&quot;\r\n    done\r\n\r\n\r\n# output\r\n\r\n    {&quot;first&quot;:&quot;John&quot;,&quot;last&quot;:&quot;Big&quot;,&quot;id&quot;:&quot;467ffeee8fea6aef01a6ffdcaf747782&quot;}\r\n    {&quot;first&quot;:&quot;Justin&quot;,&quot;last&quot;:&quot;Frozen&quot;,&quot;id&quot;:&quot;fda76523d5259c0b586441dae7c2db85&quot;}\r\n\r\n",
                "title": "shell-out value to md5 (crypto) function"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1517546554,
                "last_edit_date": 1517546554,
                "creation_date": 1517439458,
                "answer_id": 48552825,
                "question_id": 48548580,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is an efficient solution to the restated problem. There are altogether just two calls to jq, no matter the length of the array:\r\n\r\n    json=&#39;[{&quot;first&quot;: &quot;John&quot;, &quot;last&quot;: &quot;Big&quot;}, {&quot;first&quot;: &quot;Justin&quot;, &quot;last&quot;: &quot;Frozen&quot;}]&#39;\r\n\r\n    echo &quot;$json&quot; |\r\n    jq -c &#39;.[] | [.[]] | add&#39; |\r\n    while read -r line ; do echo &quot;$line&quot; | md5 ; done |\r\n    jq -s -R --argjson json &quot;$json&quot; &#39;split(&quot;\\n&quot;)\r\n      | map(select(length&gt;0))\r\n      | . as $in\r\n      | reduce range(0;length) as $i ($json; .[$i].id = $in[$i])&#39;\r\n\r\nThis produces an array.  Just tack on `|.[]` at the end to produce a stream of the elements.\r\n\r\nOr a bit more tersely, with the goal of emitting one object per line without calling jq within the loop:\r\n\r\n    jq -c --slurpfile md5 &lt;(jq -c &#39;.[] | [.[]] | add&#39; &lt;&lt;&lt; &quot;$json&quot; |\r\n        while read -r line ; do printf &#39;&quot;%s&quot;&#39; $(md5 &lt;&lt;&lt; &quot;$line&quot; ) ; done) \\\r\n     &#39;[., $md5] | transpose[] | .[0] + {id: .[1]}&#39; &lt;&lt;&lt; &quot;$json&quot;\r\n\r\n\r\n### Distinct Digest for each Record\r\n\r\n&gt; I need to generate a unique key for each record.\r\n\r\nIt would therefore make sense to compute the digest based on each entire JSON object (or more generally, the entire JSON value), i.e. use `jq -c ‘.[]’` ",
                "title": "shell-out value to md5 (crypto) function"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1645960475,
                "creation_date": 1645960475,
                "answer_id": 71284276,
                "question_id": 48548580,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I adapted accepted answer&#39;s script to my case, posting it here, it could be useful to someone.\r\n\r\ninput.json:\r\n\r\n    {&quot;date&quot;:100,&quot;text&quot;:&quot;some text&quot;,&quot;name&quot;:&quot;april&quot;}\r\n    {&quot;date&quot;:200,&quot;text&quot;:&quot;a b c&quot;,&quot;name&quot;:&quot;may&quot;}\r\n    {&quot;date&quot;:300,&quot;text&quot;:&quot;some text&quot;,&quot;name&quot;:&quot;april&quot;}\r\n\r\noutput.json:\r\n\r\n    {&quot;date&quot;:100,&quot;text&quot;:&quot;some text&quot;,&quot;name&quot;:&quot;april&quot;,&quot;id&quot;:&quot;4d93d51945b88325c213640ef59fc50b&quot;}\r\n    {&quot;date&quot;:200,&quot;text&quot;:&quot;a b c&quot;,&quot;name&quot;:&quot;may&quot;,&quot;id&quot;:&quot;3da904d79fb03e6e3936ff2127039b1a&quot;}\r\n    {&quot;date&quot;:300,&quot;text&quot;:&quot;some text&quot;,&quot;name&quot;:&quot;april&quot;,&quot;id&quot;:&quot;4d93d51945b88325c213640ef59fc50b&quot;}\r\n\r\nThe bash script to generate output.json:\r\n\r\n    cat input.json |\r\n    while read -r line ; do\r\n        jq -r &#39;.text&#39; &lt;&lt;&lt; &quot;$line&quot; | md5 |\r\n            jq -c --argjson line &quot;$line&quot; -R &#39;$line + {id: .}&#39; \\\r\n            &gt;&gt; output.json\r\n    done\r\n",
                "title": "shell-out value to md5 (crypto) function"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 2,
        "last_activity_date": 1645960475,
        "creation_date": 1517421454,
        "last_edit_date": 1517437659,
        "question_id": 48548580,
        "body_markdown": "I&#39;m looking for a solution where I&#39;m building out a JSON record and need to generate some text in JQ but pipe this text to an MD5 sum function and use it as a value for a key.\r\n\r\n    echo &#39;{&quot;first&quot;: &quot;John&quot;, &quot;last&quot;: &quot;Big&quot;}&#39; | jq &#39;. | { id: (.first + .last) | md5 }&#39;\r\n\r\nFrom looking at the manual and the GH issues I can&#39;t figure out how to do this since a function can&#39;t call out to a shell and there is not built in that provides a unique hash like functionality.\r\n\r\n\r\n# Edit\r\n\r\nA better example what I&#39;m looking for is this:\r\n\r\n    echo &#39;{&quot;first&quot;: &quot;John&quot;, &quot;last&quot;: &quot;Big&quot;}&#39; | jq &#39;. | {first, last, id: (.first + .last | md5) }&#39;\r\n\r\nto output:\r\n\r\n    {\r\n      &quot;first&quot;: &quot;John&quot;,\r\n      &quot;last&quot;: &quot;Big&quot;,\r\n      &quot;id&quot;: &quot;cda5c2dd89a0ab28a598a6b22e5b88ce&quot;\r\n    }\r\n\r\n# Edit2\r\n\r\nand a little more context.  I&#39;m creating [NDJson][1] files for use with esbulk.  I need to generate a unique key for each record. Initially, I thought piping out to the shell would be the simplest solution so I could either use sha1sum or some other hash function easily, but that is looking more challenging than I thought.\r\n\r\nA better example what I&#39;m looking for is this:\r\n\r\n    echo &#39;[{&quot;first&quot;: &quot;John&quot;, &quot;last&quot;: &quot;Big&quot;}, {&quot;first&quot;: &quot;Justin&quot;, &quot;last&quot;: &quot;Frozen&quot;}]&#39; | jq -c &#39;.[] | {first, last, id: (.first + .last | md5) }&#39;\r\n\r\nto output:\r\n\r\n    {&quot;first&quot;:&quot;John&quot;,&quot;last&quot;:&quot;Big&quot;,&quot;id&quot;:&quot;cda5c2dd89a0ab28a598a6b22e5b88ce&quot;}\r\n    {&quot;first&quot;:&quot;Justin&quot;,&quot;last&quot;:&quot;Frozen&quot;,&quot;id&quot;:&quot;af97f1bd8468e013c432208c32272668&quot;}\r\n\r\n\r\n  [1]: http://ndjson.org/",
        "link": "https://stackoverflow.com/questions/48548580/shell-out-value-to-md5-crypto-function",
        "title": "shell-out value to md5 (crypto) function"
    },
    {
        "tags": [
            "json",
            "string-matching",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1517475614,
                "last_edit_date": 1517475614,
                "creation_date": 1517471237,
                "answer_id": 48557707,
                "question_id": 48557351,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In your test.json, the value of .url is `&quot;https://&lt;part1&gt;.test/hai/&lt;part1&gt;&quot;` so evidently you don&#39;t want to check that its value is `&quot;&lt;part1&gt;&quot;`.\r\n\r\nPerhaps you meant to test the condition: `.url | contains(&quot;&lt;part1&gt;&quot;)` or maybe `.url | endswith(&quot;&lt;part1&gt;&quot;)` -- the problem description is unclear.\r\n\r\nIf your jq has support for regular expressions, you could use `test/1`, e.g.\r\n\r\n    .url | test(&quot;//&lt;part1&gt;.*&lt;part1&gt;$&quot;)\r\n\r\nAnother possibility would be to use `gsub`.",
                "title": "Replace the placeholder in the String with actual value using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1517475614,
        "creation_date": 1517469780,
        "last_edit_date": 1517471322,
        "question_id": 48557351,
        "body_markdown": "It is not working.  How to check the part of the String (not the whole String)?\r\n\r\ntest.json\r\n---------\r\n\r\n    {\r\n     &quot;url&quot;: &quot;https://&lt;part1&gt;.test/hai/&lt;part1&gt;&quot;\r\n    }\r\n\r\n\r\n\r\n    jq --arg input &quot;$arg&quot; \\\r\n       &#39;if .url == &quot;&lt;part1&gt;&quot;\r\n         then . + {&quot;url&quot; : (&quot;https://&quot; + $input + &quot;.test/hai/&quot; + $input)  }\r\n           else . end&#39; test.json  &gt; test123.json",
        "link": "https://stackoverflow.com/questions/48557351/replace-the-placeholder-in-the-string-with-actual-value-using-jq",
        "title": "Replace the placeholder in the String with actual value using jq"
    },
    {
        "tags": [
            "json",
            "date",
            "jq",
            "strptime",
            "strftime"
        ],
        "comments": [
            {
                "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": 1517500604,
                "post_id": 48566431,
                "comment_id": 84129723,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1517504274,
                "last_edit_date": 1517504274,
                "creation_date": 1517500239,
                "answer_id": 48566731,
                "question_id": 48566431,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. You could use the built-in filter `strptime/1` after truncating the string appropriately - see any documentation on the standard C library function, e.g.\r\nhttp://pubs.opengroup.org/onlinepubs/009695399/functions/strptime.html\r\n\r\nFor example:\r\n\r\n     sub(&quot; [A-Z]+$&quot;;&quot;&quot;)\r\n     | strptime(&quot;%a, %d %b %Y %T&quot;)\r\n     | mktime\r\n     | strftime(&quot;%Y-%m-%d&quot;)\r\n\r\n2. It would probably be simpler and better to fix the problem at the source, i.e. in your Python program.",
                "title": "jq date manipulation assistance"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1517553412,
        "creation_date": 1517499246,
        "last_edit_date": 1517553412,
        "question_id": 48566431,
        "body_markdown": "I have a mysql date field, called &quot;dateFound&quot;. \r\n\r\n    dateFound       | date         | YES  |     | NULL              |                             |\r\n\r\nI&#39;ve created a very basic python API that pulls all the data out of MySQL and serves it up via json. In the process, it seems to be converting YYYY-MM-DD into YYYY-MM-DD 00:00:00\r\n\r\n    mysql&gt; select dateFound from db where item = 111222;\r\n    +------------+\r\n    | dateFound  |\r\n    +------------+\r\n    | 2017-11-12 |\r\n    +------------+\r\n\r\nBut in the json output it is:\r\n\r\n    dateFound\t&quot;Sun, 12 Nov 2017 00:00:00 GMT&quot;\r\n\r\nI&#39;m trying to isolate how, via jq, I can convert that back YYYY-MM-DD but am really not finding it.\r\n\r\n    jq -r &#39;[&quot;Date Found&quot;], [&quot;-------------&quot;], (.Data[] | [.dateFound]) |  @tsv &#39; &lt;&lt;&lt;$Report\r\n\r\nis a basic approximation of the conversion I&#39;m doing (minus all the other fields), which does give me all the data I need. It&#39;s just that date format that I can&#39;t get back into YYYY-MM-DD. \r\n\r\nI tried inserting a pipe into strptime with the format defined, but that clearly wasn&#39;t the right syntax. Looking for a pointer to what I&#39;m missing. I would have thought date manipulation on the data pulled would be easier than this or I am missing something really obvious.\r\n\r\nAny assistance appreciated.",
        "link": "https://stackoverflow.com/questions/48566431/jq-date-manipulation-assistance",
        "title": "jq date manipulation assistance"
    },
    {
        "tags": [
            "date",
            "time",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1517584278,
                "creation_date": 1517584278,
                "answer_id": 48585575,
                "question_id": 48583928,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    # Input: date in &quot;dd.mm.yyyy hh:mm:ss&quot; format;\r\n    # returns true iff the date is more than (24 * days) hours\r\n    # in the past relative to `now`\r\n    def older(days):\r\n      (now - (strptime(&quot;%d.%m.%Y %T&quot;) | mktime)) #  seconds \r\n      &gt;  (days*24*3600);\r\n\r\nExample:\r\n\r\n    &quot;30.1.2018 17:11:56&quot;\r\n    | older(2)\r\n\r\nemits `true`.\r\n\r\n\r\n",
                "title": "jq select from date value after X days from now"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1517584278,
        "creation_date": 1517578812,
        "last_edit_date": 1517582186,
        "question_id": 48583928,
        "body_markdown": "i have this one json response:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;b8895839-52d3-40e1-8c86-20463f38fec4&quot;,\r\n        &quot;created&quot;: &quot;23.08.2016 17:11:56&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;294374c0-0fb9-4ab6-853c-e0a11fde4906&quot;,\r\n        &quot;created&quot;: &quot;26.08.2016 11:22:38&quot;\r\n      }\r\n    ]\r\n\r\nI want to return ids that the last created date is &gt; 2 days from current date\r\n\r\nhow i can do that?  \r\n\r\n    jq &#39;def ago(days): now - (days*24*3600);\r\n    .[] | select ( .created | sub(&quot;\\\\.[0-9]*&quot;;&quot;&quot;) &lt; ago(2) )| .id&#39;\r\n\r\nthis one does not work for me\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48583928/jq-select-from-date-value-after-x-days-from-now",
        "title": "jq select from date value after X days from now"
    },
    {
        "tags": [
            "syntax",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1517627916,
                "last_edit_date": 1517627916,
                "creation_date": 1517597156,
                "answer_id": 48589061,
                "question_id": 48586980,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`and` is a boolean (logical) operator.  What you want here is to create a pipeline using &#39;|&#39;:\r\n\r\n    jq --arg input1 &quot;$arg1&quot; --arg input2 &quot;$arg2&quot; &#39;\r\n       if .url | contains(&quot;&lt;part1&gt;&quot;)\r\n       then . + {url : (&quot;https://&quot; + $input1 + &quot;.test/hai/&quot; + $input1)  }\r\n       else . end\r\n       | if .ParameterValue == &quot;&lt;value&gt;&quot;\r\n         then . + {ParameterValue : $input2 }\r\n         else . end&#39; test.json  &gt; test123.json\r\n\r\nOr maybe better:\r\n\r\n       def when(filter; action): if (filter?) // null then action else . end;\r\n       when(.url | contains(&quot;&lt;part1&gt;&quot;);\r\n            .url = (&quot;https://&quot; + $input1 + &quot;.test/hai/&quot; + $input1))\r\n       | when(.ParameterValue == &quot;&lt;value&gt;&quot;;\r\n            .ParameterValue = $input2)\r\n\r\n\r\n",
                "title": "combining jq conditions using and"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1517627929,
        "creation_date": 1517589029,
        "last_edit_date": 1517627929,
        "question_id": 48586980,
        "body_markdown": "How to combine two jq conditions using &#39;and&#39;.\r\n\r\n**test.json**\r\n\r\n    {\r\n     &quot;url&quot;: &quot;https://&lt;part1&gt;.test/hai/&lt;part1&gt;&quot;,\r\n     &quot;ParameterValue&quot;: &quot;&lt;value&gt;&quot;  \r\n    }\r\n\r\n    jq --arg input1 &quot;$arg1&quot; --arg input2 &quot;$arg2&quot; \\\r\n       &#39;if .url | contains(&quot;&lt;part1&gt;&quot;)\r\n         then . + {&quot;url&quot; : (&quot;https://&quot; + $input1 + &quot;.test/hai/&quot; + $input1)  }\r\n           else . end&#39;    and \r\n        &#39;if .ParameterValue == &quot;&lt;value&gt;&quot;\r\n                             then . + {&quot;ParameterValue&quot; : ($input2) }\r\n                      else . end&#39;   test.json  &gt; test123.json\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48586980/combining-jq-conditions-using-and",
        "title": "combining jq conditions using and"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4610729,
                    "reputation": 986,
                    "user_id": 3738936,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/243e6594a90e494d104cc567efe1c866?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Don M",
                    "link": "https://stackoverflow.com/users/3738936/don-m"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1517593098,
                "post_id": 48588056,
                "comment_id": 84173260,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3377022,
                    "reputation": 13682,
                    "user_id": 2834978,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ff9af10001f37bc0de566ca2caf2f558?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "LMC",
                    "link": "https://stackoverflow.com/users/2834978/lmc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1517593286,
                "post_id": 48588056,
                "comment_id": 84173344,
                "content_license": "CC BY-SA 3.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": 1517593527,
                "post_id": 48588056,
                "comment_id": 84173484,
                "content_license": "CC BY-SA 3.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": 1517593587,
                "post_id": 48588056,
                "comment_id": 84173516,
                "content_license": "CC BY-SA 3.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": 1517593911,
                "post_id": 48588056,
                "comment_id": 84173668,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4610729,
                    "reputation": 986,
                    "user_id": 3738936,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/243e6594a90e494d104cc567efe1c866?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Don M",
                    "link": "https://stackoverflow.com/users/3738936/don-m"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1517594067,
                "post_id": 48588056,
                "comment_id": 84173753,
                "content_license": "CC BY-SA 3.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": 1517594850,
                "post_id": 48588056,
                "comment_id": 84174120,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1517593674,
                "creation_date": 1517593674,
                "answer_id": 48588236,
                "question_id": 48588056,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use `|=` to modify the piece in-place but return the larger document.\r\n\r\n    tempfile=$(mktemp test.json.XXXXXX)\r\n    trap &#39;rm -f -- &quot;$tempfile&quot;&#39; EXIT\r\n\r\n    if jq &#39;.Statement[0].Condition.IpAddress[&quot;aws:SourceIp&quot;] |= .[0:-1]&#39; \\\r\n            &lt;test.json &gt;&quot;$tempfile&quot;; then\r\n        chmod --reference=test.json -- &quot;$tempfile&quot; # this is a GNUism; tweak elsewhere.\r\n        mv -- &quot;$tempfile&quot; test.json\r\n    else\r\n        rm -f -- &quot;$tempfile&quot;\r\n    fi\r\n\r\nThis version also takes more care to replace the file with an updated one in a way that never can leave partially-written contents.",
                "title": "Pop last string from array with jq and return whole json object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1517610482,
                "creation_date": 1517610482,
                "answer_id": 48591765,
                "question_id": 48588056,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This is basically just a slightly simpler variant of @CharleDuffy&#39;s excellent answer, but it does use `sponge` (part of `moreutils`), the point being that `sponge` preserves the permissions of the specified file:\r\n\r\n    jq &#39;.Statement[0].Condition.IpAddress[&quot;aws:SourceIp&quot;] |= .[:-1]&#39; test.json |\r\n      sponge test.json",
                "title": "Pop last string from array with jq and return whole json object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1517610482,
        "creation_date": 1517592994,
        "last_edit_date": 1517594252,
        "question_id": 48588056,
        "body_markdown": "test.json\r\n\r\n    {\r\n        &quot;Version&quot;: &quot;2012-**-**&quot;,\r\n        &quot;Statement&quot;: [\r\n            { &quot;Effect&quot;: &quot;**&quot;,\r\n              &quot;Principal&quot;: &quot;**&quot;,\r\n              &quot;Action&quot;: &quot;**&quot;,\r\n              &quot;Resource&quot;: &quot;***&quot;,\r\n              &quot;Condition&quot;: {\r\n                &quot;IpAddress&quot;: {\r\n                    &quot;aws:SourceIp&quot;: [ &quot;127.0.0.1&quot;, &quot;1.0.0.2&quot; ]\r\n                }\r\n              }\r\n            }\r\n        ]\r\n    }\r\n\r\nI would like to pop the array of aws:SourceIp so that the 1.0.0.2, or whatever the last element of the array is removed.\r\nThe return value should be the whole json object with the array missing the 1.0.0.2.\r\n\r\nI have come close with this:\r\n\r\n    echo $(jq &#39;.Statement[0] .Condition.IpAddress.&quot;aws:SourceIp&quot; | .[0:-1] &#39; test.json ) &gt; test.json\r\n\r\nWith the help of:\r\nhttps://github.com/stedolan/jq/issues/226\r\n\r\nThis will pop the last element of the array but return only [ &quot;127.0.0.1&quot;] and then push this in to test.json.\r\n\r\nI would like it to return the whole json modified so that I can then be pushed in to test.JSON\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48588056/pop-last-string-from-array-with-jq-and-return-whole-json-object",
        "title": "Pop last string from array with jq and return whole json object"
    },
    {
        "tags": [
            "arrays",
            "json",
            "rename",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1517695639,
                "last_edit_date": 1517695639,
                "creation_date": 1517684896,
                "answer_id": 48600990,
                "question_id": 48600234,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming your jq has regex support (e.g. jq 1.5):\r\n\r\n    .values |= map(sub(&quot;foo:&quot;;&quot;&quot;)))\r\n\r\nOr maybe `&quot;^foo:&quot;;` ...",
                "title": "JQ rename parts of values in array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1517695639,
        "creation_date": 1517680209,
        "last_edit_date": 1517690938,
        "question_id": 48600234,
        "body_markdown": "I try to rename the values in an array. However, only parts of them, keeping the other parts. Managed to rename whole strings, but not the &quot;parts-task&quot; using JQ.\r\n\r\n\r\nJSON input:\r\n\r\n    {\r\n      &quot;values&quot;: [\r\n        &quot;foo:bar1&quot;,\r\n        &quot;foo:bar2&quot;,\r\n        &quot;foo:bar3&quot;\r\n      ]\r\n    }\r\n\r\n\r\ndesired output:\r\n\r\n\r\n    {\r\n      &quot;values&quot;: [\r\n        &quot;bar1&quot;,\r\n        &quot;bar2&quot;,\r\n        &quot;bar3&quot;\r\n      ]\r\n    }\r\n\r\n\r\nThank you in advance!",
        "link": "https://stackoverflow.com/questions/48600234/jq-rename-parts-of-values-in-array",
        "title": "JQ rename parts of values in array"
    },
    {
        "tags": [
            "json",
            "csv",
            "hierarchical-data",
            "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": 1517768546,
                "post_id": 48611465,
                "comment_id": 84219435,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4525077,
                    "reputation": 523,
                    "user_id": 3677164,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/TU2e6.jpg?s=256",
                    "display_name": "Hubert L&#233;veill&#233; Gauvin",
                    "link": "https://stackoverflow.com/users/3677164/hubert-l%c3%a9veill%c3%a9-gauvin"
                },
                "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": 1517836625,
                "post_id": 48611465,
                "comment_id": 84243410,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1517768332,
                "creation_date": 1517768332,
                "answer_id": 48611510,
                "question_id": 48611465,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "See the &quot;Variable / Symbolic Binding Operator&quot; section in [`jq`&#39;s documentation](https://stedolan.github.io/jq/manual/)\r\n\r\n    jq -r &#39;\r\n      .name as $album_name           ### &lt;- THIS RIGHT HERE\r\n      | .tracks.items[]\r\n      | [$album_name, .artists[].name, .name, .duration_ms]\r\n      | @csv\r\n    &#39; myfile.json\r\n",
                "title": "How to use jq @CSV filter to generate a csv file with values from different json levels"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1517888317,
        "creation_date": 1517768076,
        "last_edit_date": 1517888317,
        "question_id": 48611465,
        "body_markdown": "I have a JSON file from the Spotify API that lists all the songs on a specific album. The file is organized as follows:\r\n\r\n    .\r\n    .name\r\n    .tracks.items\r\n    .tracks.items[]\r\n    .tracks.items[].artists\r\n    .tracks.items[].artists[].name\r\n    .tracks.items[].duration_ms\r\n    .tracks.items[].name\r\n\r\nI&#39;m using jq to create a csv with the following information: song&#39;s artist, song&#39;s title, and song&#39;s duration. I can do this using the following syntax:\r\n\r\n    jq -r &#39;.tracks.items[] | [.artists[].name, .name, .duration_ms] | @csv&#39; myfile.json\r\n\r\nOutput:\r\n\r\n    &quot;Michael Jackson&quot;,&quot;Wanna Be Startin&#39; Somethin&#39;&quot;,363400\r\n    &quot;Michael Jackson&quot;,&quot;Baby Be Mine&quot;,260666 \r\n    ...\r\n\r\nHowever, I would like to also add the value under `.name` (which represents the name of the album the songs are from) to every row of my csv file. Something that would look like this:\r\n\r\n    &quot;Thriller&quot;,&quot;Michael Jackson&quot;,&quot;Wanna Be Startin&#39; Somethin&#39;&quot;,363400\r\n    &quot;Thriller&quot;,&quot;Michael Jackson&quot;,&quot;Baby Be Mine&quot;,260666 \r\n    ...\r\n\r\nIs it possible to do this using the @csv filter? I can do it by hand by hardcoding the name of the album like this \r\n\r\n    jq -r &#39;.tracks.items[] | [&quot;Thriller&quot;, .artists[].name, .name, .duration_ms] | @csv&#39; myfile.json\r\n\r\nBut I was hoping there might be a nicer way to do it.\r\n\r\nEDIT:\r\n\r\nHere&#39;s what the file looks like:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;Thriller&quot;,\r\n      &quot;tracks&quot;: {\r\n        &quot;items&quot;: [\r\n          {\r\n            &quot;artists&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;Michael Jackson&quot;\r\n              }\r\n            ],\r\n            &quot;duration_ms&quot;: 363400,\r\n            &quot;name&quot;: &quot;Wanna Be Startin&#39; Somethin&#39;&quot;\r\n          },\r\n          {\r\n            &quot;artists&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;Michael Jackson&quot;\r\n              }\r\n            ],\r\n            &quot;duration_ms&quot;: 260666,\r\n            &quot;name&quot;: &quot;Baby Be Mine&quot;\r\n          }\r\n          ]\r\n       }\r\n    }\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48611465/how-to-use-jq-csv-filter-to-generate-a-csv-file-with-values-from-different-json",
        "title": "How to use jq @CSV filter to generate a csv file with values from different json levels"
    },
    {
        "tags": [
            "sql",
            "perl",
            "awk",
            "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": 1517776279,
                "post_id": 48612588,
                "comment_id": 84222068,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 12877653,
                    "reputation": 55,
                    "user_id": 9313775,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-VLAjBqVFnCE/AAAAAAAAAAI/AAAAAAAAAE8/Ro8YGwFlp_A/s256-rj/photo.jpg",
                    "display_name": "Argenis Ramirez",
                    "link": "https://stackoverflow.com/users/9313775/argenis-ramirez"
                },
                "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": 1517776589,
                "post_id": 48612588,
                "comment_id": 84222174,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1517777760,
                "creation_date": 1517777760,
                "answer_id": 48612927,
                "question_id": 48612588,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    $ awk &#39;BEGIN {RS=&quot;&quot;; OFS=&quot;,&quot;} {$1=$1; $0=&quot;(&quot;$0&quot;)&quot;}1&#39; file\r\n    (1517773500000,0.10250100,0.10275700,0.10243500,0.10256600,257.26700000,1517773799999,26.38912220,1229,104.32200000,10.70579910,0)\r\n    (1517773800000,0.10256600,0.10268000,0.10231600,0.10243400,310.64600000,1517774099999,31.83806883,1452,129.70500000,13.29758266,0)\r\n    (1517774100000,0.10243400,0.10257500,0.10211800,0.10230000,359.06300000,1517774399999,36.73708621,1296,154.78500000,15.84041910,0)\r\n\r\n**RS=&quot;&quot;**:  \r\nTreat groups of lines separated one or more blank lines as a record\r\n\r\n**OFS=&quot;,&quot;**  \r\nSet the output separator to be a &quot;,&quot;\r\n\r\n**$1=$1**  \r\nReconstitute the line, replacing the input separators with the output separator\r\n\r\n**$0=&quot;(&quot;$0&quot;)&quot;**  \r\nSurround the record with parens\r\n\r\n**1**   \r\nPrint the record",
                "title": "Awk, order foreach 12 lines to insert query"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1517825671,
                "last_edit_date": 1517825671,
                "creation_date": 1517777932,
                "answer_id": 48612952,
                "question_id": 48612588,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s an all-jq solution:  \r\n\r\n    .[] | .[0:12] | @tsv | gsub(&quot;\\t&quot;;&quot;,&quot;) | &quot;(\\(.))&quot;\r\n\r\nIn the sample, all the subarrays have length 12, so you might be able to drop the `.[0:12]` part of the pipeline. If using jq 1.5 or later, you could use `join(“,”)` instead of the @tsv|gsub portion of the pipeline. You might, for example, want to consider:\r\n\r\n    .[] | join(“,”) | “(\\(.))”.   # jq 1.5 or later\r\n\r\nInvocation: use the -r command-line option\r\n\r\nSample output:\r\n\r\n    (1517627400000,0.10452300,0.10499000,0.10418200,0.10449400,819.50400000,1517627699999,85.57150693,2340,452.63400000,47.27213035,0)\r\n    (1517627700000,0.10435700,0.10449200,0.10366000,0.10370000,717.37000000,1517627999999,74.60582079,1996,321.25500000,33.42273846,0)\r\n    (1517628000000,0.10376600,0.10390000,0.10366000,0.10370400,519.59400000,1517628299999,53.88836170,1258,239.89300000,24.88613854,0)",
                "title": "Awk, order foreach 12 lines to insert query"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1517825671,
        "creation_date": 1517775482,
        "last_edit_date": 1517824146,
        "question_id": 48612588,
        "body_markdown": "I have the following script:\r\n\r\n    curl -s &#39;https://someonepage=5m&#39; | jq &#39;.[]|.[0],.[1],.[2],.[3],.[4],.[5],.[6],.[7],.[8],.[9],.[10],.[11],.[12]&#39; | perl -p -e &#39;s/\\&quot;//g&#39; |awk &#39;/^[0-9]/{print; if (++onr%12 == 0) print &quot;&quot;; }&#39;\r\n\r\nThis is part of result:\r\n\r\n    1517773500000\r\n    0.10250100\r\n    0.10275700\r\n    0.10243500\r\n    0.10256600\r\n    257.26700000\r\n    1517773799999\r\n    26.38912220\r\n    1229\r\n    104.32200000\r\n    10.70579910\r\n    0\r\n    \r\n    1517773800000\r\n    0.10256600\r\n    0.10268000\r\n    0.10231600\r\n    0.10243400\r\n    310.64600000\r\n    1517774099999\r\n    31.83806883\r\n    1452\r\n    129.70500000\r\n    13.29758266\r\n    0\r\n    \r\n    1517774100000\r\n    0.10243400\r\n    0.10257500\r\n    0.10211800\r\n    0.10230000\r\n    359.06300000\r\n    1517774399999\r\n    36.73708621\r\n    1296\r\n    154.78500000\r\n    15.84041910\r\n    0\r\n\r\nI want to insert this data in a MySQL database. I want for each line this result:\r\n\r\n    (1517773800000,0.10256600,0.10268000,0.10231600,0.10243400,310.64600000,1517774099999,31.83806883,1452,129.70500000,13.29758266,0)\r\n    \r\n    (1517774100000,0.10243400,0.10257500,0.10211800,0.10230000,359.06300000,151774399999,36.73708621,1296,154.78500000,15.84041910,0)\r\n\r\nI need merge lines each 12 lines, any can help me for get this result.\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48612588/awk-order-foreach-12-lines-to-insert-query",
        "title": "Awk, order foreach 12 lines to insert query"
    },
    {
        "tags": [
            "python",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4657551,
                    "reputation": 57253,
                    "user_id": 4492932,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/e8938ef2681650e100bc9f83434ef272?s=256&d=identicon&r=PG",
                    "display_name": "DYZ",
                    "link": "https://stackoverflow.com/users/4492932/dyz"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1517792142,
                "post_id": 48614477,
                "comment_id": 84226033,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1517792156,
                "creation_date": 1517792156,
                "answer_id": 48614546,
                "question_id": 48614477,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you loop through the data you can reform a new dict like:\r\n\r\n###Code:\r\n\r\n    output = {}\r\n    for datum in data:\r\n        for car in datum[&#39;car&#39;]:\r\n            output.setdefault(datum[&#39;colour&#39;], []).append(car[&#39;year&#39;])\r\n\r\n###Test Code:\r\n\r\n    data = [\r\n        {&quot;colour&quot;: &quot;Red&quot;,\r\n         &quot;car&quot;: [{&quot;year&quot;: 2000, &quot;make&quot;: &quot;Honda&quot;, &quot;model&quot;: &quot;Accord&quot;}]},\r\n        {&quot;colour&quot;: &quot;Blue&quot;,\r\n         &quot;car&quot;: [{&quot;year&quot;: 2015, &quot;make&quot;: &quot;Toyota&quot;, &quot;model&quot;: &quot;Camry&quot;}]},\r\n        {&quot;colour&quot;: &quot;Red&quot;,\r\n         &quot;car&quot;: [{&quot;year&quot;: 1999, &quot;make&quot;: &quot;Dodge&quot;, &quot;model&quot;: &quot;Ram&quot;}]}\r\n    ]\r\n\r\n    output = {}\r\n    for datum in data:\r\n        for car in datum[&#39;car&#39;]:\r\n            output.setdefault(datum[&#39;colour&#39;], []).append(car[&#39;year&#39;])\r\n    print(output)\r\n\r\n###Results:\r\n\r\n    {&#39;Red&#39;: [2000, 1999], &#39;Blue&#39;: [2015]}",
                "title": "Bad JSON to Custom JSON"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1517796197,
                "last_edit_date": 1517796197,
                "creation_date": 1517792515,
                "answer_id": 48614590,
                "question_id": 48614477,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**jq** is perfect for this. Let&#39;s see what it can do. First, let&#39;s group the cars by color. `group_by()` takes an array and groups the elements by whatever sub-expression you want.\r\n\r\n    $ jq &#39;group_by(.colour)&#39; input.json\r\n    [\r\n        [\r\n            {&quot;car&quot;:[{&quot;model&quot;:&quot;Camry&quot;,&quot;make&quot;:&quot;Toyota&quot;,&quot;year&quot;:2015}],&quot;colour&quot;:&quot;Blue&quot;}\r\n        ],\r\n        [\r\n            {&quot;car&quot;:[{&quot;model&quot;:&quot;Accord&quot;,&quot;make&quot;:&quot;Honda&quot;,&quot;year&quot;:2000}],&quot;colour&quot;:&quot;Red&quot;},\r\n            {&quot;car&quot;:[{&quot;model&quot;:&quot;Ram&quot;,   &quot;make&quot;:&quot;Dodge&quot;,&quot;year&quot;:1999}],&quot;colour&quot;:&quot;Red&quot;}\r\n        ]\r\n    ]\r\n\r\nThen let&#39;s map each sub-array to a `{color: [years]}` object. The `map()` function takes an array and changes each input element into some new output element. We can use it to create the exact `{color: [years]}` objects we desire.\r\n\r\nLet&#39;s start with a partial mapping. We&#39;ll pull out the colors and see what that looks like.\r\n\r\n    $ jq -c &#39;group_by(.colour) | map({(.[0].colour): []})&#39; input.json\r\n    [{&quot;Blue&quot;:[]},{&quot;Red&quot;:[]}]\r\n\r\nPerfect. We have the colors. Now to get the list of years we use `map` again, turn the sub-arrays of cars into arrays of years.\r\n\r\n    $ jq -c &#39;group_by(.colour) | map({(.[0].colour): map(.car[].year)})&#39; input.json\r\n    [{&quot;Blue&quot;:[2015]},{&quot;Red&quot;:[2000,1999]}]\r\n\r\n\r\n",
                "title": "Bad JSON to Custom JSON"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1517817004,
                "last_edit_date": 1517817004,
                "creation_date": 1517806649,
                "answer_id": 48616090,
                "question_id": 48614477,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`group_by` involves a sort, and is thus unnecessarily inefficient for the problem at hand. Here is a direct approach using jq.  It is similar to the python solution provided elsewhere on this page:\r\n\r\n     reduce .[] as $car ({};\r\n       .[ $car.colour ] += ($car.car | map(.year)) )\r\n     | map_values(if length==1 then .[0] else . end)\r\n     | [ to_entries[] | {(.key): .value} ]\r\n\r\nThe line beginning with `map_values` serves to meet the requirement that singleton arrays be avoided. The last line could be omitted if a dictionary of results is acceptable.\r\n\r\nNotice that the above program will work even if the `.car` array has more than one element.\r\n\r\n\r\n\r\n",
                "title": "Bad JSON to Custom JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1517817004,
        "creation_date": 1517791401,
        "last_edit_date": 1517792381,
        "question_id": 48614477,
        "body_markdown": "I am currently trying to massage undesirable JSON output that I am returning into a format that is more valuable to me. Answers should be using jq or Python code (I am using the pyjq library in python)\r\n\r\nHere is the current JSON output:\r\n\r\n    [\r\n     {&quot;colour&quot;:&quot;Red&quot;, &quot;car&quot;: [ {&quot;year&quot;:2000, &quot;make&quot;:&quot;Honda&quot;, &quot;model&quot;:&quot;Accord&quot;} ] },\r\n     {&quot;colour&quot;:&quot;Blue&quot;, &quot;car&quot;: [ {&quot;year&quot;:2015, &quot;make&quot;:&quot;Toyota&quot;, &quot;model&quot;:&quot;Camry&quot;} ] },\r\n     {&quot;colour&quot;:&quot;Red&quot;, &quot;car&quot;: [ {&quot;year&quot;:1999, &quot;make&quot;:&quot;Dodge&quot;, &quot;model&quot;:&quot;Ram&quot;} ] }\r\n    ]\r\n\r\nUsing jq or possibly looping through using Python, I would like to format this into a new JSON object that looks like this:\r\n \r\n    [\r\n     { &quot;Red&quot;:[2000,1999] },\r\n     { &quot;Blue&quot;: 2015 }\r\n    ]\r\n\r\nDoes anybody know how I can format any JSON that looks like the first snippet above, and turn it into the desired outcome listed in the second snippet.",
        "link": "https://stackoverflow.com/questions/48614477/bad-json-to-custom-json",
        "title": "Bad JSON to Custom JSON"
    },
    {
        "tags": [
            "json",
            "npm",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1517857219,
                "creation_date": 1517857219,
                "answer_id": 48629658,
                "question_id": 48629417,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "By using `..`, it will recurse through all values in the json tree. So you&#39;ll want to filter those out by objects that have the structure you&#39;re expecting. In this case, things that have a valid `dependencies` object. Once you&#39;ve located the objects, you could extract the values you want.\r\n\r\n    jq -r &#39;.. | .dependencies? | objects\r\n        | to_entries[] | [.key, .value.version, &quot;js&quot;, .value.resolved] | join(&quot;;&quot;)&#39; input.json\r\n\r\nproduces the results:\r\n\r\n    npm;5.5.1;js;\r\n    yaml-table;1.1.3;js;https://registry.npmjs.org/yaml-table/-/yaml-table-1.1.3.tgz\r\n    JSONStream;1.3.1;js;https://registry.npmjs.org/JSONStream/-/JSONStream-1.3.1.tgz\r\n    jsonparse;1.3.1;js;https://registry.npmjs.org/jsonparse/-/jsonparse-1.3.1.tgz\r\n    through;2.3.8;js;https://registry.npmjs.org/through/-/through-2.3.8.tgz\r\n    js-yaml;3.4.6;js;https://registry.npmjs.org/js-yaml/-/js-yaml-3.4.6.tgz\r\n    argparse;1.0.9;js;https://registry.npmjs.org/argparse/-/argparse-1.0.9.tgz\r\n\r\n",
                "title": "Recursive extraction of object values and parent key name using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1517857219,
        "creation_date": 1517856309,
        "question_id": 48629417,
        "body_markdown": "I have a requirement to parse the output of the `npm ls --global --json` command, such that I get a list of all the installed `npm` packages in the following format:\r\n\r\n`$package;$version;js;$resolved`\r\n\r\nWhere:\r\n\r\n * `$package` is the key containing the package name, from each `dependencies` object.\r\n * `$version` is the `version` value taken from each package\r\n * `js` is just a literal string\r\n * `$resolved` is the `resolved` value taken from each package\r\n\r\nI have gotten as far as this command syntax and output:\r\n\r\n    $ jq --raw-output &#39;select( has(&quot;dependencies&quot;) ) .dependencies[] | . as $d | &quot;parentkey&quot; + &quot;;&quot; + $d.version + &quot;;js;&quot; + $d.resolved&#39;`\r\n    parentkey;5.5.1;js;\r\n    parentkey;1.1.3;js;https://registry.npmjs.org/yaml-table/-/yaml-table-1.1.3.tgz\r\n\r\nThe parts that I am specificly having difficulty with are as follows:\r\n\r\n* How can I get the key name value that I am iterating over in `.dependencies` that contains that package name. It seems that by that point I am looking at the contents of that object itself.\r\n\r\n* How can I recurse through ALL dependency objects? At the moment I&#39;m only looking at the top level records in the root `.dependencies` object. I&#39;ve discovered `..` recursion, but I&#39;m not quite sure how to apply it here.\r\n\r\nBased on the example data below, I am trying to reach the following output results:\r\n\r\n    npm;5.5.1;js;\r\n    JSONStream;1.3.1;js;https://registry.npmjs.org/JSONStream/-/JSONStream-1.3.1.tgz\r\n    jsonparse;1.3.1;js;https://registry.npmjs.org/jsonparse/-/jsonparse-1.3.1.tgz\r\n    through;2.3.8;js;https://registry.npmjs.org/through/-/through-2.3.8.tgz\r\n    yaml-table;1.1.3;js;https://registry.npmjs.org/yaml-table/-/yaml-table-1.1.3.tgz\r\n    js-yaml;3.4.6;js;https://registry.npmjs.org/js-yaml/-/js-yaml-3.4.6.tgz\r\n    argparse;1.0.9;js;https://registry.npmjs.org/argparse/-/argparse-1.0.9.tgz\r\n\r\nSome (much reduced) sample output `npm ls --global --json` that I have used for the above example, is as follows:\r\n\r\n    {\r\n      &quot;dependencies&quot;: {\r\n        &quot;npm&quot;: {\r\n          &quot;version&quot;: &quot;5.5.1&quot;,\r\n          &quot;dependencies&quot;: {\r\n            &quot;JSONStream&quot;: {\r\n              &quot;version&quot;: &quot;1.3.1&quot;,\r\n              &quot;from&quot;: &quot;JSONStream@~1.3.1&quot;,\r\n              &quot;resolved&quot;: &quot;https://registry.npmjs.org/JSONStream/-/JSONStream-1.3.1.tgz&quot;,\r\n              &quot;dependencies&quot;: {\r\n                &quot;jsonparse&quot;: {\r\n                  &quot;version&quot;: &quot;1.3.1&quot;,\r\n                  &quot;from&quot;: &quot;jsonparse@^1.2.0&quot;,\r\n                  &quot;resolved&quot;: &quot;https://registry.npmjs.org/jsonparse/-/jsonparse-1.3.1.tgz&quot;\r\n                },\r\n                &quot;through&quot;: {\r\n                  &quot;version&quot;: &quot;2.3.8&quot;,\r\n                  &quot;from&quot;: &quot;through@&gt;=2.2.7 &lt;3&quot;,\r\n                  &quot;resolved&quot;: &quot;https://registry.npmjs.org/through/-/through-2.3.8.tgz&quot;\r\n                }\r\n              }\r\n            }\r\n          }\r\n        },\r\n        &quot;yaml-table&quot;: {\r\n          &quot;version&quot;: &quot;1.1.3&quot;,\r\n          &quot;from&quot;: &quot;yaml-table@latest&quot;,\r\n          &quot;resolved&quot;: &quot;https://registry.npmjs.org/yaml-table/-/yaml-table-1.1.3.tgz&quot;,\r\n          &quot;dependencies&quot;: {\r\n            &quot;js-yaml&quot;: {\r\n              &quot;version&quot;: &quot;3.4.6&quot;,\r\n              &quot;from&quot;: &quot;js-yaml@3.4.6&quot;,\r\n              &quot;resolved&quot;: &quot;https://registry.npmjs.org/js-yaml/-/js-yaml-3.4.6.tgz&quot;,\r\n              &quot;dependencies&quot;: {\r\n                &quot;argparse&quot;: {\r\n                  &quot;version&quot;: &quot;1.0.9&quot;,\r\n                  &quot;from&quot;: &quot;argparse@&gt;=1.0.2 &lt;2.0.0&quot;,\r\n                  &quot;resolved&quot;: &quot;https://registry.npmjs.org/argparse/-/argparse-1.0.9.tgz&quot;\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48629417/recursive-extraction-of-object-values-and-parent-key-name-using-jq",
        "title": "Recursive extraction of object values and parent key name using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1517934277,
                "creation_date": 1517934277,
                "answer_id": 48647518,
                "question_id": 48647315,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You were close.\r\n\r\n    jq &#39;. | select(.error or .sent)&#39;",
                "title": "Selecting different keys based on success of failure of curl request"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1517935515,
                "creation_date": 1517935515,
                "answer_id": 48647962,
                "question_id": 48647315,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Even shorter (no need for additional pipes):\r\n\r\n    jq &#39;.sent or .error&#39;\r\nThe output:\r\n\r\n    true",
                "title": "Selecting different keys based on success of failure of curl request"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1517935515,
        "creation_date": 1517933621,
        "last_edit_date": 1517934311,
        "question_id": 48647315,
        "body_markdown": "I have the following output from a curl request which can differ based on success / failure of the request\r\n\r\nSuccess: \r\n\r\n    {\r\n      &quot;name&quot;: &quot;appId (xxxxx-xxx-1234)&quot;,\r\n      &quot;sent&quot;: 7939246,\r\n      &quot;received&quot;: 6673490,\r\n      &quot;details&quot;: [\r\n        {\r\n          &quot;timestamp&quot;: &quot;20180201000041&quot;,\r\n          &quot;sentbytes&quot;: 1805,\r\n          &quot;receivedbytes&quot;: 1485\r\n        }\r\n    ]}\r\n\r\nFailure: \r\n\r\n    {\r\n      &quot;error&quot;: &quot;Not found&quot;\r\n    }\r\n\r\nCan someone let me know how to check whether sent or error exists. I have tried\r\n\r\n    jq &#39;. | select (.error | .sent)\r\n\r\nbut that does not seem to be the correct syntax.",
        "link": "https://stackoverflow.com/questions/48647315/selecting-different-keys-based-on-success-of-failure-of-curl-request",
        "title": "Selecting different keys based on success of failure of curl request"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1517942527,
                "last_edit_date": 1517942527,
                "creation_date": 1517939914,
                "answer_id": 48649177,
                "question_id": 48648058,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq &#39;.endpoints |= map((.virtual_endpoint | sub(&quot;https?://[^/]+&quot;; &quot;&quot;)) as $end_p \r\n                          | .vs_endpoints |= [.[] + $end_p] )&#39; main.json\r\n\r\nDemonstration:\r\nhttps://jqplay.org/s/ypiYcNBa-I",
                "title": "json - appending URIs to hostnames programatically through jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1517942527,
        "creation_date": 1517935867,
        "question_id": 48648058,
        "body_markdown": "I&#39;ve been using jq to sort of map multiple json files, i&#39;ve had good success with jq but blocked on finalizing my end results. long story short.\r\n\r\n**I have the following json:\r\nmain.json**\r\n\r\n    {\r\n      &quot;endpoints&quot;: [\r\n        {\r\n          &quot;org&quot;: &quot;Alison Sandbox&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;https://dev.service-now.com/ESD_Assets.do?SOAP&quot;,\r\n          &quot;physical_service&quot;: &quot;ServiceNowService_v1_0&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-dv.soa.com:443/ServiceNow/ESD_ServiceNowSvc_v1_0_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;ServiceNowService_v1_0_vs0&quot;,\r\n          &quot;vs_endpoints&quot;: [\r\n            &quot;https://sandbox-ci.soa.com&quot;,\r\n            &quot;https://sandbox-dv101.soa.com&quot;,\r\n            &quot;https://sandbox-dv102.soa.com&quot;,\r\n            &quot;https://sandbox-dv103.soa.com&quot;,\r\n            &quot;https://sandbox-dv104.soa.com&quot;,\r\n            &quot;https://sandbox-dv105.soa.com&quot;,\r\n            &quot;https://sandbox-dv106.soa.com&quot;,\r\n            &quot;https://sandbox-dv106.soa.com&quot;,\r\n            &quot;https://sandbox-dv107.soa.com&quot;,\r\n            &quot;https://sandbox-dv108.soa.com&quot;,\r\n            &quot;https://sandbox-dv109.soa.com&quot;,\r\n            &quot;https://sandbox-dv110.soa.com&quot;,\r\n            &quot;https://sandbox-dv111.soa.com&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Architecture Frameworks&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://localhostdayofweek/DayOfWeek&quot;,\r\n          &quot;physical_service&quot;: &quot;DayOfWeekServiceMT1001&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-dv.soa.com:443/testpromotion/DayOfWeekServiceMT1001_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;DayOfWeekServiceMT1001_vs0&quot;,\r\n          &quot;vs_endpoints&quot;: [\r\n            &quot;https://sandbox-ci.soa.com&quot;,\r\n            &quot;https://sandbox-dv101.soa.com&quot;,\r\n            &quot;https://sandbox-dv102.soa.com&quot;,\r\n            &quot;https://sandbox-dv103.soa.com&quot;,\r\n            &quot;https://sandbox-dv104.soa.com&quot;,\r\n            &quot;https://sandbox-dv105.soa.com&quot;,\r\n            &quot;https://sandbox-dv106.soa.com&quot;,\r\n            &quot;https://sandbox-dv106.soa.com&quot;,\r\n            &quot;https://sandbox-dv107.soa.com&quot;,\r\n            &quot;https://sandbox-dv108.soa.com&quot;,\r\n            &quot;https://sandbox-dv109.soa.com&quot;,\r\n            &quot;https://sandbox-dv110.soa.com&quot;,\r\n            &quot;https://sandbox-dv111.soa.com&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Architecture Frameworks&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://localhostdayofweek/DayOfWeek/updated&quot;,\r\n          &quot;physical_service&quot;: &quot;DayOfWeekServiceMT1002&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-dv.soa.com:443/UPDATE/DayOfWeekServiceMT1002_vs0_2&quot;,\r\n          &quot;virtual_service&quot;: &quot;DayOfWeekServiceMT1002_vs0&quot;,\r\n          &quot;vs_endpoints&quot;: [\r\n            &quot;https://sandbox-ci.soa.com&quot;,\r\n            &quot;https://sandbox-dv101.soa.com&quot;,\r\n            &quot;https://sandbox-dv102.soa.com&quot;,\r\n            &quot;https://sandbox-dv103.soa.com&quot;,\r\n            &quot;https://sandbox-dv104.soa.com&quot;,\r\n            &quot;https://sandbox-dv105.soa.com&quot;,\r\n            &quot;https://sandbox-dv106.soa.com&quot;,\r\n            &quot;https://sandbox-dv106.soa.com&quot;,\r\n            &quot;https://sandbox-dv107.soa.com&quot;,\r\n            &quot;https://sandbox-dv108.soa.com&quot;,\r\n            &quot;https://sandbox-dv109.soa.com&quot;,\r\n            &quot;https://sandbox-dv110.soa.com&quot;,\r\n            &quot;https://sandbox-dv111.soa.com&quot;\r\n          ]\r\n        },\r\n.\r\n.\r\n.\r\n.\r\n\r\n**I wanted to append the URI part from virtual_endpoint attribute to each of the vs_endpoints (which i appended through jq from another json file)\r\nMy end results would look like this:**\r\n\r\n    {\r\n      &quot;endpoints&quot;: [\r\n        {\r\n          &quot;org&quot;: &quot;Alison Sandbox&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;https://dev.service-now.com/ESD_Assets.do?SOAP&quot;,\r\n          &quot;physical_service&quot;: &quot;ServiceNowService_v1_0&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-dv.soa.com:443/ServiceNow/ESD_ServiceNowSvc_v1_0_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;ServiceNowService_v1_0_vs0&quot;,\r\n          &quot;vs_endpoints&quot;: [\r\n            &quot;https://sandbox-ci.soa.com/ServiceNow/ESD_ServiceNowSvc_v1_0_vs0&quot;,\r\n            &quot;https://sandbox-dv101.soa.com/ServiceNow/ESD_ServiceNowSvc_v1_0_vs0&quot;,\r\n            &quot;https://sandbox-dv102.soa.com/ServiceNow/ESD_ServiceNowSvc_v1_0_vs0&quot;,\r\n            &quot;https://sandbox-dv103.soa.com/ServiceNow/ESD_ServiceNowSvc_v1_0_vs0&quot;,\r\n            &quot;https://sandbox-dv104.soa.com/ServiceNow/ESD_ServiceNowSvc_v1_0_vs0&quot;,\r\n            &quot;https://sandbox-dv105.soa.com/ServiceNow/ESD_ServiceNowSvc_v1_0_vs0&quot;,\r\n            &quot;https://sandbox-dv106.soa.com/ServiceNow/ESD_ServiceNowSvc_v1_0_vs0&quot;,\r\n            &quot;https://sandbox-dv106.soa.com/ServiceNow/ESD_ServiceNowSvc_v1_0_vs0&quot;,\r\n            &quot;https://sandbox-dv107.soa.com/ServiceNow/ESD_ServiceNowSvc_v1_0_vs0&quot;,\r\n            &quot;https://sandbox-dv108.soa.com/ServiceNow/ESD_ServiceNowSvc_v1_0_vs0&quot;,\r\n            &quot;https://sandbox-dv109.soa.com/ServiceNow/ESD_ServiceNowSvc_v1_0_vs0&quot;,\r\n            &quot;https://sandbox-dv110.soa.com/ServiceNow/ESD_ServiceNowSvc_v1_0_vs0&quot;,\r\n            &quot;https://sandbox-dv111.soa.com/ServiceNow/ESD_ServiceNowSvc_v1_0_vs0&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Architecture Frameworks&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://localhostdayofweek/DayOfWeek&quot;,\r\n          &quot;physical_service&quot;: &quot;DayOfWeekServiceMT1001&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-dv.soa.com:443/testpromotion/DayOfWeekServiceMT1001_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;DayOfWeekServiceMT1001_vs0&quot;,\r\n          &quot;vs_endpoints&quot;: [\r\n            &quot;https://sandbox-ci.soa.com/testpromotion/DayOfWeekServiceMT1001_vs0&quot;,\r\n            &quot;https://sandbox-dv101.soa.com/testpromotion/DayOfWeekServiceMT1001_vs0&quot;,\r\n            &quot;https://sandbox-dv102.soa.com/testpromotion/DayOfWeekServiceMT1001_vs0&quot;,\r\n            &quot;https://sandbox-dv103.soa.com/testpromotion/DayOfWeekServiceMT1001_vs0&quot;,\r\n            &quot;https://sandbox-dv104.soa.com/testpromotion/DayOfWeekServiceMT1001_vs0&quot;,\r\n            &quot;https://sandbox-dv105.soa.com/testpromotion/DayOfWeekServiceMT1001_vs0&quot;,\r\n            &quot;https://sandbox-dv106.soa.com/testpromotion/DayOfWeekServiceMT1001_vs0&quot;,\r\n            &quot;https://sandbox-dv106.soa.com/testpromotion/DayOfWeekServiceMT1001_vs0&quot;,\r\n            &quot;https://sandbox-dv107.soa.com/testpromotion/DayOfWeekServiceMT1001_vs0&quot;,\r\n            &quot;https://sandbox-dv108.soa.com/testpromotion/DayOfWeekServiceMT1001_vs0&quot;,\r\n            &quot;https://sandbox-dv109.soa.com/testpromotion/DayOfWeekServiceMT1001_vs0&quot;,\r\n            &quot;https://sandbox-dv110.soa.com/testpromotion/DayOfWeekServiceMT1001_vs0&quot;,\r\n            &quot;https://sandbox-dv111.soa.com/testpromotion/DayOfWeekServiceMT1001_vs0&quot;\r\n           ]\r\n        },\r\n        {\r\n           &quot;org&quot;: &quot;Architecture Frameworks&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://localhostdayofweek/DayOfWeek/updated&quot;,\r\n          &quot;physical_service&quot;: &quot;DayOfWeekServiceMT1002&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-dv.soa.com:443/UPDATE/DayOfWeekServiceMT1002_vs0_2&quot;,\r\n          &quot;virtual_service&quot;: &quot;DayOfWeekServiceMT1002_vs0&quot;,\r\n          &quot;vs_endpoints&quot;: [\r\n            &quot;https://sandbox-ci.soa.com/UPDATE/DayOfWeekServiceMT1002_vs0_2&quot;,\r\n            &quot;https://sandbox-dv101.soa.com/UPDATE/DayOfWeekServiceMT1002_vs0_2&quot;,\r\n            &quot;https://sandbox-dv102.soa.com/UPDATE/DayOfWeekServiceMT1002_vs0_2&quot;,\r\n            &quot;https://sandbox-dv103.soa.com/UPDATE/DayOfWeekServiceMT1002_vs0_2&quot;,\r\n            &quot;https://sandbox-dv104.soa.com/UPDATE/DayOfWeekServiceMT1002_vs0_2&quot;,\r\n            &quot;https://sandbox-dv105.soa.com/UPDATE/DayOfWeekServiceMT1002_vs0_2&quot;,\r\n            &quot;https://sandbox-dv106.soa.com/UPDATE/DayOfWeekServiceMT1002_vs0_2&quot;,\r\n            &quot;https://sandbox-dv106.soa.com/UPDATE/DayOfWeekServiceMT1002_vs0_2&quot;,\r\n            &quot;https://sandbox-dv107.soa.com/UPDATE/DayOfWeekServiceMT1002_vs0_2&quot;,\r\n            &quot;https://sandbox-dv108.soa.com/UPDATE/DayOfWeekServiceMT1002_vs0_2&quot;,\r\n            &quot;https://sandbox-dv109.soa.com/UPDATE/DayOfWeekServiceMT1002_vs0_2&quot;,\r\n            &quot;https://sandbox-dv110.soa.com/UPDATE/DayOfWeekServiceMT1002_vs0_2&quot;,\r\n            &quot;https://sandbox-dv111.soa.com/UPDATE/DayOfWeekServiceMT1002_vs0_2&quot;\r\n          ]\r\n        },\r\n.\r\n.\r\n.\r\n.\r\n.",
        "link": "https://stackoverflow.com/questions/48648058/json-appending-uris-to-hostnames-programatically-through-jq",
        "title": "json - appending URIs to hostnames programatically through jq?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1517947678,
                "creation_date": 1517947678,
                "answer_id": 48651141,
                "question_id": 48650452,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq &#39;[.[] | [(.Authors | split(&quot;, &quot;)), (.Affiliation | split(&quot;, &quot;))] \r\n             | transpose | { authors: map({ Name:.[0], Affiliation:.[1] }) }]&#39; input.json\r\nThe output:\r\n\r\n    [\r\n      {\r\n        &quot;authors&quot;: [\r\n          {\r\n            &quot;Name&quot;: &quot;Author1&quot;,\r\n            &quot;Affiliation&quot;: &quot;Here&quot;\r\n          },\r\n          {\r\n            &quot;Name&quot;: &quot;Author2&quot;,\r\n            &quot;Affiliation&quot;: &quot;There&quot;\r\n          },\r\n          {\r\n            &quot;Name&quot;: &quot;Author3&quot;,\r\n            &quot;Affiliation&quot;: &quot;Everywhere&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;authors&quot;: [\r\n          {\r\n            &quot;Name&quot;: &quot;Author4&quot;,\r\n            &quot;Affiliation&quot;: &quot;Nirvana&quot;\r\n          },\r\n          {\r\n            &quot;Name&quot;: &quot;Author5&quot;,\r\n            &quot;Affiliation&quot;: &quot;Utopia&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\n",
                "title": "Using jq to convert array of strings into array of objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1517947678,
        "creation_date": 1517944910,
        "question_id": 48650452,
        "body_markdown": "\r\nInput json:\r\n\r\n    [\r\n       {\r\n          &quot;Authors&quot;: &quot;Author1, Author2, Author3&quot;,\r\n          &quot;Affiliation&quot;: &quot;Here, There, Everywhere&quot;\r\n       },\r\n       {\r\n          &quot;Authors&quot;: &quot;Author4, Author5&quot;,\r\n          &quot;Affiliation&quot;: &quot;Nirvana, Utopia&quot;\r\n       }\r\n    ]\r\n\r\nDesired output:\r\n\r\n    {\r\n       &quot;authors&quot;: [\r\n          {\r\n             &quot;Name&quot;: &quot;Author1&quot;,\r\n             &quot;Affiliation&quot;: &quot;Here&quot;\r\n          },\r\n          {\r\n             &quot;Name&quot;: &quot;Author2&quot;,\r\n             &quot;Affiliation&quot;: &quot;There&quot;\r\n          },\r\n          {\r\n             &quot;Name&quot;: &quot;Author3&quot;,\r\n             &quot;Affiliation&quot;: &quot;Everywhere&quot;\r\n          }\r\n       ]\r\n    },\r\n    {\r\n       &quot;authors&quot;: [\r\n          {\r\n             &quot;Name&quot;: &quot;Author4&quot;,\r\n             &quot;Affiliation&quot;: &quot;Nirvana&quot;\r\n          },\r\n          {\r\n             &quot;Name&quot;: &quot;Author5&quot;,\r\n             &quot;Affiliation&quot;: &quot;Utopia&quot;\r\n          }\r\n       ]\r\n    }\r\n     \r\nI can read the first elements of both arrays with:\r\n\r\n    jq &#39;.[] as $o | $o.Authors | split(&quot;, &quot;) as $authors | $o.Affiliation | split(&quot;, &quot;) as $affiliation | { &quot;Authors&quot;: [ { &quot;Name&quot;: $authors[.0], &quot;Affiliation&quot;: $affiliation[.0]} ] }&#39;\r\n\r\nbut I&#39;m struggling to understand how to get jq to iterate over the entire (arbitrary length) string to produce the full desired output.\r\n",
        "link": "https://stackoverflow.com/questions/48650452/using-jq-to-convert-array-of-strings-into-array-of-objects",
        "title": "Using jq to convert array of strings into array of objects"
    },
    {
        "tags": [
            "linux",
            "date",
            "time",
            "github-api",
            "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": 1517995729,
                "post_id": 48659631,
                "comment_id": 84317738,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11099976,
                    "reputation": 11,
                    "user_id": 8148936,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/65342516ad9815aace21e7d074489141?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "pprmdas",
                    "link": "https://stackoverflow.com/users/8148936/pprmdas"
                },
                "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": 1518002838,
                "post_id": 48659631,
                "comment_id": 84322549,
                "content_license": "CC BY-SA 3.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": 1518003789,
                "post_id": 48659631,
                "comment_id": 84323150,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11099976,
                    "reputation": 11,
                    "user_id": 8148936,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/65342516ad9815aace21e7d074489141?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "pprmdas",
                    "link": "https://stackoverflow.com/users/8148936/pprmdas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1518004755,
                "post_id": 48659631,
                "comment_id": 84323743,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1518097105,
                "last_edit_date": 1518097105,
                "creation_date": 1518027233,
                "answer_id": 48670694,
                "question_id": 48659631,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using jq:\r\n\r\n    # Input should be a date of the form: 2017-12-15T01:05:47\r\n    def older(days):\r\n      (now - (strptime(&quot;%Y-%m-%dT%T&quot;) | mktime)) #  seconds \r\n      &gt;  (days*24*3600);\r\n    \r\n    .[]\r\n    | (.created_at | sub(&quot;Z.*&quot;;&quot;&quot;)) as $date \r\n    | select($date | older(7) | not)\r\n    | [.number, .user.login, .state, .created_at]\r\n    | @tsv\r\n\r\nThe above might need tweaking with respect to accessing the appropriate assignee information.\r\n\r\n\r\n",
                "title": "github issues api and jq filter and grep"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1518497462,
                "creation_date": 1518497462,
                "answer_id": 48759662,
                "question_id": 48659631,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Shameless self-advertising. You can do this neatly with jf\r\n\r\n    pip install jf\r\n    curl &quot;https://api.github.com/repos/alhoo/jf/issues&quot; | jf &#39;filter(age(x.created_at) &lt; age(&quot;1 week&quot;))&#39;",
                "title": "github issues api and jq filter and grep"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1518497462,
        "creation_date": 1517994028,
        "last_edit_date": 1518060441,
        "question_id": 48659631,
        "body_markdown": "I&#39;m using GitHub enterprise API to get the list of issues in one of my repo. \r\nBut, I need to filter the output, so that I can get the list of issues which was created since last one week. \r\n\r\nBelow is where I&#39;ve reached so far &amp; it is working fine. I need help in filtering the issues created only since last week. \r\n\r\n\r\n    #!/bin/sh\r\n    tot_page=`curl -k -I https://&lt;my_pat&gt;:x-oauth-basic@github.developer.blah.com/api/v3/repos/droppin/remotedev/issues?state=all\\&amp;per_page=10 2&gt;/dev/null |  awk -F&#39;[&amp;=&lt;&gt;]&#39; &#39;{for(i=1;i&lt;=NF;i++) if($i ~ /^page$/) {kk=$(i+1)}} END{print kk}&#39;`;\r\n    echo &quot;$tot_page&quot;\r\n    for ((i=1;i&lt;=tot_page;i++))\r\n    do\r\n            curl -k https://&lt;my_pat&gt;:x-oauth-basic@github.developer.blah.com/api/v3/repos/droppin/remotedev/issues?state=all\\&amp;per_page=2\\&amp;page=$i 2&gt;/dev/null | \r\n            jq -r &#39;.[] | \r\n              &quot;\\(.number)&quot; + &quot;\\t\\t&quot; + &quot;\\(.assignee.login)&quot; \r\n               + &quot;\\t\\t\\t&quot; +  &quot;\\(.state)&quot; + &quot;\\t\\t&quot; \r\n               + &quot;\\(.created_at) | date(&quot;&#39;\r\n    done\r\n\r\n\r\nAppreciate your help on this. Thank you.\r\n\r\nSample JSON output as requested.\r\n\r\n    [\r\n          {\r\n        &quot;url&quot;: &quot;https://api.github.com/repos/stedolan/jq/issues/1558&quot;,\r\n        &quot;repository_url&quot;: &quot;https://api.github.com/repos/stedolan/jq&quot;,\r\n        &quot;labels_url&quot;: &quot;https://api.github.com/repos/stedolan/jq/issues/1558/labels{/name}&quot;,\r\n        &quot;comments_url&quot;: &quot;https://api.github.com/repos/stedolan/jq/issues/1558/comments&quot;,\r\n        &quot;events_url&quot;: &quot;https://api.github.com/repos/stedolan/jq/issues/1558/events&quot;,\r\n        &quot;html_url&quot;: &quot;https://github.com/stedolan/jq/pull/1558&quot;,\r\n        &quot;id&quot;: 282346710,\r\n        &quot;number&quot;: 1558,\r\n        &quot;title&quot;: &quot;Fix a try-catch example&quot;,\r\n        &quot;user&quot;: {\r\n          &quot;login&quot;: &quot;zogwarg&quot;,\r\n          &quot;id&quot;: 6682272,\r\n          &quot;avatar_url&quot;: &quot;https://avatars3.githubusercontent.com/u/6682272?v=4&quot;,\r\n          &quot;gravatar_id&quot;: &quot;&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/users/zogwarg&quot;,\r\n          &quot;html_url&quot;: &quot;https://github.com/zogwarg&quot;,\r\n          &quot;followers_url&quot;: &quot;https://api.github.com/users/zogwarg/followers&quot;,\r\n          &quot;following_url&quot;: &quot;https://api.github.com/users/zogwarg/following{/other_user}&quot;,\r\n          &quot;gists_url&quot;: &quot;https://api.github.com/users/zogwarg/gists{/gist_id}&quot;,\r\n          &quot;starred_url&quot;: &quot;https://api.github.com/users/zogwarg/starred{/owner}{/repo}&quot;,\r\n          &quot;subscriptions_url&quot;: &quot;https://api.github.com/users/zogwarg/subscriptions&quot;,\r\n          &quot;organizations_url&quot;: &quot;https://api.github.com/users/zogwarg/orgs&quot;,\r\n          &quot;repos_url&quot;: &quot;https://api.github.com/users/zogwarg/repos&quot;,\r\n          &quot;events_url&quot;: &quot;https://api.github.com/users/zogwarg/events{/privacy}&quot;,\r\n          &quot;received_events_url&quot;: &quot;https://api.github.com/users/zogwarg/received_events&quot;,\r\n          &quot;type&quot;: &quot;User&quot;,\r\n          &quot;site_admin&quot;: false\r\n        },\r\n        &quot;labels&quot;: [\r\n    \r\n        ],\r\n        &quot;state&quot;: &quot;open&quot;,\r\n        &quot;locked&quot;: false,\r\n        &quot;assignee&quot;: null,\r\n        &quot;assignees&quot;: [\r\n    \r\n        ],\r\n        &quot;milestone&quot;: null,\r\n        &quot;comments&quot;: 0,\r\n        &quot;created_at&quot;: &quot;2017-12-15T07:56:31Z&quot;,\r\n        &quot;updated_at&quot;: &quot;2017-12-15T07:56:31Z&quot;,\r\n        &quot;closed_at&quot;: null,\r\n        &quot;author_association&quot;: &quot;NONE&quot;,\r\n        &quot;pull_request&quot;: {\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/stedolan/jq/pulls/1558&quot;,\r\n          &quot;html_url&quot;: &quot;https://github.com/stedolan/jq/pull/1558&quot;,\r\n          &quot;diff_url&quot;: &quot;https://github.com/stedolan/jq/pull/1558.diff&quot;,\r\n          &quot;patch_url&quot;: &quot;https://github.com/stedolan/jq/pull/1558.patch&quot;\r\n        },\r\n        &quot;body&quot;: &quot;Fixing a bad syntax in a try-catch example\\r\\n\\r\\nIt was probably based on the inputs builtin definition,\\r\\nThe if statement was messed up and the semi-colon actually belongs to the function definition.&quot;\r\n      },\r\n      {\r\n        &quot;url&quot;: &quot;https://api.github.com/repos/stedolan/jq/issues/1557&quot;,\r\n        &quot;repository_url&quot;: &quot;https://api.github.com/repos/stedolan/jq&quot;,\r\n        &quot;labels_url&quot;: &quot;https://api.github.com/repos/stedolan/jq/issues/1557/labels{/name}&quot;,\r\n        &quot;comments_url&quot;: &quot;https://api.github.com/repos/stedolan/jq/issues/1557/comments&quot;,\r\n        &quot;events_url&quot;: &quot;https://api.github.com/repos/stedolan/jq/issues/1557/events&quot;,\r\n        &quot;html_url&quot;: &quot;https://github.com/stedolan/jq/issues/1557&quot;,\r\n        &quot;id&quot;: 282289185,\r\n        &quot;number&quot;: 1557,\r\n        &quot;title&quot;: &quot;Compiling for tvOS&quot;,\r\n        &quot;user&quot;: {\r\n          &quot;login&quot;: &quot;larryaasen&quot;,\r\n          &quot;id&quot;: 325973,\r\n          &quot;avatar_url&quot;: &quot;https://avatars1.githubusercontent.com/u/325973?v=4&quot;,\r\n          &quot;gravatar_id&quot;: &quot;&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/users/larryaasen&quot;,\r\n          &quot;html_url&quot;: &quot;https://github.com/larryaasen&quot;,\r\n          &quot;followers_url&quot;: &quot;https://api.github.com/users/larryaasen/followers&quot;,\r\n          &quot;following_url&quot;: &quot;https://api.github.com/users/larryaasen/following{/other_user}&quot;,\r\n          &quot;gists_url&quot;: &quot;https://api.github.com/users/larryaasen/gists{/gist_id}&quot;,\r\n          &quot;starred_url&quot;: &quot;https://api.github.com/users/larryaasen/starred{/owner}{/repo}&quot;,\r\n          &quot;subscriptions_url&quot;: &quot;https://api.github.com/users/larryaasen/subscriptions&quot;,\r\n          &quot;organizations_url&quot;: &quot;https://api.github.com/users/larryaasen/orgs&quot;,\r\n          &quot;repos_url&quot;: &quot;https://api.github.com/users/larryaasen/repos&quot;,\r\n          &quot;events_url&quot;: &quot;https://api.github.com/users/larryaasen/events{/privacy}&quot;,\r\n          &quot;received_events_url&quot;: &quot;https://api.github.com/users/larryaasen/received_events&quot;,\r\n          &quot;type&quot;: &quot;User&quot;,\r\n          &quot;site_admin&quot;: false\r\n        },\r\n        &quot;labels&quot;: [\r\n    \r\n        ],\r\n        &quot;state&quot;: &quot;open&quot;,\r\n        &quot;locked&quot;: false,\r\n        &quot;assignee&quot;: null,\r\n        &quot;assignees&quot;: [\r\n    \r\n        ],\r\n        &quot;milestone&quot;: null,\r\n        &quot;comments&quot;: 0,\r\n        &quot;created_at&quot;: &quot;2017-12-15T01:05:47Z&quot;,\r\n        &quot;updated_at&quot;: &quot;2017-12-15T01:05:47Z&quot;,\r\n        &quot;closed_at&quot;: null,\r\n        &quot;author_association&quot;: &quot;CONTRIBUTOR&quot;,\r\n        &quot;body&quot;: &quot;I attempted to update the compile-ios.sh file for tvOS to build the library for use in an Apple TV app. I am not able to get it to link. Has anyone been able to compile the library for tvOS?\\r\\n\\r\\nHere is the error message:\\r\\n/opt/local/bin/ranlib: object: .libs/libonig.a(regerror.o) malformed object (unknown load command 1)\\r\\n\\r\\nAttached the script file:\\r\\n[compile-tvos.sh.zip](https://github.com/stedolan/jq/files/1561265/compile-tvos.sh.zip)\\r\\n&quot;\r\n      }\r\n    ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48659631/github-issues-api-and-jq-filter-and-grep",
        "title": "github issues api and jq filter and grep"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1518017875,
                "last_edit_date": 1518017875,
                "creation_date": 1518015284,
                "answer_id": 48666796,
                "question_id": 48666137,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq -r &#39;.attributes |= map(select(.name == &quot;TargetNode&quot;)) \r\n           | if (.attributes | length != 0) then .targetNode = .attributes[0].value else . end \r\n           | if (.userId == &quot;0&quot;) then del(.userId) else . end \r\n           | if (.groupId == &quot;0&quot;) then del(.groupId) else . end \r\n           | del(.attributes, .xconns) | to_entries \r\n           | map(&quot;\\(.key | ascii_upcase):\\(.value)&quot;) | @tsv&#39; file.json\r\n\r\nIf an object with `&quot;name&quot;: &quot;TargetNode&quot;` pair not exists - `TARGETNODE` won&#39;t be added into resulting structure\r\n\r\nThe output:\r\n\r\n    ID:1\tNAME:profile1\tGROUPID:3\tTARGETNODE:system1\r\n    ID:2\tNAME:profile2\tUSERID:7\tTARGETNODE:system2",
                "title": "json - query with conditions"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1518165475,
        "creation_date": 1518013246,
        "last_edit_date": 1518165475,
        "question_id": 48666137,
        "body_markdown": "I have following json:\r\n\r\n    {\r\n      &quot;id&quot;: &quot;1&quot;,\r\n      &quot;name&quot;: &quot;profile1&quot;,\r\n      &quot;userId&quot;: &quot;0&quot;,\r\n      &quot;groupId&quot;: &quot;3&quot;,\r\n      &quot;attributes&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;104&quot;,\r\n          &quot;name&quot;: &quot;Enable&quot;,\r\n          &quot;value&quot;: &quot;1&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;105&quot;,\r\n          &quot;name&quot;: &quot;TargetNode&quot;,\r\n          &quot;value&quot;: &quot;system1&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;106&quot;,\r\n          &quot;name&quot;: &quot;Timeout&quot;,\r\n          &quot;value&quot;: &quot;30&quot;\r\n        }\r\n      ],\r\n      &quot;xconns&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;1&quot;,\r\n          &quot;locked&quot;: false,\r\n          &quot;attributeList&quot;: [\r\n            {\r\n              &quot;id&quot;: &quot;101&quot;,\r\n              &quot;name&quot;: &quot;Lgrp&quot;,\r\n              &quot;value&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: &quot;102&quot;,\r\n              &quot;name&quot;: &quot;IsRem&quot;,\r\n              &quot;value&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: &quot;103&quot;,\r\n              &quot;name&quot;: &quot;Media&quot;,\r\n              &quot;value&quot;: &quot;1&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;1&quot;,\r\n          &quot;locked&quot;: false,\r\n          &quot;attributeList&quot;: [\r\n            {\r\n              &quot;id&quot;: &quot;101&quot;,\r\n              &quot;name&quot;: &quot;Lgrp&quot;,\r\n              &quot;value&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: &quot;102&quot;,\r\n              &quot;name&quot;: &quot;IsRem&quot;,\r\n              &quot;value&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: &quot;103&quot;,\r\n              &quot;name&quot;: &quot;Media&quot;,\r\n              &quot;value&quot;: &quot;1&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;1&quot;,\r\n          &quot;locked&quot;: false,\r\n          &quot;attributeList&quot;: [\r\n            {\r\n              &quot;id&quot;: &quot;101&quot;,\r\n              &quot;name&quot;: &quot;Lgrp&quot;,\r\n              &quot;value&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: &quot;102&quot;,\r\n              &quot;name&quot;: &quot;IsRem&quot;,\r\n              &quot;value&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: &quot;103&quot;,\r\n              &quot;name&quot;: &quot;Media&quot;,\r\n              &quot;value&quot;: &quot;1&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;2&quot;,\r\n      &quot;name&quot;: &quot;profile2&quot;,\r\n      &quot;userId&quot;: &quot;7&quot;,\r\n      &quot;groupId&quot;: &quot;0&quot;,\r\n      &quot;attributes&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;104&quot;,\r\n          &quot;name&quot;: &quot;Enable&quot;,\r\n          &quot;value&quot;: &quot;1&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;105&quot;,\r\n          &quot;name&quot;: &quot;TargetNode&quot;,\r\n          &quot;value&quot;: &quot;system2&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;106&quot;,\r\n          &quot;name&quot;: &quot;Timeout&quot;,\r\n          &quot;value&quot;: &quot;30&quot;\r\n        }\r\n      ],\r\n      &quot;xconns&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;2&quot;,\r\n          &quot;locked&quot;: false,\r\n          &quot;attributeList&quot;: [\r\n            {\r\n              &quot;id&quot;: &quot;101&quot;,\r\n              &quot;name&quot;: &quot;Lgrp&quot;,\r\n              &quot;value&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: &quot;102&quot;,\r\n              &quot;name&quot;: &quot;IsRem&quot;,\r\n              &quot;value&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: &quot;103&quot;,\r\n              &quot;name&quot;: &quot;Media&quot;,\r\n              &quot;value&quot;: &quot;1&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;2&quot;,\r\n          &quot;locked&quot;: false,\r\n          &quot;attributeList&quot;: [\r\n            {\r\n              &quot;id&quot;: &quot;101&quot;,\r\n              &quot;name&quot;: &quot;Lgrp&quot;,\r\n              &quot;value&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: &quot;102&quot;,\r\n              &quot;name&quot;: &quot;IsRem&quot;,\r\n              &quot;value&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: &quot;103&quot;,\r\n              &quot;name&quot;: &quot;Media&quot;,\r\n              &quot;value&quot;: &quot;1&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;2&quot;,\r\n          &quot;locked&quot;: false,\r\n          &quot;attributeList&quot;: [\r\n            {\r\n              &quot;id&quot;: &quot;101&quot;,\r\n              &quot;name&quot;: &quot;Lgrp&quot;,\r\n              &quot;value&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: &quot;102&quot;,\r\n              &quot;name&quot;: &quot;IsRem&quot;,\r\n              &quot;value&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: &quot;103&quot;,\r\n              &quot;name&quot;: &quot;Media&quot;,\r\n              &quot;value&quot;: &quot;1&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nI can filter following:\r\n\r\n    $ jq -r &#39;select([.attributes[] | .name == &quot;TargetNode&quot; ] | any ) | [{userId, groupId, id, name}] | .[] | if (.userId == &quot;0&quot;) then del(.userId) else . end | if (.groupId == &quot;0&quot;) then del(.groupId) else . end | to_entries | map(&quot;\\(.key | ascii_upcase):\\(.value)&quot;) | @tsv&#39; file.json\r\n    GROUPID:3       ID:1    NAME:profile1\r\n    USERID:7        ID:2    NAME:profile2\r\n\r\n\r\nI need to add also value of TargetNode:\r\n\r\n    GROUPID:3       ID:1    NAME:profile1    TARGETNODE:system1\r\n    USERID:7        ID:2    NAME:profile2    TARGETNODE:system2\r\n\r\n\r\nis there a way to include it in \r\n[{userId, groupId, id, name, TargetNode}] \r\nto get the value of TargetNode and not null?\r\n\r\nGROUPID:3       ID:1    NAME:profile1   TARGETNODE:null\r\n\r\nUSERID:7        ID:2    NAME:profile2   TARGETNODE:null\r\n\r\n\r\nUpdate:\r\nthe solution provided by RomanPerekhrest is nearly ok, but there is one issue because the json file in real is much bigger, there are more attrobutes in &quot;main secttion&quot;, for example:\r\n\r\n    {\r\n      &quot;id&quot;: &quot;1&quot;,\r\n      &quot;name&quot;: &quot;profile1&quot;,\r\n      &quot;userId&quot;: &quot;0&quot;,\r\n      &quot;groupId&quot;: &quot;3&quot;,\r\n      &quot;attrib101&quot;: &quot;A&quot;,\r\n      &quot;attrib102&quot;: &quot;B&quot;,\r\n      &quot;attributes&quot;: [\r\n    ...\r\n    ...\r\n\r\nit is cousing that RomanPerekhrest&#39;s jq filter returns too much...\r\nhow to rid of them too?\r\n\r\n    ID:1    NAME:profile1   GROUPID:3   ATTRIB101:A     ATTRIB102:B TARGETNODE:system1\r\n    ID:2    NAME:profile2   USERID:7    ATTRIB101:C     ATTRIB102:D TARGETNODE:system2",
        "link": "https://stackoverflow.com/questions/48666137/json-query-with-conditions",
        "title": "json - query with conditions"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "aws-cli",
            "tee"
        ],
        "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": 1518084291,
                "post_id": 48682276,
                "comment_id": 84362445,
                "content_license": "CC BY-SA 3.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": 0,
                "creation_date": 1518084412,
                "post_id": 48682276,
                "comment_id": 84362535,
                "content_license": "CC BY-SA 3.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": 1518084417,
                "post_id": 48682276,
                "comment_id": 84362539,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1178096,
                    "reputation": 6502,
                    "user_id": 1153600,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://i.sstatic.net/MYULx.jpg?s=256",
                    "display_name": "Gismo Ranas",
                    "link": "https://stackoverflow.com/users/1153600/gismo-ranas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1518084537,
                "post_id": 48682276,
                "comment_id": 84362634,
                "content_license": "CC BY-SA 3.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": 1518098517,
                "post_id": 48682276,
                "comment_id": 84372298,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1178096,
                    "reputation": 6502,
                    "user_id": 1153600,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://i.sstatic.net/MYULx.jpg?s=256",
                    "display_name": "Gismo Ranas",
                    "link": "https://stackoverflow.com/users/1153600/gismo-ranas"
                },
                "reply_to_user": {
                    "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": 1518099523,
                "post_id": 48682276,
                "comment_id": 84373044,
                "content_license": "CC BY-SA 3.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": 1518099876,
                "post_id": 48682276,
                "comment_id": 84373283,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1178096,
                    "reputation": 6502,
                    "user_id": 1153600,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://i.sstatic.net/MYULx.jpg?s=256",
                    "display_name": "Gismo Ranas",
                    "link": "https://stackoverflow.com/users/1153600/gismo-ranas"
                },
                "reply_to_user": {
                    "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": 1518100198,
                "post_id": 48682276,
                "comment_id": 84373473,
                "content_license": "CC BY-SA 3.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": 1518101911,
                "post_id": 48682276,
                "comment_id": 84374735,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1178096,
                    "reputation": 6502,
                    "user_id": 1153600,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://i.sstatic.net/MYULx.jpg?s=256",
                    "display_name": "Gismo Ranas",
                    "link": "https://stackoverflow.com/users/1153600/gismo-ranas"
                },
                "reply_to_user": {
                    "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": 1518108809,
                "post_id": 48682276,
                "comment_id": 84379610,
                "content_license": "CC BY-SA 3.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": 1518109015,
                "post_id": 48682276,
                "comment_id": 84379778,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1178096,
                    "reputation": 6502,
                    "user_id": 1153600,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://i.sstatic.net/MYULx.jpg?s=256",
                    "display_name": "Gismo Ranas",
                    "link": "https://stackoverflow.com/users/1153600/gismo-ranas"
                },
                "reply_to_user": {
                    "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": 1518188553,
                "post_id": 48682276,
                "comment_id": 84415955,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1518085089,
                "creation_date": 1518085089,
                "answer_id": 48683017,
                "question_id": 48682276,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You might consider it a bit of trick, but you can use [`tee`](http://man7.org/linux/man-pages/man1/tee.1.html) to pipe all the output to stderr and fetch the one line you want for your variable with `head`:\r\n\r\n    var=&quot;$(command | tee /dev/stderr | head -n 1)&quot;\r\n\r\nOr you can solve this with a bit of scripting:\r\n\r\n    first=true\r\n    while read -r line; do\r\n        if $first; then\r\n            first=false\r\n            var=&quot;$line&quot;\r\n        fi\r\n        echo &quot;$line&quot;\r\n    done &lt; &lt;(command)",
                "title": "Bash - Pipe first line into variable and display the rest without using a temp file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1518086032,
                "last_edit_date": 1518086032,
                "creation_date": 1518085404,
                "answer_id": 48683115,
                "question_id": 48682276,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you are interested in storing the contents to variables, use `mapfile` or `read` on older `bash` versions. \r\n\r\nJust using `read` to get the first line do. I&#39;ve added `-r` flag to `jq` print output without quotes\r\n\r\n    read -r token &lt; &lt;(aws logs get-log-events --log-group-name &quot;$logGroup&quot; --log-stream-name &quot;$logStreamName&quot; --limit &quot;$logSize&quot; | jq -r &#39;{message:.nextForwardToken}, .events[] | .message&#39;)\r\n    printf &#39;%s\\n&#39; &quot;$token&quot;\r\n\r\nOr using `mapfile`\r\n\r\n    mapfile -t output &lt; &lt;(aws logs get-log-events --log-group-name &quot;$logGroup&quot; --log-stream-name &quot;$logStreamName&quot; --limit &quot;$logSize&quot; | jq -r &#39;{message:.nextForwardToken}, .events[] | .message&#39;)\r\n\r\nand loop through the array. The first element will always contain the token-id you want.\r\n\r\n    printf &#39;%s\\n&#39; &quot;${output[0]}&quot;\r\n\r\nRest of the elements can be iterated over,\r\n\r\n    for ((i=1; i&lt;${#output[@]}; i++)); do\r\n        printf &#39;%s\\n&#39; &quot;${output[i]}&quot;\r\n    done",
                "title": "Bash - Pipe first line into variable and display the rest without using a temp file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1518086416,
                "last_edit_date": 1518086416,
                "creation_date": 1518086032,
                "answer_id": 48683357,
                "question_id": 48682276,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Straightforwardly:\r\n\r\n    aws logs get-log-events --log-group-name &quot;$logGroup&quot; \\\r\n    --log-stream-name &quot;$logStreamName&quot; --limit &quot;$logSize&quot; &gt; /tmp/log_data\r\n\r\n-- set `nextForwardToken` variable:\r\n\r\n    nextForwardToken=$(jq -r &#39;.nextForwardToken&#39; /tmp/log_data)\r\n    echo $nextForwardToken \r\n    f/33854369274157730709515363051725446974398055862891970561\r\n\r\n-- print all `message` items:\r\n\r\n`jq -r &#39;.events[].message&#39; /tmp/log_data`\r\n\r\n    08.02.2018 09:17:40.955 [SimpleAsyncTaskExecutor-138] INFO  o.s.b.c.l.support.SimpleJobLauncher - Job: [SimpleJob: [name=price-update]] launched with the following parameters: [{time=1518081460875, sku=N-W7ZLH9U737B|N-XIBH22XQE87|N-3EXIRFNYNW0|N-U19C031D640|N-6TQ1847FQE6|N-NF0XCNG0029|N-UJ3H0OZROCQ|N-W2JKJD4S6YP|N-VEMA4QVV3X1|N-F40J6P2VM01|N-VIT7YEAVYL2|N-PKLKX1PAUXC|N-VPAK74C75DP|N-C5BLYC5HQRI|N-GEIGFIBG6X2|N-R0V88ZYS10W|N-GQAF3DK7Y5Z|N-9EZ4FDDSQLC|N-U15C031D668|N-B8ELYSSFAVH}]    \r\n    08.02.2018 09:17:41.095 [SimpleAsyncTaskExecutor-138] INFO  o.s.batch.core.job.SimpleStepHandler - Executing step: [index salesprices]\r\n    08.02.2018 09:33:41.586 [upriceUpdateTaskExecutor-3] DEBUG e.u.d.a.j.d.b.StoredMasterDataReader - Reading page 1621\r\n\r\n",
                "title": "Bash - Pipe first line into variable and display the rest without using a temp file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1518120981,
                "last_edit_date": 1518120981,
                "creation_date": 1518119210,
                "answer_id": 48693605,
                "question_id": 48682276,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I believe the following meets the stated requirements, assuming a bash-like environment:\r\n\r\n    x=$(aws ... |\r\n        tee &gt;(jq -r &#39;.events[] | .message&#39; &gt;&amp;2) |\r\n        jq .nextForwardToken) 2&gt;&amp;1\r\n\r\nThis makes the item of interest available as the shell variable $x.\r\n\r\nNotice that the string manipulation using `sed` can be avoided by using the `-r` command-line option of jq.\r\n\r\n### Calling jq just once\r\n\r\n    x=$(aws ... |\r\n     jq -r &#39;.nextForwardToken, (.events[] | .message)&#39; |\r\n     tee &gt;(tail -n +2 &gt;&amp;2) |\r\n     head -n 1) 2&gt;&amp;1\r\n    \r\n    echo &quot;x=$x&quot;\r\n",
                "title": "Bash - Pipe first line into variable and display the rest without using a temp file"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1518329131,
        "creation_date": 1518083200,
        "last_edit_date": 1518329131,
        "question_id": 48682276,
        "body_markdown": "I receive some json that I process until it becomes just text lines. In the first line there&#39;s a value that I would like to keep in a variable and all the rest after the first line should be displayed with less or other utils.\r\n\r\nCan I do this without using a temporary file?\r\n\r\nThe context is this: \r\n\r\n    aws logs get-log-events --log-group-name &quot;$logGroup&quot; --log-stream-name &quot;$logStreamName&quot; --limit &quot;$logSize&quot; |\r\n     jq &#39;{message:.nextForwardToken}, .events[] | .message&#39; |\r\n     sed &#39;s/^&quot;//g&#39; | sed &#39;s/&quot;$//g&#39;\r\n\r\nIn the first line there&#39;s the nextForwardToken that I want to put in the variable and all the rest is log messages.\r\n\r\nThe json looks like this:\r\n\r\n    {\r\n    &quot;events&quot;: [\r\n        {\r\n            &quot;timestamp&quot;: 1518081460955,\r\n            &quot;ingestionTime&quot;: 1518081462998,\r\n            &quot;message&quot;: &quot;08.02.2018 09:17:40.955 [SimpleAsyncTaskExecutor-138] INFO  o.s.b.c.l.support.SimpleJobLauncher - Job: [SimpleJob: [name=price-update]] launched with the following parameters: [{time=1518081460875, sku=N-W7ZLH9U737B|N-XIBH22XQE87|N-3EXIRFNYNW0|N-U19C031D640|N-6TQ1847FQE6|N-NF0XCNG0029|N-UJ3H0OZROCQ|N-W2JKJD4S6YP|N-VEMA4QVV3X1|N-F40J6P2VM01|N-VIT7YEAVYL2|N-PKLKX1PAUXC|N-VPAK74C75DP|N-C5BLYC5HQRI|N-GEIGFIBG6X2|N-R0V88ZYS10W|N-GQAF3DK7Y5Z|N-9EZ4FDDSQLC|N-U15C031D668|N-B8ELYSSFAVH}]&quot;\r\n        },\r\n        {\r\n            &quot;timestamp&quot;: 1518081461095,\r\n            &quot;ingestionTime&quot;: 1518081462998,\r\n            &quot;message&quot;: &quot;08.02.2018 09:17:41.095 [SimpleAsyncTaskExecutor-138] INFO  o.s.batch.core.job.SimpleStepHandler - Executing step: [index salesprices]&quot;\r\n        },\r\n        {\r\n            &quot;timestamp&quot;: 1518082421586,\r\n            &quot;ingestionTime&quot;: 1518082423001,\r\n            &quot;message&quot;: &quot;08.02.2018 09:33:41.586 [upriceUpdateTaskExecutor-3] DEBUG e.u.d.a.j.d.b.StoredMasterDataReader - Reading page 1621&quot;\r\n        }\r\n    ],\r\n    &quot;nextBackwardToken&quot;: &quot;b/33854347851370569899844322814554152895248902123886870536&quot;,\r\n    &quot;nextForwardToken&quot;: &quot;f/33854369274157730709515363051725446974398055862891970561&quot;\r\n    }\r\n\r\nI need to put in a variable this:\r\n\r\n    f/33854369274157730709515363051725446974398055862891970561\r\n\r\nand display (or put in an other variable) the messages:\r\n\r\n    08.02.2018 09:17:40.955 [SimpleAsyncTaskExecutor-138] INFO  o.s.b.c.l.support.SimpleJobLauncher - Job: [SimpleJob: [name=price-update]] launched with the following parameters: [{time=1518081460875, sku=N-W7ZLH9U737B|N-XIBH22XQE87|N-3EXIRFNYNW0|N-U19C031D640|N-6TQ1847FQE6|N-NF0XCNG0029|N-UJ3H0OZROCQ|N-W2JKJD4S6YP|N-VEMA4QVV3X1|N-F40J6P2VM01|N-VIT7YEAVYL2|N-PKLKX1PAUXC|N-VPAK74C75DP|N-C5BLYC5HQRI|N-GEIGFIBG6X2|N-R0V88ZYS10W|N-GQAF3DK7Y5Z|N-9EZ4FDDSQLC|N-U15C031D668|N-B8ELYSSFAVH}]\r\n    08.02.2018 09:17:41.095 [SimpleAsyncTaskExecutor-138] INFO  o.s.batch.core.job.SimpleStepHandler - Executing step: [index salesprices]\r\n    08.02.2018 09:33:41.586 [upriceUpdateTaskExecutor-3] DEBUG e.u.d.a.j.d.b.StoredMasterDataReader - Reading page 1621\r\n\r\n\r\nThanks in advance for your help.",
        "link": "https://stackoverflow.com/questions/48682276/bash-pipe-first-line-into-variable-and-display-the-rest-without-using-a-temp-f",
        "title": "Bash - Pipe first line into variable and display the rest without using a temp file"
    },
    {
        "tags": [
            "json",
            "bash",
            "loops",
            "jq",
            "artifactory-query-lang"
        ],
        "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": 1518109878,
                "post_id": 48690913,
                "comment_id": 84380347,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7661276,
                    "reputation": 817,
                    "user_id": 5806501,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://graph.facebook.com/10156574880005106/picture?type=large",
                    "display_name": "Ebrahim Moshaya",
                    "link": "https://stackoverflow.com/users/5806501/ebrahim-moshaya"
                },
                "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": 1518110001,
                "post_id": 48690913,
                "comment_id": 84380438,
                "content_license": "CC BY-SA 3.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": 1518110024,
                "post_id": 48690913,
                "comment_id": 84380459,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7661276,
                    "reputation": 817,
                    "user_id": 5806501,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://graph.facebook.com/10156574880005106/picture?type=large",
                    "display_name": "Ebrahim Moshaya",
                    "link": "https://stackoverflow.com/users/5806501/ebrahim-moshaya"
                },
                "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": 1518110136,
                "post_id": 48690913,
                "comment_id": 84380541,
                "content_license": "CC BY-SA 3.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": 1518110222,
                "post_id": 48690913,
                "comment_id": 84380602,
                "content_license": "CC BY-SA 3.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": 1518110976,
                "post_id": 48690913,
                "comment_id": 84381044,
                "content_license": "CC BY-SA 3.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": 1518111710,
                "post_id": 48690913,
                "comment_id": 84381458,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1518110749,
                "creation_date": 1518110749,
                "answer_id": 48691358,
                "question_id": 48690913,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    #!/usr/bin/env bash\r\n    \r\n    template=&#39;{\r\n      &quot;files&quot;: [\r\n        {\r\n          &quot;aql&quot;: {\r\n            &quot;items.find&quot;: {\r\n              &quot;repo&quot;: &quot;release-repo&quot;,\r\n              &quot;modified&quot;: { &quot;$before&quot;: &quot;30d&quot; },\r\n              &quot;type&quot;: { &quot;$eq&quot;: &quot;folder&quot; },\r\n              &quot;$or&quot;: [],\r\n              &quot;depth&quot;: &quot;2&quot;\r\n            }\r\n          }\r\n        }\r\n      ]\r\n    }&#39;\r\n    \r\n    shas=(\r\n      &quot;a991fef6bb9e9759d513fd4b277fe3674b44e4f4&quot;\r\n      &quot;5a562d34bb1d4ab4264acc2c61327651218524ad&quot;\r\n      &quot;d4e296c35644743e58aed35d1afb87e34d6c8823&quot;\r\n    )\r\n    \r\n    jq -n \\\r\n            --argjson template &quot;$template&quot; \\\r\n            --arg shas_str &quot;${shas[*]}&quot; \\\r\n    &#39;\r\n    reduce ($shas_str | split(&quot; &quot;) | .[]) as $sha ($template;\r\n      .files[0].aql[&quot;items.find&quot;][&quot;$or&quot;] += [{\r\n        &quot;$and&quot;: [{&quot;name&quot;: {&quot;$nmatch&quot;: (&quot;*&quot; + $sha + &quot;*&quot;)}}]\r\n      }]\r\n    )\r\n    &#39;\r\n\r\n...emits as output:\r\n\r\n    {\r\n      &quot;files&quot;: [\r\n        {\r\n          &quot;aql&quot;: {\r\n            &quot;items.find&quot;: {\r\n              &quot;repo&quot;: &quot;release-repo&quot;,\r\n              &quot;modified&quot;: {\r\n                &quot;$before&quot;: &quot;30d&quot;\r\n              },\r\n              &quot;type&quot;: {\r\n                &quot;$eq&quot;: &quot;folder&quot;\r\n              },\r\n              &quot;$or&quot;: [\r\n                {\r\n                  &quot;$and&quot;: [\r\n                    {\r\n                      &quot;name&quot;: {\r\n                        &quot;$nmatch&quot;: &quot;*a991fef6bb9e9759d513fd4b277fe3674b44e4f4*&quot;\r\n                      }\r\n                    }\r\n                  ]\r\n                },\r\n                {\r\n                  &quot;$and&quot;: [\r\n                    {\r\n                      &quot;name&quot;: {\r\n                        &quot;$nmatch&quot;: &quot;*5a562d34bb1d4ab4264acc2c61327651218524ad*&quot;\r\n                      }\r\n                    }\r\n                  ]\r\n                },\r\n                {\r\n                  &quot;$and&quot;: [\r\n                    {\r\n                      &quot;name&quot;: {\r\n                        &quot;$nmatch&quot;: &quot;*d4e296c35644743e58aed35d1afb87e34d6c8823*&quot;\r\n                      }\r\n                    }\r\n                  ]\r\n                }\r\n              ],\r\n              &quot;depth&quot;: &quot;2&quot;\r\n            }\r\n          }\r\n        }\r\n      ]\r\n    }",
                "title": "Add to existing json file using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1518116745,
                "creation_date": 1518116745,
                "answer_id": 48693003,
                "question_id": 48690913,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a reduce-free solution. It makes some inessential assumptions -\r\n that the sha strings are presented as a stream of strings on STDIN, and that the Artifactory spec is in a file named spec.json.  Here is the jq program:\r\n\r\n\r\n    map( {&quot;$and&quot;: [ {name: { &quot;$nmatch&quot;: &quot;*\\(.)*&quot; }}]} ) as $x\r\n    | $spec[0] | (.files[0].aql.&quot;items.find&quot;.&quot;$or&quot; = $x)\r\n\r\n\r\nThe jq invocation might look like this:\r\n    \r\n    jq -s --slurpfile spec spec.json -f program.jq &lt;&lt;&lt; &quot;${shas[*]}&quot;\r\n",
                "title": "Add to existing json file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1518301887,
        "creation_date": 1518109225,
        "last_edit_date": 1518301887,
        "question_id": 48690913,
        "body_markdown": "I have an [Artifactory AQL][1] Spec file in JSON format. The spec file is as follows:\r\n\r\n    {\r\n      &quot;files&quot;: [\r\n        {\r\n          &quot;aql&quot;: {\r\n            &quot;items.find&quot;: {\r\n              &quot;repo&quot;: &quot;release-repo&quot;,\r\n              &quot;modified&quot;: { &quot;$before&quot;: &quot;30d&quot; },\r\n              &quot;type&quot;: { &quot;$eq&quot;: &quot;folder&quot; },\r\n              &quot;depth&quot;: &quot;2&quot;\r\n            }\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nlet&#39;s say I run a gitlab api query to acquire a list of SHAs that I want to iterate through and add to this json spec file.. The list of SHAs are assigned to a variable..\r\n\r\n    &quot;a991fef6bb9e9759d513fd4b277fe3674b44e4f4&quot;\r\n    &quot;5a562d34bb1d4ab4264acc2c61327651218524ad&quot;\r\n    &quot;d4e296c35644743e58aed35d1afb87e34d6c8823&quot;\r\n\r\nI would like to iterate through all these commit IDs in and add them one by one to the json so that they are in this format:\r\n\r\n    {\r\n      &quot;files&quot;: [\r\n        {\r\n          &quot;aql&quot;: {\r\n            &quot;items.find&quot;: {\r\n              &quot;repo&quot;: &quot;release-repo&quot;,\r\n              &quot;modified&quot;: { &quot;$before&quot;: &quot;30d&quot; },\r\n              &quot;type&quot;: { &quot;$eq&quot;: &quot;folder&quot; },\r\n              &quot;$or&quot;: [\r\n                {\r\n                  &quot;$and&quot;: [\r\n                    {\r\n                      &quot;name&quot;: {\r\n                        &quot;$nmatch&quot;: &quot;*a991fef6bb9e9759d513fd4b277fe3674b44e4f4*&quot;\r\n                      }\r\n                    }\r\n                  ]\r\n                },\r\n                {\r\n                  &quot;$and&quot;: [\r\n                    {\r\n                      &quot;name&quot;: {\r\n                        &quot;$nmatch&quot;: &quot;*5a562d34bb1d4ab4264acc2c61327651218524ad*&quot;\r\n                      }\r\n                    }\r\n                  ]\r\n                },\r\n                {\r\n                  &quot;$and&quot;: [\r\n                    {\r\n                      &quot;name&quot;: {\r\n                        &quot;$nmatch&quot;: &quot;*d4e296c35644743e58aed35d1afb87e34d6c8823*&quot;\r\n                      }\r\n                    }\r\n                  ]\r\n                }\r\n              ],\r\n              &quot;depth&quot;: &quot;2&quot;\r\n            }\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nThe list of SHAs returned from the gitlab api query will be different everything and that&#39;s why I&#39;d like this to be a dynamic entry or update every time. The number of returned SHAs will also be different... Could return 10 one day or it could return 50 on another day.\r\n\r\n  [1]: https://www.jfrog.com/confluence/display/RTF/Artifactory+Query+Language\r\n",
        "link": "https://stackoverflow.com/questions/48690913/add-to-existing-json-file-using-jq",
        "title": "Add to existing json file using jq"
    },
    {
        "tags": [
            "json",
            "elasticsearch",
            "jq",
            "jsonlines"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": -3,
                "last_activity_date": 1518197657,
                "creation_date": 1518197657,
                "answer_id": 48711233,
                "question_id": 48711199,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "figured this out:\r\n\r\n    cat test_array.json |jq &#39;.[]&#39;",
                "title": "Use jq to convert json array to jsonl format"
            },
            {
                "up_vote_count": 38,
                "is_accepted": false,
                "score": 38,
                "last_activity_date": 1518199119,
                "creation_date": 1518199119,
                "answer_id": 48711608,
                "question_id": 48711199,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The key is the -c command-line option, which produces JSONL:\r\n\r\n    jq -c &#39;.[]&#39; test_array.json\r\n\r\n",
                "title": "Use jq to convert json array to jsonl format"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 20,
        "last_activity_date": 1518205994,
        "creation_date": 1518197499,
        "last_edit_date": 1518205994,
        "question_id": 48711199,
        "body_markdown": "I have json like this:\r\n\r\n    [ {&quot;one&quot;: 1}, {&quot;two&quot;: 2}]\r\n\r\nand wish to convert it to this format:\r\n\r\n    {&quot;one&quot;: 1}\r\n    {&quot;two&quot;: 2}\r\n\r\nto facilitate indexing it into ElasticSearch. (latter is called &#39;jsonl&#39; format).  JQ is my tool of preference but I can&#39;t figure out how to do this.\r\nThanks\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48711199/use-jq-to-convert-json-array-to-jsonl-format",
        "title": "Use jq to convert json array to jsonl format"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 12232513,
                    "reputation": 3741,
                    "user_id": 8928024,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/91ed98174506dcff51fc238ff3de9771?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ZF007",
                    "link": "https://stackoverflow.com/users/8928024/zf007"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1518203660,
                "post_id": 48712545,
                "comment_id": 84424320,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "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": 1518205217,
                "post_id": 48712545,
                "comment_id": 84425048,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1647847,
                    "reputation": 1864,
                    "user_id": 2934184,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0194750ec0837d953c7beda6f9c57e15?s=256&d=identicon&r=PG",
                    "display_name": "Omar Alvarado",
                    "link": "https://stackoverflow.com/users/2934184/omar-alvarado"
                },
                "reply_to_user": {
                    "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": 1518205358,
                "post_id": 48712545,
                "comment_id": 84425106,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 82,
                "is_accepted": true,
                "score": 82,
                "last_activity_date": 1518204160,
                "creation_date": 1518204160,
                "answer_id": 48712751,
                "question_id": 48712545,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`jq` is fine with literal line breaks, so just add linefeeds anywhere without trying to escape them:\r\n\r\n    vpcExists=$(aws ec2 describe-vpcs --profile $profile |\r\n        jq -r --arg vpcId &quot;$vpcId&quot; &#39;\r\n       .[][] \r\n         | select(.VpcId == $vpcId)\r\n         | .[&quot;State&quot;]&#39; \r\n    )\r\n\r\n\r\nHere&#39;s a MCVE:\r\n\r\n    jq -r --arg vpcId &quot;someId&quot; &#39;\r\n       .[][] \r\n         | select(.VpcId == $vpcId)\r\n         | .[&quot;State&quot;]&#39;  &lt;&lt; &#39;EOF&#39;\r\n\r\n\r\n    { &quot;Vpcs&quot;: [ {\r\n                &quot;VpcId&quot;: &quot;someId&quot;,\r\n                &quot;InstanceTenancy&quot;: &quot;default&quot;,\r\n                &quot;State&quot;: &quot;available&quot;,\r\n                &quot;IsDefault&quot;: false\r\n            } ] }\r\n    EOF",
                "title": "Break jq query string into lines"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 47,
        "last_activity_date": 1518204160,
        "creation_date": 1518203289,
        "last_edit_date": 1518203413,
        "question_id": 48712545,
        "body_markdown": "How can i break jq string into lines, this is for long lines, when i put &quot;\\&quot; query breaks.\r\n\r\n    vpcExists=$(aws ec2 describe-vpcs --profile $profile | jq -r --arg vpcId &quot;$vpcId&quot; &#39;.[][] | \\\r\n     select(.VpcId == $vpcId) \\\r\n    | .[&quot;State&quot;]&#39; \\\r\n    )",
        "link": "https://stackoverflow.com/questions/48712545/break-jq-query-string-into-lines",
        "title": "Break jq query string into lines"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "max",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2425848,
                    "reputation": 2633,
                    "user_id": 9112450,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Ocfqi.gif?s=256",
                    "display_name": "sorak",
                    "link": "https://stackoverflow.com/users/9112450/sorak"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1518384651,
                "post_id": 48736632,
                "comment_id": 84472802,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11083511,
                    "reputation": 31,
                    "user_id": 8138040,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/10154740450372532/picture?type=large",
                    "display_name": "Justin Tasset",
                    "link": "https://stackoverflow.com/users/8138040/justin-tasset"
                },
                "reply_to_user": {
                    "account_id": 2425848,
                    "reputation": 2633,
                    "user_id": 9112450,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Ocfqi.gif?s=256",
                    "display_name": "sorak",
                    "link": "https://stackoverflow.com/users/9112450/sorak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1518386077,
                "post_id": 48736632,
                "comment_id": 84473263,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1518409421,
                "post_id": 48736632,
                "comment_id": 84478665,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1518459765,
                "last_edit_date": 1518459765,
                "creation_date": 1518389470,
                "answer_id": 48737339,
                "question_id": 48736632,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Under the assumption that your data structure is something like this:\r\n\r\n    $ cat test.json\r\n    {&quot;coins&quot; : { &quot;coin1&quot;: { &quot;id&quot;: 4,  &quot;profitability24&quot;: 3 },\r\n                 &quot;coin2&quot;: { &quot;id&quot;: 5, &quot;profitability24&quot;: 2 },\r\n                 &quot;coin3&quot;: { &quot;id&quot;: 6, &quot;profitability24&quot;: 1 } } }\r\n\r\nAnd you want to extract the max of &#39;profitability24, I would just filter out the dictionaries into a list, and then pipe that to `max_by` (did you read [the jq docs][1]?):\r\n\r\n    $ cat test.json | jq &#39;[.coins[]]|max_by(.profitability24)&#39;\r\n    {\r\n       &quot;id&quot;: 4,\r\n       &quot;profitability24&quot;: 3\r\n    }\r\n\r\n[1]: https://stedolan.github.io/jq/manual/\r\n\r\n",
                "title": "How to get the most profitable currency from a JSON?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1518392385,
                "creation_date": 1518392385,
                "answer_id": 48737635,
                "question_id": 48736632,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since you indicate that the item you want is &quot;always the first&quot;, you could simply write:\r\n\r\n    first(.coins[])\r\n\r\nIf you want to ensure you always select one of the maximal objects, you could write:\r\n\r\n    [.coins[]] | max_by(.profitability24)\r\n\r\n(For the sample data, these two approaches give different answers, as there are two maximal objects.)\r\n\r\nIf you want *all* maximal objects, then one approach would be to define and use `maximals_by(s; f)` as follows:\r\n\r\n    # Emit a stream of the maximal entities in the stream, s:\r\n    def maximals_by(s; f):\r\n      reduce s as $x ({v:null, a:[]}; \r\n        ($x|f) as $y\r\n        | if $y == .v then .a += [$x] elif $y &gt; .v then {v:$y, a: [$x]} else . end)\r\n      | .a[];\r\n    \r\n    \r\n    maximals_by(.coins[]; .profitability24)\r\n\r\nWith the given data, the last approach yields the two maximal items:\r\n\r\n    {\r\n      &quot;id&quot;: 15,\r\n      &quot;tag&quot;: &quot;NICEHASH&quot;,\r\n      &quot;algorithm&quot;: &quot;Ethash&quot;,\r\n      &quot;block_time&quot;: 1,\r\n      &quot;block_reward&quot;: 1,\r\n      &quot;block_reward24&quot;: 1,\r\n      &quot;last_block&quot;: 0,\r\n      &quot;difficulty&quot;: 1,\r\n      &quot;difficulty24&quot;: 1,\r\n      &quot;nethash&quot;: 5595177528830,\r\n      &quot;exchange_rate&quot;: 0.0084,\r\n      &quot;exchange_rate24&quot;: 0.0086,\r\n      &quot;exchange_rate_vol&quot;: 38.522578574534,\r\n      &quot;exchange_rate_curr&quot;: &quot;BTC&quot;,\r\n      &quot;market_cap&quot;: &quot;$0.00&quot;,\r\n      &quot;estimated_rewards&quot;: &quot;0.00071&quot;,\r\n      &quot;estimated_rewards24&quot;: &quot;0.00072&quot;,\r\n      &quot;btc_revenue&quot;: &quot;0.0007056&quot;,\r\n      &quot;btc_revenue24&quot;: &quot;0.0007224&quot;,\r\n      &quot;profitability&quot;: 95,\r\n      &quot;profitability24&quot;: 101,\r\n      &quot;lagging&quot;: false,\r\n      &quot;timestamp&quot;: 1518385271\r\n    }\r\n    {\r\n      &quot;id&quot;: 162,\r\n      &quot;tag&quot;: &quot;ETC&quot;,\r\n      &quot;algorithm&quot;: &quot;Ethash&quot;,\r\n      &quot;block_time&quot;: &quot;14.5606&quot;,\r\n      &quot;block_reward&quot;: 3.88,\r\n      &quot;block_reward24&quot;: 3.88000000000005,\r\n      &quot;last_block&quot;: 5372259,\r\n      &quot;difficulty&quot;: 119798042603096,\r\n      &quot;difficulty24&quot;: 118354683854950,\r\n      &quot;nethash&quot;: 8227548494093,\r\n      &quot;exchange_rate&quot;: 0.003034,\r\n      &quot;exchange_rate24&quot;: 0.00285318393234672,\r\n      &quot;exchange_rate_vol&quot;: 2318.70107084,\r\n      &quot;exchange_rate_curr&quot;: &quot;BTC&quot;,\r\n      &quot;market_cap&quot;: &quot;$2,525,050,483.01&quot;,\r\n      &quot;estimated_rewards&quot;: &quot;0.23506&quot;,\r\n      &quot;estimated_rewards24&quot;: &quot;0.23792&quot;,\r\n      &quot;btc_revenue&quot;: &quot;0.00071316&quot;,\r\n      &quot;btc_revenue24&quot;: &quot;0.00072186&quot;,\r\n      &quot;profitability&quot;: 96,\r\n      &quot;profitability24&quot;: 101,\r\n      &quot;lagging&quot;: false,\r\n      &quot;timestamp&quot;: 1518385186\r\n    }\r\n\r\n",
                "title": "How to get the most profitable currency from a JSON?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1523740689,
        "creation_date": 1518384365,
        "last_edit_date": 1523740689,
        "question_id": 48736632,
        "body_markdown": "I&#39;m trying to write a bash script that can adjust to the most profitable cryptocurrency to mine and change what is being mined on the fly.\r\n\r\nI have used `curl` to grab API information from &lt;http://whattomine.com/coins.json&gt; using `curl` script:\r\n\r\n    curl whattomine.com/coins.json -O | &gt; coins.json\r\n\r\nSample API:\r\n\r\n    {&quot;coins&quot;:{&quot;Nicehash-Ethash&quot;:{&quot;id&quot;:15,&quot;tag&quot;:&quot;NICEHASH&quot;,&quot;algorithm&quot;:&quot;Ethash&quot;,&quot;block_time&quot;:1,&quot;block_reward&quot;:1,&quot;block_reward24&quot;:1,&quot;last_block&quot;:0,&quot;difficulty&quot;:1,&quot;difficulty24&quot;:1,&quot;nethash&quot;:5595177528830,&quot;exchange_rate&quot;:0.0084,&quot;exchange_rate24&quot;:0.0086,&quot;exchange_rate_vol&quot;:38.522578574534,&quot;exchange_rate_curr&quot;:&quot;BTC&quot;,&quot;market_cap&quot;:&quot;$0.00&quot;,&quot;estimated_rewards&quot;:&quot;0.00071&quot;,&quot;estimated_rewards24&quot;:&quot;0.00072&quot;,&quot;btc_revenue&quot;:&quot;0.0007056&quot;,&quot;btc_revenue24&quot;:&quot;0.0007224&quot;,&quot;profitability&quot;:95,&quot;profitability24&quot;:101,&quot;lagging&quot;:false,&quot;timestamp&quot;:1518385271},&quot;EthereumClassic&quot;:{&quot;id&quot;:162,&quot;tag&quot;:&quot;ETC&quot;,&quot;algorithm&quot;:&quot;Ethash&quot;,&quot;block_time&quot;:&quot;14.5606&quot;,&quot;block_reward&quot;:3.88,&quot;block_reward24&quot;:3.88000000000005,&quot;last_block&quot;:5372259,&quot;difficulty&quot;:119798042603096.0,&quot;difficulty24&quot;:118354683854950.0,&quot;nethash&quot;:8227548494093,&quot;exchange_rate&quot;:0.003034,&quot;exchange_rate24&quot;:0.00285318393234672,&quot;exchange_rate_vol&quot;:2318.70107084,&quot;exchange_rate_curr&quot;:&quot;BTC&quot;,&quot;market_cap&quot;:&quot;$2,525,050,483.01&quot;,&quot;estimated_rewards&quot;:&quot;0.23506&quot;,&quot;estimated_rewards24&quot;:&quot;0.23792&quot;,&quot;btc_revenue&quot;:&quot;0.00071316&quot;,&quot;btc_revenue24&quot;:&quot;0.00072186&quot;,&quot;profitability&quot;:96,&quot;profitability24&quot;:101,&quot;lagging&quot;:false,&quot;timestamp&quot;:1518385186},&quot;Ethereum&quot;:{&quot;id&quot;:151,&quot;tag&quot;:&quot;ETH&quot;,&quot;algorithm&quot;:&quot;Ethash&quot;,&quot;block_time&quot;:&quot;14.529&quot;,&quot;block_reward&quot;:2.91,&quot;block_reward24&quot;:2.91000000000001,&quot;last_block&quot;:5073173,&quot;difficulty&quot;:2.86396845523669e+15,&quot;difficulty24&quot;:2.96145362923571e+15,&quot;nethash&quot;:197120824229932,&quot;exchange_rate&quot;:0.100691,&quot;exchange_rate24&quot;:0.100200274841438,&quot;exchange_rate_vol&quot;:12443.48347244,&quot;exchange_rate_curr&quot;:&quot;BTC&quot;,&quot;market_cap&quot;:&quot;$81,928,528,426.15&quot;,&quot;estimated_rewards&quot;:&quot;0.00737&quot;,&quot;estimated_rewards24&quot;:&quot;0.00713&quot;,&quot;btc_revenue&quot;:&quot;0.00074252&quot;,&quot;btc_revenue24&quot;:&quot;0.00071808&quot;,&quot;profitability&quot;:100,&quot;profitability24&quot;:100,&quot;lagging&quot;:false,&quot;timestamp&quot;:1518385171},&quot;Expanse&quot;:{&quot;id&quot;:154,&quot;tag&quot;:&quot;EXP&quot;,&quot;algorithm&quot;:&quot;Ethash&quot;,&quot;block_time&quot;:&quot;45.0&quot;,&quot;block_reward&quot;:4.0,&quot;block_reward24&quot;:4.0,&quot;last_block&quot;:975425,&quot;difficulty&quot;:13101309242779.0,&quot;difficulty24&quot;:14838722424377.6,&quot;nethash&quot;:291140205395,&quot;exchange_rate&quot;:0.00033176,&quot;exchange_rate24&quot;:0.000334064524312897,&quot;exchange_rate_vol&quot;:10.94411548,&quot;exchange_rate_curr&quot;:&quot;BTC&quot;,&quot;market_cap&quot;:&quot;$21,877,350.59&quot;,&quot;estimated_rewards&quot;:&quot;2.2152&quot;,&quot;estimated_rewards24&quot;:&quot;1.9559&quot;,&quot;btc_revenue&quot;:&quot;0.00073491&quot;,&quot;btc_revenue24&quot;:&quot;0.00064889&quot;,&quot;profitability&quot;:99,&quot;profitability24&quot;:90,&quot;lagging&quot;:false,&quot;timestamp&quot;:1518383559},&quot;Pirl&quot;:{&quot;id&quot;:211,&quot;tag&quot;:&quot;PIRL&quot;,&quot;algorithm&quot;:&quot;Ethash&quot;,&quot;block_time&quot;:&quot;14.0&quot;,&quot;block_reward&quot;:10.0,&quot;block_reward24&quot;:10.0,&quot;last_block&quot;:825434,&quot;difficulty&quot;:16734197347723.0,&quot;difficulty24&quot;:16762811072321.5,&quot;nethash&quot;:1195299810551,&quot;exchange_rate&quot;:0.00014626,&quot;exchange_rate24&quot;:0.000155109957716702,&quot;exchange_rate_vol&quot;:12.9604288790783,&quot;exchange_rate_curr&quot;:&quot;BTC&quot;,&quot;market_cap&quot;:&quot;$12,081,862.82&quot;,&quot;estimated_rewards&quot;:&quot;4.33668&quot;,&quot;estimated_rewards24&quot;:&quot;4.32928&quot;,&quot;btc_revenue&quot;:&quot;0.00063428&quot;,&quot;btc_revenue24&quot;:&quot;0.0006332&quot;,&quot;profitability&quot;:85,&quot;profitability24&quot;:88,&quot;lagging&quot;:false,&quot;timestamp&quot;:1518385184},&quot;Musicoin&quot;:{&quot;id&quot;:178,&quot;tag&quot;:&quot;MUSIC&quot;,&quot;algorithm&quot;:&quot;Ethash&quot;,&quot;block_time&quot;:&quot;14.0&quot;,&quot;block_reward&quot;:246.2,&quot;block_reward24&quot;:246.199999999998,&quot;last_block&quot;:1953827,&quot;difficulty&quot;:6613543703874.0,&quot;difficulty24&quot;:6686438484420.37,&quot;nethash&quot;:472395978848,&quot;exchange_rate&quot;:2.34e-06,&quot;exchange_rate24&quot;:2.29601694915254e-06,&quot;exchange_rate_vol&quot;:17.78104309,&quot;exchange_rate_curr&quot;:&quot;BTC&quot;,&quot;market_cap&quot;:&quot;$11,918,018.41&quot;,&quot;estimated_rewards&quot;:&quot;270.12802&quot;,&quot;estimated_rewards24&quot;:&quot;267.18363&quot;,&quot;btc_revenue&quot;:&quot;0.0006321&quot;,&quot;btc_revenue24&quot;:&quot;0.00062521&quot;,&quot;profitability&quot;:85,&quot;profitability24&quot;:87,&quot;lagging&quot;:false,&quot;timestamp&quot;:1518385185},&quot;Ellaism&quot;:{&quot;id&quot;:221,&quot;tag&quot;:&quot;ELLA&quot;,&quot;algorithm&quot;:&quot;Ethash&quot;,&quot;block_time&quot;:&quot;14.0&quot;,&quot;block_reward&quot;:4.91,&quot;block_reward24&quot;:4.91000000000001,&quot;last_block&quot;:945964,&quot;difficulty&quot;:4376186239122.0,&quot;difficulty24&quot;:4319302576114.62,&quot;nethash&quot;:312584731365,&quot;exchange_rate&quot;:7.501e-05,&quot;exchange_rate24&quot;:7.6147420718816e-05,&quot;exchange_rate_vol&quot;:1.27998339143897,&quot;exchange_rate_curr&quot;:&quot;BTC&quot;,&quot;market_cap&quot;:&quot;$2,958,733.31&quot;,&quot;estimated_rewards&quot;:&quot;8.14071&quot;,&quot;estimated_rewards24&quot;:&quot;8.24789&quot;,&quot;btc_revenue&quot;:&quot;0.00061063&quot;,&quot;btc_revenue24&quot;:&quot;0.00061867&quot;,&quot;profitability&quot;:82,&quot;profitability24&quot;:86,&quot;lagging&quot;:false,&quot;timestamp&quot;:1518385172}\r\n\r\nI would like to use the `profitability24` field.  \r\n\r\nNow that I have a json with the information I need I am having a lot of problems figuring out how to grab the most profitable currency (it&#39;s always the first in the json). My plan was to use jq but I&#39;m open to ideas. My next step is to variablize the most profitable currency and then script out the proper command for the miner to start mining that currency.\r\n\r\n  [1]: https://i.sstatic.net/GhA8S.jpg",
        "link": "https://stackoverflow.com/questions/48736632/how-to-get-the-most-profitable-currency-from-a-json",
        "title": "How to get the most profitable currency from a JSON?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2247163,
                    "reputation": 4651,
                    "user_id": 7417402,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0362a30046be9244cf62d2a9fc6f8568?s=256&d=identicon&r=PG",
                    "display_name": "Devstr",
                    "link": "https://stackoverflow.com/users/7417402/devstr"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1518435338,
                "post_id": 48745410,
                "comment_id": 84490784,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1518452492,
                "last_edit_date": 1518452492,
                "creation_date": 1518435684,
                "answer_id": 48745675,
                "question_id": 48745410,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "First I suggest you make original file a proper JSON by adding quotes to keys:\r\n\r\n    {\r\n      &quot;config&quot;: {\r\n          &quot;name&quot;: &quot;test1&quot;\r\n      }\r\n    }\r\n\r\nNow you can do it like this:    \r\n\r\n    jq &#39;{(.config.name):{}}&#39; config.name\r\n\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;test1&quot;: {}\r\n    }",
                "title": "Jq: Create new empty object with existing property as its key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1518452492,
        "creation_date": 1518434889,
        "last_edit_date": 1518435951,
        "question_id": 48745410,
        "body_markdown": "If I have a json file as follows:\r\n\r\n    {\r\n     config: {\r\n       name: &quot;test1&quot;\r\n       }\r\n    }\r\n\r\nHow would I use `jq` to create an empty object named after &quot;test1&quot; in a new file? \r\ni.e. \r\n    \r\n    test1: {\r\n    }",
        "link": "https://stackoverflow.com/questions/48745410/jq-create-new-empty-object-with-existing-property-as-its-key",
        "title": "Jq: Create new empty object with existing property as its key"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "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": 1518437766,
                "post_id": 48746081,
                "comment_id": 84492299,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1518439710,
                "creation_date": 1518439710,
                "answer_id": 48746890,
                "question_id": 48746081,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq &#39;.hits.hits[]._source | .search_result_data.shop.id as $shop_id \r\n        | .offers_data[] | select(.shop_id == $shop_id).shop_name&#39; jsonfile\r\n\r\nThe output:\r\n\r\n    &quot;Stuff&quot;",
                "title": "jq select with dynamic data from path"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1518532263,
        "creation_date": 1518436993,
        "last_edit_date": 1518532263,
        "question_id": 48746081,
        "body_markdown": "._source.offers_data[]|select(.shop_id == 2004).shop_name works, but I want to replace 2004 by a dynamic value which is ._source.search_result_data.shop.id\r\n\r\nso I wrote this  ._source.offers_data[]|select(.shop_id ==  ._source.search_result_data.shop.id).shop_name as  ._source.search_result_data.shop.id is a number it doesn&#39;t seem to be a type issue\r\n\r\n    {\r\n    &quot;_shards&quot;: {\r\n        &quot;failed&quot;: 0, \r\n        &quot;successful&quot;: 2, \r\n        &quot;total&quot;: 2\r\n    }, \r\n    &quot;hits&quot;: {\r\n        &quot;hits&quot;: [\r\n                    {\r\n                &quot;_id&quot;: &quot;P3ssss&quot;, \r\n                &quot;_index&quot;: &quot;truc&quot;, \r\n                &quot;_score&quot;: 0.0057305535, \r\n                &quot;_source&quot;: {\r\n                    &quot;category&quot;: {\r\n                        &quot;all_categories&quot;: [\r\n                            {\r\n                                &quot;id&quot;: 69, \r\n                                &quot;name&quot;: &quot;my stuff&quot;, \r\n                                &quot;url&quot;: &quot;/fr/soms/&quot;\r\n                            }\r\n                        ], \r\n                        &quot;master_category&quot;: {\r\n                            &quot;id&quot;: 69, \r\n                            &quot;name&quot;: &quot;my stuff&quot;, \r\n                            &quot;url&quot;: &quot;/soms/&quot;\r\n                        }, \r\n                        &quot;master_path&quot;: &quot;28-63-69&quot;, \r\n                        &quot;master_universe&quot;: {\r\n                            &quot;id&quot;: 28, \r\n                            &quot;name&quot;: &quot;ffffff&quot;, \r\n                            &quot;url&quot;: &quot;/soms/&quot;\r\n                        }, \r\n                        &quot;paths&quot;: [\r\n                            &quot;28-63-69&quot;\r\n                        ]\r\n                    }, \r\n                    &quot;number_filters&quot;: {\r\n                        &quot;available_quantity&quot;: 3, \r\n                        &quot;status&quot;: 1\r\n                    }, \r\n                    &quot;offers_data&quot;: [\r\n                        \r\n                        {\r\n                            &quot;availability_date&quot;: &quot;2018-02-14&quot;, \r\n                            &quot;base_price&quot;: 280.06, \r\n                            &quot;nature&quot;: 11, \r\n                            &quot;offer_id&quot;: 2628, \r\n                            &quot;promo_price&quot;: 247.35, \r\n                            &quot;quantity&quot;: 3, \r\n                            &quot;shipping_price&quot;: 0, \r\n                            &quot;shop_grade&quot;: 3, \r\n                            &quot;shop_id&quot;: 2004, \r\n                            &quot;shop_name&quot;: &quot;Stuff&quot;, \r\n                            &quot;shop_url&quot;: &quot;/some/Stuff&quot;\r\n                        }, \r\n                        {\r\n                            &quot;availability_date&quot;: &quot;2018-02-14&quot;, \r\n                            &quot;base_price&quot;: 270.61, \r\n                            &quot;nature&quot;: 11, \r\n                            &quot;offer_id&quot;: 4998, \r\n                            &quot;promo_price&quot;: 270.61, \r\n                            &quot;quantity&quot;: 12, \r\n                            &quot;shipping_price&quot;: 0, \r\n                            &quot;shop_grade&quot;: 3, \r\n                            &quot;shop_id&quot;: 2003, \r\n                            &quot;shop_name&quot;: &quot;Truc&quot;, \r\n                            &quot;shop_url&quot;: &quot;/some/truc&quot;\r\n                        }\r\n                    ], \r\n                    &quot;search_result_data&quot;: {\r\n                        &quot;base_price&quot;: 280.06, \r\n                        &quot;brand&quot;: {\r\n                            &quot;id&quot;: 58, \r\n                            &quot;logo&quot;: &quot;/so.jpg&quot;, \r\n                            &quot;name&quot;: &quot;truc&quot;, \r\n                            &quot;url&quot;: &quot;/TTTT&quot;\r\n                        }, \r\n                        &quot;flags&quot;: {\r\n                            &quot;is_exclusivity&quot;: null, \r\n                            &quot;is_favorite&quot;: false, \r\n                            &quot;is_new&quot;: false, \r\n                            &quot;is_topsales&quot;: false\r\n                        }, \r\n                        &quot;grey_dot&quot;: true, \r\n                        &quot;identifiers&quot;: {\r\n                            &quot;erp&quot;: &quot;ZORGLUB&quot;, \r\n                            &quot;id&quot;: 455565\r\n                        }, \r\n                        &quot;image&quot;: &quot;/images/&quot;, \r\n                        \r\n                        &quot;name&quot;: &quot;Isomething&quot;, \r\n                        &quot;nature&quot;: 11, \r\n                        &quot;offers_count&quot;: 11, \r\n                        &quot;offers_min_price&quot;: 233.21, \r\n                        &quot;own_offer&quot;: {\r\n                            &quot;base_price&quot;: 249.99, \r\n                            &quot;base_price_ht&quot;: 208.325, \r\n                            &quot;grey_dot&quot;: true, \r\n                            &quot;nature&quot;: 11, \r\n                            &quot;promo_price&quot;: 249.99, \r\n                            &quot;promo_price_ht&quot;: 208.325\r\n                        }, \r\n                        &quot;promo_price&quot;: 247.35, \r\n                        &quot;reviews_count&quot;: &quot;0&quot;, \r\n                        &quot;reviews_count_website_5&quot;: &quot;0&quot;, \r\n                        &quot;reviews_note&quot;: &quot;0.0000&quot;, \r\n                        &quot;reviews_note_website_5&quot;: &quot;0.0000&quot;, \r\n                        &quot;shop&quot;: {\r\n                            &quot;id&quot;: 2004, \r\n                            &quot;name&quot;: &quot;Stuff&quot;, \r\n                            &quot;url&quot;: &quot;/soms/Stuff&quot;\r\n                        }, \r\n                        &quot;url&quot;: &quot;/soms/product.html&quot;\r\n                    }\r\n                }, \r\n                &quot;_type&quot;: &quot;page&quot;, \r\n                &quot;sort&quot;: [\r\n                    0.0057305535, \r\n                    0.04427508529513\r\n                ]\r\n            }\r\n        ], \r\n        &quot;max_score&quot;: null, \r\n        &quot;total&quot;: 3657\r\n    }, \r\n    &quot;timed_out&quot;: false, \r\n    &quot;took&quot;: 68\r\n    }\r\n\r\nThen I must use in in that statement :\r\n\r\n    cat my.json | jq -c &#39;.hits.hits[]|{products_ids: ._source.search_result_data.identifiers.id,best_shop_name: ._source.offers_data[]|select(.shop_id ==  ._source.search_result_data.shop.id)}\r\n\r\nSo end result should be :\r\n\r\n{&quot;products_ids&quot;:30671,&quot;status&quot;:1,&quot;note&quot;:&quot;0.0000&quot;,&quot;is_exclusivity&quot;:null,&quot;is_favorite&quot;:false,&quot;is_new&quot;:false,&quot;is_topsales&quot;:false,&quot;price&quot;:249.99,&quot;promo_price&quot;:249.99,&quot;grey_dot&quot;:true,&quot;best_shop_name&quot;:&quot;Stuff&quot;}",
        "link": "https://stackoverflow.com/questions/48746081/jq-select-with-dynamic-data-from-path",
        "title": "jq select with dynamic data from path"
    },
    {
        "tags": [
            "json",
            "object",
            "merge",
            "jq"
        ],
        "comments": [
            {
                "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": 1518443919,
                "post_id": 48747820,
                "comment_id": 84496222,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3607837,
                    "reputation": 1023,
                    "user_id": 3009613,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://i.sstatic.net/zHINq.jpg?s=256",
                    "display_name": "John Bergqvist",
                    "link": "https://stackoverflow.com/users/3009613/john-bergqvist"
                },
                "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": 1518444194,
                "post_id": 48747820,
                "comment_id": 84496415,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1518448259,
                "last_edit_date": 1518448259,
                "creation_date": 1518447332,
                "answer_id": 48749241,
                "question_id": 48747820,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could use &quot;jf&quot; for this from https://pypi.python.org/pypi/jf\r\n\r\n    $ pip install jf\r\n\r\n    $ jf &#39;chain(), {y[&quot;id&quot;]: y for y in x}&#39; input1.json input2.json\r\n    {\r\n      &quot;input2_id&quot;: {\r\n        &quot;id&quot;: &quot;input2_id&quot;,\r\n        &quot;val&quot;: &quot;testVal2&quot;\r\n      },\r\n      &quot;input1_id&quot;: {\r\n        &quot;id&quot;: &quot;input1_id&quot;,\r\n        &quot;val&quot;: &quot;testVal1&quot;\r\n      }\r\n    }\r\n",
                "title": "Jq: appending an object from 1 file into another file"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1518447721,
                "last_edit_date": 1518447721,
                "creation_date": 1518447347,
                "answer_id": 48749245,
                "question_id": 48747820,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You’re on the right track with `{(.id):(.)}`. The following should handle the case you mentioned, and might give you some ideas about similar cases:\r\n\r\n**program.jq**: `map({(.id):(.)}) | add`\r\n\r\nInvocation:\r\n\r\n    jq -s -f program.jq input_01.json input_02.json\r\n",
                "title": "Jq: appending an object from 1 file into another file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1655707105,
        "creation_date": 1518442659,
        "last_edit_date": 1655707105,
        "question_id": 48747820,
        "body_markdown": "Using jq, how can I take a json object from a file (input_02.json), and append it to output.json, while retaining everything already in output.json (e.g. an object originating from file input_01.json).\r\n\r\nThe object to be appended in both cases is literally the entire contents of the file, with the file&#39;s &quot;id&quot; field as the object&#39;s key. \r\n\r\nI&#39;m taking a large list of input files (all with the same syntax) and essentially combining them like that.\r\n\r\nThe command i&#39;m using to create the object to be appended is as follows:\r\n    \r\n    jq &#39;{(.id):(.)} &#39; input_01.json\r\n\r\nwhich gives me: \r\n    \r\n    {\r\n      &quot;input1_id&quot;: {\r\n\r\n      }\r\n    }\r\n\r\n\r\n\r\ninput_1.json:\r\n    \r\n    {\r\n      &quot;id&quot;: &quot;input1_id&quot;,\r\n      &quot;val&quot;: &quot;testVal1&quot;\r\n    }\r\n\r\ninput2.json:\r\n    \r\n    {\r\n      &quot;id&quot;: &quot;input2_id&quot;,\r\n      &quot;val&quot;: &quot;testVal2&quot;\r\n    }\r\n\r\ndesired output:\r\n\r\n    {\r\n      &quot;input1_id&quot;: {\r\n        &quot;id&quot;: &quot;input1_id&quot;,\r\n        &quot;val&quot;: &quot;testVal1&quot;\r\n      },\r\n      &quot;input2_id&quot;: {\r\n        &quot;id&quot;: &quot;input2_id&quot;,\r\n        &quot;val&quot;: &quot;testVal2&quot;\r\n      }\r\n    }",
        "link": "https://stackoverflow.com/questions/48747820/jq-appending-an-object-from-1-file-into-another-file",
        "title": "Jq: appending an object from 1 file into another file"
    },
    {
        "tags": [
            "json",
            "jq",
            "iso8601",
            "dayofweek",
            "weekend"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1518468506,
                "last_edit_date": 1518468506,
                "creation_date": 1518464568,
                "answer_id": 48754305,
                "question_id": 48753701,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you are using UTC(!) datetimes and `jq` is linked against a `libc` which supports `strftime()`, then you can use something like this:\r\n\r\n*file.json*:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;foo&quot;,\r\n      &quot;date&quot;: &quot;2018-02-11T12:00:00Z&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;bar&quot;,\r\n      &quot;date&quot;: &quot;2018-02-12T12:00:00Z&quot;\r\n    }\r\n\r\n\r\n`jq` command:\r\n\r\n    jq &#39;.[]|select(.date|fromdateiso8601|strftime(&quot;%w&quot;) as $d|$d==&quot;7&quot; or $d==&quot;0&quot;)&#39; file.json\r\n\r\n\r\n`7` stands for Saturday, `0` for Sunday.\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;foo&quot;,\r\n      &quot;date&quot;: &quot;2018-02-11T12:00:00Z&quot;\r\n    }\r\n\r\n",
                "title": "How to filter the last items of every week?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1518497169,
                "creation_date": 1518497169,
                "answer_id": 48759625,
                "question_id": 48753701,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Shamelessly advertising.\r\n\r\nYou could use the jf version, which support all the python libraries. For Saturday and Sunday:\r\n\r\n    pip install jf\r\n    jf &#39;filter(date(x.date).weekday() &gt; 4)&#39; file.json",
                "title": "How to filter the last items of every week?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1518497169,
        "creation_date": 1518462296,
        "last_edit_date": 1518466300,
        "question_id": 48753701,
        "body_markdown": "I have json data which contains a datetime field in ISO 8601 format. I want to filter out all items which happened during the weekend. How can I do this? ",
        "link": "https://stackoverflow.com/questions/48753701/how-to-filter-the-last-items-of-every-week",
        "title": "How to filter the last items of every week?"
    },
    {
        "tags": [
            "json",
            "merge",
            "jq"
        ],
        "comments": [
            {
                "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": 1518517558,
                "post_id": 48755543,
                "comment_id": 84529456,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1518472298,
                "creation_date": 1518472298,
                "answer_id": 48756114,
                "question_id": 48755543,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq --slurpfile patterns file_2.json \\\r\n    &#39;($patterns[0] | map({(.pattern): .url}) | add) as $patterns \r\n     | .[0] | [ map((.physical_endpoint | match(&quot;^http://[^/]+/&quot;).string) as $url \r\n                     | if ($patterns | has($url)) then .available_urls = $patterns[$url]\r\n                       else . end) ]&#39; file_1.json\r\n\r\n\r\n- `($patterns[0] | map({(.pattern): .url}) | add) as $patterns` - generating *hash* structure to deal with optimized processing\r\n- `(.physical_endpoint | match(&quot;^http://[^/]+/&quot;).string) as $url` - points to the extracted *hostname*\r\n\r\n----------\r\n\r\n\r\nThe output:\r\n\r\n    [\r\n      [\r\n        {\r\n          &quot;org&quot;: &quot;Architecture Frameworks&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://localhostdayofweek/DayOfWeek&quot;,\r\n          &quot;physical_service&quot;: &quot;DayOfWeekServiceMT1001&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/testpromotion/DayOfWeekServiceMT1001_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;DayOfWeekServiceMT1001_vs0&quot;,\r\n          &quot;available_urls&quot;: [\r\n            &quot;http://cm-billingsvc2-west-pt01.crawl.com/&quot;,\r\n            &quot;http://policymanager-pt.crawl.com:30000/&quot;,\r\n            &quot;http://rmosr-resourcelifecyclemgmt-ps101.crawl.com/&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Architecture Frameworks&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://localhostdayofweek/DayOfWeek/updated&quot;,\r\n          &quot;physical_service&quot;: &quot;DayOfWeekServiceMT1002&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/UPDATE/DayOfWeekServiceMT1002_vs0_2&quot;,\r\n          &quot;virtual_service&quot;: &quot;DayOfWeekServiceMT1002_vs0&quot;,\r\n          &quot;available_urls&quot;: [\r\n            &quot;http://cm-billingsvc2-west-pt01.crawl.com/&quot;,\r\n            &quot;http://policymanager-pt.crawl.com:30000/&quot;,\r\n            &quot;http://rmosr-resourcelifecyclemgmt-ps101.crawl.com/&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Architecture Frameworks&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://localhostdayofweek/DayOfWeek&quot;,\r\n          &quot;physical_service&quot;: &quot;DayOfWeekServiceMT1004&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/test/DayOfWeekServiceMT1004_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;DayOfWeekServiceMT1004_vs0&quot;,\r\n          &quot;available_urls&quot;: [\r\n            &quot;http://cm-billingsvc2-west-pt01.crawl.com/&quot;,\r\n            &quot;http://policymanager-pt.crawl.com:30000/&quot;,\r\n            &quot;http://rmosr-resourcelifecyclemgmt-ps101.crawl.com/&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Architecture Frameworks&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://localhostdayofweek/DayOfWeek&quot;,\r\n          &quot;physical_service&quot;: &quot;DayOfWeekServiceMT1005&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/test/DayOfWeekServiceMT1005_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;DayOfWeekServiceMT1005_vs0&quot;,\r\n          &quot;available_urls&quot;: [\r\n            &quot;http://cm-billingsvc2-west-pt01.crawl.com/&quot;,\r\n            &quot;http://policymanager-pt.crawl.com:30000/&quot;,\r\n            &quot;http://rmosr-resourcelifecyclemgmt-ps101.crawl.com/&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Architecture Frameworks&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://localhostdayofweek/DayOfWeek&quot;,\r\n          &quot;physical_service&quot;: &quot;DayOfWeekServiceMT1006&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/testing/DayOfWeekServiceMT1006_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;DayOfWeekServiceMT1006_vs0&quot;,\r\n          &quot;available_urls&quot;: [\r\n            &quot;http://cm-billingsvc2-west-pt01.crawl.com/&quot;,\r\n            &quot;http://policymanager-pt.crawl.com:30000/&quot;,\r\n            &quot;http://rmosr-resourcelifecyclemgmt-ps101.crawl.com/&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;BruceSandbox&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://customerselfmgmt-bussvc-dv101.crawl.com/CMO/OnlineCharging/Charge/AmountChargingService_v1_0/AmountChargingService_v1_0&quot;,\r\n          &quot;physical_service&quot;: &quot;AmountChargingService_v1_0&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/CMO/OnlineCharging/Charge/AmountChargingService_v1_0_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;AmountChargingService_v1_0_vs0&quot;\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;BruceSandbox&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://customerselfmgmt-bussvc-dv101.crawl.com/CMO/OnlineCharging/Charge/AmountChargingService_v1_0/AmountChargingService_v1_0&quot;,\r\n          &quot;physical_service&quot;: &quot;AmountChargingService_v1_0&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/CMO/OnlineCharging/Charge/AmountChargingService_v1_0_vs2&quot;,\r\n          &quot;virtual_service&quot;: &quot;AmountChargingService_v1_0_vs2&quot;\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;BruceSandbox&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://rmf-resourceordermgmt-dv103.crawl.com/v1/eo/securitymgmt/testing/loadtestservice-v1-0/LoadTestService_v1_0&quot;,\r\n          &quot;physical_service&quot;: &quot;LoadTestService_v1_0&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/c1/EO/SecurityMgmt/testing/LoadTestService_v1_0_SOAP_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;LoadTestService_v1_0_vs0&quot;\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Campaign Management&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://cmassurance-ccmgmt-dv103.crawl.com/v1/mso/campaignmgmt/actionadvisor/actionadvisormanagementservice-v1-0&quot;,\r\n          &quot;physical_service&quot;: &quot;ActionAdvisorManagementService_v1_0&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/v1/mso/campaignmgmt/actionadvisor/actionadvisormanagementservice-v1-0_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;ActionAdvisorManagementService_v1_0_vs0&quot;\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Campaign Management&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://cmassurance-ccmgmt-dv103.crawl.com/v1/mso/campaignmgmt/actionadvisorservice/actionadvisorservice-v1-0&quot;,\r\n          &quot;physical_service&quot;: &quot;ActionAdvisorService_v1_0&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/MSO/CampaignMgmt/ActionAdvisorService_v1_0_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;ActionAdvisorService_v1_0_vs0&quot;\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Campaign Management&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://cmassurance-ccmgmt-dv103.crawl.com/v1-1/mso/campaignmgmt/actionadvisorservice/actionadvisorservice-v1-1&quot;,\r\n          &quot;physical_service&quot;: &quot;ActionAdvisorService_v1_1&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/mso/campaignmgmt/ActionAdvisorService_v1_1_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;ActionAdvisorService_v1_1_vs0&quot;\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Campaign Management&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://cmassurance-ccmgmt-dv103.crawl.com/MSO/CampaignMgmt/ActionAdvisorService/ActionAdvisorService_v2_0&quot;,\r\n          &quot;physical_service&quot;: &quot;ActionAdvisorService_v2_0&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/MSO/CampaignMgmt/ActionAdvisorService/ActionAdvisorService_v2_0_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;ActionAdvisorService_v2_0_vs0&quot;\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Campaign Management&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://cmf-custcontactmgmt-dv103.crawl.com/MSO/CampaignMgmt/Offer/BoltOnOfferService_v1_0&quot;,\r\n          &quot;physical_service&quot;: &quot;BoltOnOfferService_v1_0&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/MSO/CampaignMgmt/Offer/BoltOnOfferService_v1_0_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;BoltOnOfferService_v1_0_vs0&quot;\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Campaign Management&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://cmf-custcontactmgmt-dv103.crawl.com/MSO/CampaignMgmt/Offer/BoltOnOfferService_v1_1&quot;,\r\n          &quot;physical_service&quot;: &quot;BoltOnOfferService_v1_1&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/MSO/CampaignMgmt/Offer/BoltOnOfferService_v1_1_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;BoltOnOfferService_v1_1_vs0&quot;\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Campaign Management&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://cmf-custcontactmgmt-dv103.crawl.com/MSO/CampaignMgmt/Offer/BoltOnOfferService_v1_2&quot;,\r\n          &quot;physical_service&quot;: &quot;BoltOnOfferService_v1_2&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/MSO/CampaignMgmt/Offer/BoltOnOfferService_v1_2_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;BoltOnOfferService_v1_2_vs0&quot;\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Campaign Management&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://cmf-custcontactmgmt-dv103.crawl.com/MSO/CampaignMgmt/Offer/BoltOnOfferService_v1_3&quot;,\r\n          &quot;physical_service&quot;: &quot;BoltOnOfferService_v1_3&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/MSO/CampaignMgmt/Offer/BoltOnOfferService_v1_3_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;BoltOnOfferService_v1_3_vs0&quot;\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Campaign Management&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://cmf-custcontactmgmt-dv103.crawl.com/MSO/CampaignMgmt/Offer/BoltOnOfferService_v2_0&quot;,\r\n          &quot;physical_service&quot;: &quot;BoltOnOfferService_v2_0&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/MSO/CampaignMgmt/Offer/BoltOnOfferService_v2_0_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;BoltOnOfferService_v2_0_vs0&quot;\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Campaign Management&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://cmassurance-ccmgmt-dv103.crawl.com/CMO/ContactMgmt/BundleCommitmentExtSvc_v1_0&quot;,\r\n          &quot;physical_service&quot;: &quot;BundleCommitmentExtSvc_v1_0_1&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/CMO/ContactMgmt/BundleCommitmentExtSvc_v1_0_1_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;BundleCommitmentExtSvc_v1_0_1_vs0&quot;\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Campaign Management&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://cmassurance-ccmgmt-dv103.crawl.com/CMO/ContactMgmt/BundleCommitmentMgmtSvc_v1_1/BundleCommitmentMgmtSvc_v1_1&quot;,\r\n          &quot;physical_service&quot;: &quot;BundleCommitmentMgmtSvc_v1_0_1&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/CMO/ContactMgmt/BundleCommitmentMgmtSvc_v1_0_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;BundleCommitmentMgmtSvc_v1_0_1_vs0&quot;\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Campaign Management&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://cmassurance-ccmgmt-dv103.crawl.com/CMO/ContactMgmt/BundleCommitmentMgmtSvc_v1_1/BundleCommitmentMgmtSvc_v1_1&quot;,\r\n          &quot;physical_service&quot;: &quot;BundleCommitmentMgmtSvc_v1_1&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/CMO/ContactMgmt/BundleCommitmentMgmtSvc_v1_1_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;BundleCommitmentMgmtSvc_v1_1_vs0&quot;\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Campaign Management&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://cmassurance-ccmgmt-dv103.crawl.com/CMO/ContactMgmt/BundleCommitmentSvc_v1_1/BundleCommitmentSvc_v1_1&quot;,\r\n          &quot;physical_service&quot;: &quot;BundleCommitmentSvc_v1_0_1&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/CMO/ContactMgmt/BundleCommitmentSvc_v1_0_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;BundleCommitmentSvc_v1_0_1_vs0&quot;\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Campaign Management&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://cmassurance-ccmgmt-dv103.crawl.com/CMO/ContactMgmt/BundleCommitmentSvc_v1_1/BundleCommitmentSvc_v1_1&quot;,\r\n          &quot;physical_service&quot;: &quot;BundleCommitmentSvc_v1_1&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/CMO/ContactMgmt/BundleCommitmentSvc_v1_1_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;BundleCommitmentSvc_v1_1_vs0&quot;\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Campaign Management&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://cmassurance-ccmgmt-dv103.crawl.com/v1/mso/campaignmgmt/customer/customermarketingprofileservice-v1-0&quot;,\r\n          &quot;physical_service&quot;: &quot;CustomerMarketingProfileService_v1_0&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/v1/mso/campaignmgmt/customer/CustomerMarketingProfileService_v1_0_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;CustomerMarketingProfileService_v1_0_vs0&quot;\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Campaign Management&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://cmassurance-ccmgmt-dv103.crawl.com/v1-1/mso/campaignmgmt/customer/customermarketingprofileservice-v1-1&quot;,\r\n          &quot;physical_service&quot;: &quot;CustomerMarketingProfileService_v1_1&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/v1-1/mso/campaignmgmt/customer/customermarketingprofileservice-v1-1_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;CustomerMarketingProfileService_v1_1_vs0&quot;\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Campaign Management&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://cmassurance-ccmgmt-dv103.crawl.com/v2/mso/campaignmgmt/customer/customermarketingprofileservice-v2-0&quot;,\r\n          &quot;physical_service&quot;: &quot;CustomerMarketingProfileService_v2_0&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/v2/mso/campaignmgmt/customer/customermarketingprofileservice-v2-0_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;CustomerMarketingProfileService_v2_0_vs0&quot;\r\n        }\r\n      ]\r\n    ]\r\n\r\n\r\n",
                "title": "add attributes from one JSON file to another based on a pattern through jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1518476983,
        "creation_date": 1518469754,
        "last_edit_date": 1518476983,
        "question_id": 48755543,
        "body_markdown": "I am a jq beginner and i was wondering if it is possible to add an array from one json file to another based on a given pattern. I know it is achievable using sed or grep but I feel it is ashame to not use jq as it is designed to work with json.\r\n\r\nSo here is my scenario.\r\n\r\ni have file_1.json:\r\n\r\n    [\r\n      [\r\n    {\r\n      &quot;org&quot;: &quot;Architecture Frameworks&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;http://localhostdayofweek/DayOfWeek&quot;,\r\n      &quot;physical_service&quot;: &quot;DayOfWeekServiceMT1001&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/testpromotion/DayOfWeekServiceMT1001_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;DayOfWeekServiceMT1001_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;Architecture Frameworks&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;http://localhostdayofweek/DayOfWeek/updated&quot;,\r\n      &quot;physical_service&quot;: &quot;DayOfWeekServiceMT1002&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/UPDATE/DayOfWeekServiceMT1002_vs0_2&quot;,\r\n      &quot;virtual_service&quot;: &quot;DayOfWeekServiceMT1002_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;Architecture Frameworks&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;http://localhostdayofweek/DayOfWeek&quot;,\r\n      &quot;physical_service&quot;: &quot;DayOfWeekServiceMT1004&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/test/DayOfWeekServiceMT1004_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;DayOfWeekServiceMT1004_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;Architecture Frameworks&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;http://localhostdayofweek/DayOfWeek&quot;,\r\n      &quot;physical_service&quot;: &quot;DayOfWeekServiceMT1005&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/test/DayOfWeekServiceMT1005_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;DayOfWeekServiceMT1005_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;Architecture Frameworks&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;http://localhostdayofweek/DayOfWeek&quot;,\r\n      &quot;physical_service&quot;: &quot;DayOfWeekServiceMT1006&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/testing/DayOfWeekServiceMT1006_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;DayOfWeekServiceMT1006_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;BruceSandbox&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;http://customerselfmgmt-bussvc-dv101.crawl.com/CMO/OnlineCharging/Charge/AmountChargingService_v1_0/AmountChargingService_v1_0&quot;,\r\n      &quot;physical_service&quot;: &quot;AmountChargingService_v1_0&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/CMO/OnlineCharging/Charge/AmountChargingService_v1_0_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;AmountChargingService_v1_0_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;BruceSandbox&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;http://customerselfmgmt-bussvc-dv101.crawl.com/CMO/OnlineCharging/Charge/AmountChargingService_v1_0/AmountChargingService_v1_0&quot;,\r\n      &quot;physical_service&quot;: &quot;AmountChargingService_v1_0&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/CMO/OnlineCharging/Charge/AmountChargingService_v1_0_vs2&quot;,\r\n      &quot;virtual_service&quot;: &quot;AmountChargingService_v1_0_vs2&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;BruceSandbox&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;http://rmf-resourceordermgmt-dv103.crawl.com/v1/eo/securitymgmt/testing/loadtestservice-v1-0/LoadTestService_v1_0&quot;,\r\n      &quot;physical_service&quot;: &quot;LoadTestService_v1_0&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/c1/EO/SecurityMgmt/testing/LoadTestService_v1_0_SOAP_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;LoadTestService_v1_0_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;Campaign Management&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;http://cmassurance-ccmgmt-dv103.crawl.com/v1/mso/campaignmgmt/actionadvisor/actionadvisormanagementservice-v1-0&quot;,\r\n      &quot;physical_service&quot;: &quot;ActionAdvisorManagementService_v1_0&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/v1/mso/campaignmgmt/actionadvisor/actionadvisormanagementservice-v1-0_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;ActionAdvisorManagementService_v1_0_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;Campaign Management&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;http://cmassurance-ccmgmt-dv103.crawl.com/v1/mso/campaignmgmt/actionadvisorservice/actionadvisorservice-v1-0&quot;,\r\n      &quot;physical_service&quot;: &quot;ActionAdvisorService_v1_0&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/MSO/CampaignMgmt/ActionAdvisorService_v1_0_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;ActionAdvisorService_v1_0_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;Campaign Management&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;http://cmassurance-ccmgmt-dv103.crawl.com/v1-1/mso/campaignmgmt/actionadvisorservice/actionadvisorservice-v1-1&quot;,\r\n      &quot;physical_service&quot;: &quot;ActionAdvisorService_v1_1&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/mso/campaignmgmt/ActionAdvisorService_v1_1_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;ActionAdvisorService_v1_1_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;Campaign Management&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;http://cmassurance-ccmgmt-dv103.crawl.com/MSO/CampaignMgmt/ActionAdvisorService/ActionAdvisorService_v2_0&quot;,\r\n      &quot;physical_service&quot;: &quot;ActionAdvisorService_v2_0&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/MSO/CampaignMgmt/ActionAdvisorService/ActionAdvisorService_v2_0_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;ActionAdvisorService_v2_0_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;Campaign Management&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;https://ca.smartbutton.com/WS/MemberSecurity.asmx&quot;,\r\n      &quot;physical_service&quot;: &quot;AimiaMemberLoginMgmtSvc_v1_0&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/CMO/SelfMgmt/SOAP11/AimiaMemberLoginMgmtSvc_v1_0_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;AimiaMemberLoginMgmtSvc_v1_0_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;Campaign Management&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;https://ca.smartbutton.com/WS/MemberActivity.asmx&quot;,\r\n      &quot;physical_service&quot;: &quot;AimiaMemberPointsQuerySvc_v1_0&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/CMO/SelfMgmt/SOAP11/AimiaMemberPointsQuerySvc_v1_0_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;AimiaMemberPointsQuerySvc_v1_0_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;Campaign Management&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;https://ca.smartbutton.com/WS/Portal.asmx&quot;,\r\n      &quot;physical_service&quot;: &quot;AimiaPortalSvc_v1_0&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/CMO/SelfMgmt/SOAP11/AimiaPortalSvc_v1_0_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;AimiaPortalSvc_v1_0_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;Campaign Management&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;https://ca.smartbutton.com/WS/user.asmx&quot;,\r\n      &quot;physical_service&quot;: &quot;AimiaUserSvc_v1_0&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/CMO/SelfMgmt/SOAP11/AimiaUserSvc_v1_0_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;AimiaUserSvc_v1_0_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;Campaign Management&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;http://cmf-custcontactmgmt-dv103.crawl.com/MSO/CampaignMgmt/Offer/BoltOnOfferService_v1_0&quot;,\r\n      &quot;physical_service&quot;: &quot;BoltOnOfferService_v1_0&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/MSO/CampaignMgmt/Offer/BoltOnOfferService_v1_0_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;BoltOnOfferService_v1_0_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;Campaign Management&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;http://cmf-custcontactmgmt-dv103.crawl.com/MSO/CampaignMgmt/Offer/BoltOnOfferService_v1_1&quot;,\r\n      &quot;physical_service&quot;: &quot;BoltOnOfferService_v1_1&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/MSO/CampaignMgmt/Offer/BoltOnOfferService_v1_1_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;BoltOnOfferService_v1_1_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;Campaign Management&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;http://cmf-custcontactmgmt-dv103.crawl.com/MSO/CampaignMgmt/Offer/BoltOnOfferService_v1_2&quot;,\r\n      &quot;physical_service&quot;: &quot;BoltOnOfferService_v1_2&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/MSO/CampaignMgmt/Offer/BoltOnOfferService_v1_2_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;BoltOnOfferService_v1_2_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;Campaign Management&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;http://cmf-custcontactmgmt-dv103.crawl.com/MSO/CampaignMgmt/Offer/BoltOnOfferService_v1_3&quot;,\r\n      &quot;physical_service&quot;: &quot;BoltOnOfferService_v1_3&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/MSO/CampaignMgmt/Offer/BoltOnOfferService_v1_3_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;BoltOnOfferService_v1_3_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;Campaign Management&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;http://cmf-custcontactmgmt-dv103.crawl.com/MSO/CampaignMgmt/Offer/BoltOnOfferService_v2_0&quot;,\r\n      &quot;physical_service&quot;: &quot;BoltOnOfferService_v2_0&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/MSO/CampaignMgmt/Offer/BoltOnOfferService_v2_0_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;BoltOnOfferService_v2_0_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;Campaign Management&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;http://cmassurance-ccmgmt-dv103.crawl.com/CMO/ContactMgmt/BundleCommitmentExtSvc_v1_0&quot;,\r\n      &quot;physical_service&quot;: &quot;BundleCommitmentExtSvc_v1_0_1&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/CMO/ContactMgmt/BundleCommitmentExtSvc_v1_0_1_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;BundleCommitmentExtSvc_v1_0_1_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;Campaign Management&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;http://cmassurance-ccmgmt-dv103.crawl.com/CMO/ContactMgmt/BundleCommitmentMgmtSvc_v1_1/BundleCommitmentMgmtSvc_v1_1&quot;,\r\n      &quot;physical_service&quot;: &quot;BundleCommitmentMgmtSvc_v1_0_1&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/CMO/ContactMgmt/BundleCommitmentMgmtSvc_v1_0_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;BundleCommitmentMgmtSvc_v1_0_1_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;Campaign Management&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;http://cmassurance-ccmgmt-dv103.crawl.com/CMO/ContactMgmt/BundleCommitmentMgmtSvc_v1_1/BundleCommitmentMgmtSvc_v1_1&quot;,\r\n      &quot;physical_service&quot;: &quot;BundleCommitmentMgmtSvc_v1_1&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/CMO/ContactMgmt/BundleCommitmentMgmtSvc_v1_1_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;BundleCommitmentMgmtSvc_v1_1_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;Campaign Management&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;http://cmassurance-ccmgmt-dv103.crawl.com/CMO/ContactMgmt/BundleCommitmentSvc_v1_1/BundleCommitmentSvc_v1_1&quot;,\r\n      &quot;physical_service&quot;: &quot;BundleCommitmentSvc_v1_0_1&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/CMO/ContactMgmt/BundleCommitmentSvc_v1_0_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;BundleCommitmentSvc_v1_0_1_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;Campaign Management&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;http://cmassurance-ccmgmt-dv103.crawl.com/CMO/ContactMgmt/BundleCommitmentSvc_v1_1/BundleCommitmentSvc_v1_1&quot;,\r\n      &quot;physical_service&quot;: &quot;BundleCommitmentSvc_v1_1&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/CMO/ContactMgmt/BundleCommitmentSvc_v1_1_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;BundleCommitmentSvc_v1_1_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;Campaign Management&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;http://cmassurance-ccmgmt-dv103.crawl.com/v1/mso/campaignmgmt/customer/customermarketingprofileservice-v1-0&quot;,\r\n      &quot;physical_service&quot;: &quot;CustomerMarketingProfileService_v1_0&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/v1/mso/campaignmgmt/customer/CustomerMarketingProfileService_v1_0_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;CustomerMarketingProfileService_v1_0_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;Campaign Management&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;http://cmassurance-ccmgmt-dv103.crawl.com/v1-1/mso/campaignmgmt/customer/customermarketingprofileservice-v1-1&quot;,\r\n      &quot;physical_service&quot;: &quot;CustomerMarketingProfileService_v1_1&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/v1-1/mso/campaignmgmt/customer/customermarketingprofileservice-v1-1_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;CustomerMarketingProfileService_v1_1_vs0&quot;\r\n    },\r\n    {\r\n      &quot;org&quot;: &quot;Campaign Management&quot;,\r\n      &quot;physical_endpoint&quot;: &quot;http://cmassurance-ccmgmt-dv103.crawl.com/v2/mso/campaignmgmt/customer/customermarketingprofileservice-v2-0&quot;,\r\n      &quot;physical_service&quot;: &quot;CustomerMarketingProfileService_v2_0&quot;,\r\n      &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/v2/mso/campaignmgmt/customer/customermarketingprofileservice-v2-0_vs0&quot;,\r\n      &quot;virtual_service&quot;: &quot;CustomerMarketingProfileService_v2_0_vs0&quot;\r\n    }\r\n      ]\r\n    ]\r\n\r\nand file_2.json:\r\n\r\n    [\r\n      {\r\n        &quot;pattern&quot;: &quot;http://localhostdayofweek/&quot;,\r\n        &quot;url&quot;: [\r\n          &quot;http://cm-billingsvc2-west-pt01.crawl.com/&quot;,\r\n          &quot;http://policymanager-pt.crawl.com:30000/&quot;,\r\n          &quot;http://rmosr-resourcelifecyclemgmt-ps101.crawl.com/&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;pattern&quot;: &quot; https://207.229.22.173:9446/&quot;,\r\n        &quot;url&quot;: [\r\n          &quot; https://fbpm-itn01-west.crawl.com/&quot;,\r\n          &quot; https://fbpm-itn02-west.crawl.com/&quot;,\r\n          &quot; https://fbpm-itn03-west.crawl.com/&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;pattern&quot;: &quot;customermanagementesb-entk-dv01.crawl.com/&quot;,\r\n        &quot;url&quot;: [\r\n          &quot;http://customermanagementesb-pt168.crawl.com/&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;pattern&quot;: &quot;http://an05050.corp.ads:9080/&quot;,\r\n        &quot;url&quot;: [\r\n          &quot;http://abe-wbsf-pt3-01.osc.tac.net:9080/&quot;,\r\n          &quot;http://an05063.corp.ads:9080/&quot;,\r\n          &quot;http://fabric-st1.crawl.com:9080/&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;pattern&quot;: &quot;http://an05057.corp.ads:9080/&quot;,\r\n        &quot;url&quot;: [\r\n          &quot;http://abe-wbsf-at-01.osc.tac.net:9080/&quot;,\r\n          &quot;http://abe-wbsf-pt1-01.osc.tac.net:9080/&quot;,\r\n          &quot;http://abe-wbsf-pt3-01.osc.tac.net:9080/&quot;,\r\n          &quot;http://an05050.corp.ads:9080/&quot;,\r\n          &quot;http://cbpm-itn01-west.crawl.com/&quot;,\r\n          &quot;http://cbpm-itn02-west.crawl.com/&quot;,\r\n          &quot;http://cbpm-itn03-west.crawl.com/&quot;,\r\n          &quot;http://cbpm-itn04-west.crawl.com/&quot;,\r\n          &quot;http://fabric-st1.crawl.com:9080/&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;pattern&quot;: &quot;http://asfweb-wk02.crawl.com/&quot;,\r\n        &quot;url&quot;: [\r\n          &quot;http://asfweb-is03.crawl.com/&quot;,\r\n          &quot;http://asfweb-is05.crawl.com/&quot;,\r\n          &quot;http://asfweb-is06.crawl.com/&quot;,\r\n          &quot;http://asfweb-is09.crawl.com/&quot;,\r\n          &quot;http://asfweb-itn01.crawl.com/&quot;,\r\n          &quot;http://asfweb-itn02.crawl.com/&quot;,\r\n          &quot;http://asfweb-itn03.crawl.com/&quot;,\r\n          &quot;http://asfweb-itn04.crawl.com/&quot;\r\n        ]\r\n       }\r\n    ]\r\n\r\nfrom file_1.json, i wanted to be able to search for each of the physical_endpoint starting with http[s]://hostname / on file_2.json, and if there is a match, append the .url array to file_1.json as .available_urls.\r\n\r\nThe expected output is like this:\r\n\r\n    [\r\n      [\r\n        {\r\n          &quot;org&quot;: &quot;Architecture Frameworks&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://localhostdayofweek/DayOfWeek&quot;,\r\n          &quot;physical_service&quot;: &quot;DayOfWeekServiceMT1001&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/testpromotion/DayOfWeekServiceMT1001_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;DayOfWeekServiceMT1001_vs0&quot;,\r\n    \t  &quot;available_urls&quot;: [\r\n              &quot;http://cm-billingsvc2-west-pt01.crawl.com/&quot;,\r\n              &quot;http://policymanager-pt.crawl.com:30000/&quot;,\r\n              &quot;http://rmosr-resourcelifecyclemgmt-ps101.crawl.com/&quot;\r\n            ]\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Architecture Frameworks&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://localhostdayofweek/DayOfWeek/updated&quot;,\r\n          &quot;physical_service&quot;: &quot;DayOfWeekServiceMT1002&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/UPDATE/DayOfWeekServiceMT1002_vs0_2&quot;,\r\n          &quot;virtual_service&quot;: &quot;DayOfWeekServiceMT1002_vs0&quot;,\r\n    \t  &quot;available_urls&quot;: [\r\n              &quot;http://cm-billingsvc2-west-pt01.crawl.com/&quot;,\r\n              &quot;http://policymanager-pt.crawl.com:30000/&quot;,\r\n              &quot;http://rmosr-resourcelifecyclemgmt-ps101.crawl.com/&quot;\r\n            ]\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Architecture Frameworks&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://localhostdayofweek/DayOfWeek&quot;,\r\n          &quot;physical_service&quot;: &quot;DayOfWeekServiceMT1004&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/test/DayOfWeekServiceMT1004_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;DayOfWeekServiceMT1004_vs0&quot;,\r\n    \t  &quot;available_urls&quot;: [\r\n              &quot;http://cm-billingsvc2-west-pt01.crawl.com/&quot;,\r\n              &quot;http://policymanager-pt.crawl.com:30000/&quot;,\r\n              &quot;http://rmosr-resourcelifecyclemgmt-ps101.crawl.com/&quot;\r\n            ]\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Architecture Frameworks&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://localhostdayofweek/DayOfWeek&quot;,\r\n          &quot;physical_service&quot;: &quot;DayOfWeekServiceMT1005&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/test/DayOfWeekServiceMT1005_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;DayOfWeekServiceMT1005_vs0&quot;,\r\n    \t  &quot;available_urls&quot;: [\r\n              &quot;http://cm-billingsvc2-west-pt01.crawl.com/&quot;,\r\n              &quot;http://policymanager-pt.crawl.com:30000/&quot;,\r\n              &quot;http://rmosr-resourcelifecyclemgmt-ps101.crawl.com/&quot;\r\n            ]\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;Architecture Frameworks&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://localhostdayofweek/DayOfWeek&quot;,\r\n          &quot;physical_service&quot;: &quot;DayOfWeekServiceMT1006&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/testing/DayOfWeekServiceMT1006_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;DayOfWeekServiceMT1006_vs0&quot;,\r\n    \t  &quot;available_urls&quot;: [\r\n              &quot;http://cm-billingsvc2-west-pt01.crawl.com/&quot;,\r\n              &quot;http://policymanager-pt.crawl.com:30000/&quot;,\r\n              &quot;http://rmosr-resourcelifecyclemgmt-ps101.crawl.com/&quot;\r\n            ]\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;BruceSandbox&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://customerselfmgmt-bussvc-dv101.crawl.com/CMO/OnlineCharging/Charge/AmountChargingService_v1_0/AmountChargingService_v1_0&quot;,\r\n          &quot;physical_service&quot;: &quot;AmountChargingService_v1_0&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/CMO/OnlineCharging/Charge/AmountChargingService_v1_0_vs0&quot;,\r\n          &quot;virtual_service&quot;: &quot;AmountChargingService_v1_0_vs0&quot;\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;BruceSandbox&quot;,\r\n          &quot;physical_endpoint&quot;: &quot;http://customerselfmgmt-bussvc-dv101.crawl.com/CMO/OnlineCharging/Charge/AmountChargingService_v1_0/AmountChargingService_v1_0&quot;,\r\n          &quot;physical_service&quot;: &quot;AmountChargingService_v1_0&quot;,\r\n          &quot;virtual_endpoint&quot;: &quot;https://sandbox-laird-dv.crawl.com:443/CMO/OnlineCharging/Charge/AmountChargingService_v1_0_vs2&quot;,\r\n          &quot;virtual_service&quot;: &quot;AmountChargingService_v1_0_vs2&quot;\r\n        }\r\n      ]\r\n    ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48755543/add-attributes-from-one-json-file-to-another-based-on-a-pattern-through-jq",
        "title": "add attributes from one JSON file to another based on a pattern through jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2022684,
                    "reputation": 568,
                    "user_id": 1808480,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cb82ccb3c72846f4e111348b8d5a01e5?s=256&d=identicon&r=PG",
                    "display_name": "ErisDS",
                    "link": "https://stackoverflow.com/users/1808480/erisds"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1518515161,
                "post_id": 48762994,
                "comment_id": 84527947,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1518520103,
                "last_edit_date": 1518520103,
                "creation_date": 1518514521,
                "answer_id": 48763533,
                "question_id": 48762994,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You don’t indicate precisely what should happen when there is no private ip (or indeed if there is more than one), but the following should get you on your way.\r\n\r\n&lt;!-- language: lang-jq --&gt;\r\n\r\n    .droplets\r\n    | map({id, name, status, \r\n           public_ip: (first(.networks.v4[] | select(.type==&quot;public&quot;))  // {})\r\n                      | .ip_address,\r\n           private_ip: (first(.networks.v4[] | select(.type==&quot;private&quot;)) // {})\r\n                      | .ip_address } )\r\n\r\n### Conditional key\r\n\r\n&lt;!-- language: lang-jq --&gt;\r\n\r\n    def one(condition): first(.[] | select(condition)) // null;\r\n\r\n    .droplets\r\n    | map({id, name, status}\r\n          + (.networks.v4\r\n             | { public_ip: one(.type==&quot;public&quot;) | .ip_address}\r\n               + (one(.type==&quot;private&quot;) \r\n                  | if . then {private_ip: .ip_address} else null end ) ))\r\n\r\n\r\n",
                "title": "How to conditionally map values to new object with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1518520103,
        "creation_date": 1518512751,
        "question_id": 48762994,
        "body_markdown": "I am fetching droplet lists from the DigitalOcean JSON API and using jq map to transform the response into just the info I need.\r\n\r\nI want to be able to add an optional key &amp; value pair to my new object, based on whether the response contains a key with a certain value. \r\n\r\nWhen using `select()` if the response doesn&#39;t contain a match, the whole droplet entry is removed from my new object, rather than just the key.\r\n\r\nHow can I filter a single key rather than the whole entry?\r\n\r\nIn detail:\r\n\r\nThe response for a single droplet looks like this:\r\n\r\n\r\n     &quot;id&quot;: 12345678,\r\n     &quot;name&quot;: &quot;my-droplet&quot;,\r\n     ...\r\n     &quot;networks&quot;: {\r\n          &quot;v4&quot;: [\r\n            {\r\n              &quot;ip_address&quot;: &quot;123.456.78.90&quot;,\r\n              &quot;netmask&quot;: &quot;255.255.240.0&quot;,\r\n              &quot;gateway&quot;: &quot;123.123.0.1&quot;,\r\n              &quot;type&quot;: &quot;public&quot;\r\n            },\r\n            {\r\n              &quot;ip_address&quot;: &quot;10.123.45.67&quot;,\r\n              &quot;netmask&quot;: &quot;255.255.0.0&quot;,\r\n              &quot;gateway&quot;: &quot;10.123.0.1&quot;,\r\n              &quot;type&quot;: &quot;private&quot;\r\n            }\r\n          ],\r\n          &quot;v6&quot;: []\r\n        },\r\n     ...\r\n\r\n\r\nI want to transform this into an object of the form:\r\n\r\n\r\n    {\r\n      &quot;id&quot;: 12345678,\r\n      &quot;name&quot;: &quot;my-droplet&quot;,\r\n      &quot;public_ip&quot;: &quot;123.456.78.90&quot;,\r\n      &quot;private_ip&quot; &quot;10.123.45.67&quot;\r\n    } \r\n\r\nAll droplets have a public IP, but the private IP is optional.\r\n\r\nI have this, which ignores the optional private IP, and works fine so far:\r\n\r\n`jq &#39;.droplets | map({id: .id, name: .name, status: .status, public_ip: .networks.v4[] | select(.type==&quot;public&quot;) | .ip_address})&#39;`\r\n\r\nHowever, once I add in the private IP, any droplet that doesn&#39;t have one goes missing from the response:\r\n\r\n`jq &#39;.droplets | map({id: .id, name: .name, status: .status, public_ip: .networks.v4[] | select(.type==&quot;public&quot;) | .ip_address, private_ip: .networks.v4[] | select(.type==&quot;private&quot;) | .ip_address})&#39;`\r\n\r\nI think I need to use concatenation or conditionals some how, but I can&#39;t quite figure out the syntax.\r\n\r\nNote: I found this similar question, but it doesn&#39;t include changing the name of the key: https://stackoverflow.com/questions/33148557/denormalizing-json-with-jq",
        "link": "https://stackoverflow.com/questions/48762994/how-to-conditionally-map-values-to-new-object-with-jq",
        "title": "How to conditionally map values to new object with jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 14,
                "is_accepted": true,
                "score": 14,
                "last_activity_date": 1518519112,
                "last_edit_date": 1518519112,
                "creation_date": 1518518806,
                "answer_id": 48764947,
                "question_id": 48764829,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It would be:\r\n\r\n    jq -r &#39;to_entries|map(.value)|@tsv&#39; file.json\r\n\r\n`to_entries` transforms the input into:\r\n\r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;base_price_mw&quot;,\r\n        &quot;value&quot;: 249.99\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;best_offer_base_price&quot;,\r\n        &quot;value&quot;: 280.06\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;best_offer_nature&quot;,\r\n        &quot;value&quot;: 11\r\n      },\r\n      ...\r\n    ]\r\n\r\n... we get only the values from that using `map(.value)` and pass that to `@tsv`\r\n\r\n",
                "title": "jq cannot be tsv-formatted, only array error"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1518522804,
                "creation_date": 1518522804,
                "answer_id": 48766247,
                "question_id": 48764829,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you just want the values (without headers):\r\n\r\n    [.[]] | @tsv\r\n\r\nIf you want the headers as well:\r\n\r\n    (keys_unsorted, [.[]]) | @tsv\r\n\r\n \r\n",
                "title": "jq cannot be tsv-formatted, only array error"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 9,
        "last_activity_date": 1518532013,
        "creation_date": 1518518474,
        "last_edit_date": 1518532013,
        "question_id": 48764829,
        "body_markdown": "I&#39;ve this structure\r\n\r\n*file.json:*\r\n\r\n    {\r\n    &quot;base_price_mw&quot;: 249.99, \r\n    &quot;best_offer_base_price&quot;: 280.06, \r\n    &quot;best_offer_nature&quot;: 11, \r\n    &quot;best_offer_promo_price&quot;: 247.35, \r\n    &quot;best_offer_shiping_price&quot;: 0, \r\n    &quot;best_shop_id&quot;: 2004, \r\n    &quot;best_shop_name&quot;: &quot;Stuff&quot;, \r\n    &quot;cat_id&quot;: 69, \r\n    &quot;grey_dot&quot;: true, \r\n    &quot;is_exclusivity&quot;: null, \r\n    &quot;is_favorite&quot;: false, \r\n    &quot;is_new&quot;: false, \r\n    &quot;is_topsales&quot;: false, \r\n    &quot;manufacturer_id&quot;: 58, \r\n    &quot;name&quot;: &quot;my product name&quot;, \r\n    &quot;nature_mw&quot;: 11, \r\n    &quot;note&quot;: &quot;0.0000&quot;, \r\n    &quot;offers_count&quot;: 11, \r\n    &quot;offers_min_price&quot;: 233.21, \r\n    &quot;products_ids&quot;: 30671, \r\n    &quot;promo_price_mw&quot;: 249.99, \r\n    &quot;status&quot;: 1\r\n    }\r\n\r\nI want to make it tsv with jq, but jq says:\r\n\r\n    jq: error (at &lt;stdin&gt;:1): object ({&quot;products_...) cannot be tsv-formatted, only array\r\n\r\nI can&#39;t see why\r\n\r\nthe full command I&#39;m passing is : \r\n\r\n    jq  &#39;@tsv&#39; file.json\r\n\r\nI tried -c or -r and -R options with no luck. I can&#39;t see why this doesn&#39;t work\r\nThanks for your help",
        "link": "https://stackoverflow.com/questions/48764829/jq-cannot-be-tsv-formatted-only-array-error",
        "title": "jq cannot be tsv-formatted, only array error"
    },
    {
        "tags": [
            "json",
            "linux",
            "shell",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "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": 1518526557,
                "post_id": 48767090,
                "comment_id": 84534931,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1518526572,
                "creation_date": 1518526572,
                "answer_id": 48767387,
                "question_id": 48767090,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your jq invocations are fine, but the sample data is missing a final closing brace (&quot;}&quot;), so perhaps you were not feeding jq properly. \r\n\r\nIf you&#39;re wondering why you didn&#39;t see an error message, it&#39;s almost certainly because jq 1.5 is not very good about handling incomplete JSON. The problem has since been fixed at &quot;master&quot;.  With the current version, you&#39;d see something like this:\r\n\r\n    parse error: Unfinished JSON term at EOF at line 15, column 0\r\n\r\n",
                "title": "How to use jq to get a value of decimal/number type from a JSON response which is not surrounded by &quot; &quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1518527411,
        "creation_date": 1518525702,
        "last_edit_date": 1518527411,
        "question_id": 48767090,
        "body_markdown": "I am new to shell scripting and I need some help.\r\nI am trying to use jq to get values from a api response and check for its correctness.\r\n\r\nHere is a sample for how the response looks like,\r\n\r\n        {\r\n          &quot;data&quot; : {\r\n            &quot;transactionType&quot; : &quot;Sales&quot;,\r\n            &quot;transactionSubType&quot; : &quot;DomesticSale&quot;,\r\n            &quot;Items&quot; : [ {\r\n              &quot;itemID&quot; : &quot;2&quot;,\r\n              &quot;itemType&quot; : &quot;Good&quot;,\r\n              &quot;amount&quot; : 5.0,\r\n              &quot;tax&quot; : 1.0\t     \r\n            } ]\r\n         }\r\n    }\r\n\r\nI am able to get the values for transactionType or transactionsubtype or even ItemID values etc as given below\r\n\r\n    jq &#39;.data.transactionType&#39;    \r\n    jq &#39;.data.Items[0].itemID&#39; \r\n\r\nfor Transaction type and item id\r\n\r\nbut when it comes to values of numeric types i.e., without the quotes in it, I don&#39;t get any value. \r\nI am using similar syntax for the numeric type also as shown below.\r\n\r\n    jq &#39;.data.Items[0].amount&#39;\r\n    jq &#39;.data.Items[0].tax&#39;\r\n\r\nPlease help!!!\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48767090/how-to-use-jq-to-get-a-value-of-decimal-number-type-from-a-json-response-which-i",
        "title": "How to use jq to get a value of decimal/number type from a JSON response which is not surrounded by &quot; &quot;"
    },
    {
        "tags": [
            "json",
            "posix",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3057,
                    "reputation": 250951,
                    "user_id": 4323,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://i.sstatic.net/qqgFU.png?s=256",
                    "display_name": "John Zwinck",
                    "link": "https://stackoverflow.com/users/4323/john-zwinck"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1518624699,
                "post_id": 48790861,
                "comment_id": 84585142,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3057,
                    "reputation": 250951,
                    "user_id": 4323,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://i.sstatic.net/qqgFU.png?s=256",
                    "display_name": "John Zwinck",
                    "link": "https://stackoverflow.com/users/4323/john-zwinck"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1518624918,
                "post_id": 48790861,
                "comment_id": 84585317,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1518623363,
                "creation_date": 1518623363,
                "answer_id": 48791139,
                "question_id": 48790861,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In case you have an array of 2 objects:\r\n\r\n    jq &#39;.[0]&#39; input.json &gt; doc1.json &amp;&amp; jq &#39;.[1]&#39; input.json &gt; doc2.json\r\nResults:\r\n\r\n    $ head -n100 doc[12].json\r\n    ==&gt; doc1.json &lt;==\r\n    {\r\n      &quot;correlationId&quot;: &quot;2232845a8556cd3219e46ab8&quot;,\r\n      &quot;leg&quot;: 0,\r\n      &quot;tag&quot;: &quot;received&quot;,\r\n      &quot;offset&quot;: 263128,\r\n      &quot;len&quot;: 30,\r\n      &quot;prev&quot;: {\r\n        &quot;page&quot;: {\r\n          &quot;file&quot;: 0,\r\n          &quot;page&quot;: 0\r\n        },\r\n        &quot;record&quot;: 0\r\n      },\r\n      &quot;data&quot;: &quot;HEAD /healthcheck HTTP/1.1\\r\\n\\r\\n&quot;\r\n    }\r\n    \r\n    ==&gt; doc2.json &lt;==\r\n    {\r\n      &quot;correlationId&quot;: &quot;2232845a8556cd3219e46ab8&quot;,\r\n      &quot;leg&quot;: 0,\r\n      &quot;tag&quot;: &quot;sent&quot;,\r\n      &quot;offset&quot;: 262971,\r\n      &quot;len&quot;: 157,\r\n      &quot;prev&quot;: {\r\n        &quot;page&quot;: {\r\n          &quot;file&quot;: 10330,\r\n          &quot;page&quot;: 6\r\n        },\r\n        &quot;record&quot;: 1271\r\n      },\r\n      &quot;data&quot;: &quot;HTTP/1.1 200 OK\\r\\nDate: Wed, 14 Feb 2018 12:57:06 GMT\\r\\nServer: \\r\\nConnection: close\\r\\nX-CorrelationID: Id-2232845a8556cd3219e46ab8 0\\r\\nContent-Type: text/xml\\r\\n\\r\\n&quot;\r\n    }\r\n\r\n",
                "title": "Split JSON array into separate files/objects"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1518624877,
                "last_edit_date": 1518624877,
                "creation_date": 1518623971,
                "answer_id": 48791333,
                "question_id": 48790861,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can do it more efficiently using Python (because you can read the entire input once, instead of once per document):\r\n\r\n    import json\r\n    \r\n    docs = json.load(open(&#39;in.json&#39;))\r\n    \r\n    for ii, doc in enumerate(docs):\r\n        with open(&#39;doc{}.json&#39;.format(ii), &#39;w&#39;) as out:\r\n            json.dump(doc, out, indent=2)\r\n",
                "title": "Split JSON array into separate files/objects"
            },
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1518681986,
                "last_edit_date": 1518681986,
                "creation_date": 1518678402,
                "answer_id": 48801628,
                "question_id": 48790861,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using jq, one can split an array into its components using the filter:\r\n\r\n    .[]\r\n\r\nThe question then becomes what is to be done with each component. If you want to direct each component to a separate file, you could (for example) use jq with the -c option, and filter the result into awk, which can then allocate the components to different files. See e.g. https://stackoverflow.com/questions/41500569/split-json-file-objects-into-multiple-files\r\n\r\n### Performance considerations\r\nOne might think that the overhead of calling jq+awk would be high compared to calling python, but both jq and awk are lightweight compared to python+json, as suggested by these timings (using Python 2.7.10):\r\n\r\n    time (jq -c  .[] input.json | awk &#39;{print &gt; &quot;doc00&quot; NR &quot;.json&quot;;}&#39;)\r\n    user\t0m0.005s\r\n    sys\t    0m0.008s\r\n    \r\n    time python split.py\r\n    user\t0m0.016s\r\n    sys\t    0m0.046s\r\n\r\n\r\n",
                "title": "Split JSON array into separate files/objects"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1537170659,
                "creation_date": 1537170659,
                "answer_id": 52363084,
                "question_id": 48790861,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To split a json with many records into chunks of a desired size I simply use:\r\n\r\n    jq -c &#39;.[0:1000]&#39; mybig.json\r\n\r\nwhich works like python slicing.\r\n\r\nSee the docs here: https://stedolan.github.io/jq/manual/\r\n\r\n&gt; Array/String Slice: .[10:15] \r\n&gt;\r\n&gt; The .[10:15] syntax can be used to return\r\n&gt; a subarray of an array or substring of a string. The array returned by\r\n&gt; .[10:15] will be of length 5, containing the elements from index 10\r\n&gt; (inclusive) to index 15 (exclusive). Either index may be negative (in\r\n&gt; which case it counts backwards from the end of the array), or omitted\r\n&gt; (in which case it refers to the start or end of the array).",
                "title": "Split JSON array into separate files/objects"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1565782101,
                "creation_date": 1565782101,
                "answer_id": 57493808,
                "question_id": 48790861,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way to do this is using jq&#39;s stream option and piping that to the split command \r\n```bash\r\njq -cn --stream &#39;fromstream(1|truncate_stream(inputs))&#39; bigfile.json | split -l $num_of_elements_in_a_file - big_part\r\n```\r\nThe number of lines per file varies according to the value that you put into num_of_elements_in_a_file,\r\n\r\nYou can check out this answer https://stackoverflow.com/questions/49808581/using-jq-how-can-i-split-a-very-large-json-file-into-multiple-files-each-a-spec#\r\nwhich refers to this page for a discussion on how to use the streaming parser\r\nhttps://github.com/stedolan/jq/wiki/FAQ#streaming-json-parser",
                "title": "Split JSON array into separate files/objects"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1663329598,
                "creation_date": 1663329598,
                "answer_id": 73744530,
                "question_id": 48790861,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just adding another example.\r\njq -c &#39;.[0:10]&#39; large_json.json &gt; outputtosmall.json",
                "title": "Split JSON array into separate files/objects"
            }
        ],
        "is_answered": true,
        "answer_count": 6,
        "score": 10,
        "last_activity_date": 1663329598,
        "creation_date": 1518622515,
        "last_edit_date": 1526398206,
        "question_id": 48790861,
        "body_markdown": "I have JSON exported from Cassandra in this format.\r\n\r\n    [\r\n      {\r\n        &quot;correlationId&quot;: &quot;2232845a8556cd3219e46ab8&quot;,\r\n        &quot;leg&quot;: 0,\r\n        &quot;tag&quot;: &quot;received&quot;,\r\n        &quot;offset&quot;: 263128,\r\n        &quot;len&quot;: 30,\r\n        &quot;prev&quot;: {\r\n          &quot;page&quot;: {\r\n            &quot;file&quot;: 0,\r\n            &quot;page&quot;: 0\r\n          },\r\n          &quot;record&quot;: 0\r\n        },\r\n        &quot;data&quot;: &quot;HEAD /healthcheck HTTP/1.1\\r\\n\\r\\n&quot;\r\n      },\r\n      {\r\n        &quot;correlationId&quot;: &quot;2232845a8556cd3219e46ab8&quot;,\r\n        &quot;leg&quot;: 0,\r\n        &quot;tag&quot;: &quot;sent&quot;,\r\n        &quot;offset&quot;: 262971,\r\n        &quot;len&quot;: 157,\r\n        &quot;prev&quot;: {\r\n          &quot;page&quot;: {\r\n            &quot;file&quot;: 10330,\r\n            &quot;page&quot;: 6\r\n          },\r\n          &quot;record&quot;: 1271\r\n        },\r\n        &quot;data&quot;: &quot;HTTP/1.1 200 OK\\r\\nDate: Wed, 14 Feb 2018 12:57:06 GMT\\r\\nServer: \\r\\nConnection: close\\r\\nX-CorrelationID: Id-2232845a8556cd3219e46ab8 0\\r\\nContent-Type: text/xml\\r\\n\\r\\n&quot;\r\n      }]\r\n\r\nI would like to split it to separate documents:\r\n\r\n&gt; {\r\n&gt;         &quot;correlationId&quot;: &quot;2232845a8556cd3219e46ab8&quot;,\r\n&gt;         &quot;leg&quot;: 0,\r\n&gt;         &quot;tag&quot;: &quot;received&quot;,\r\n&gt;         &quot;offset&quot;: 263128,\r\n&gt;         &quot;len&quot;: 30,\r\n&gt;         &quot;prev&quot;: {\r\n&gt;           &quot;page&quot;: {\r\n&gt;             &quot;file&quot;: 0,\r\n&gt;             &quot;page&quot;: 0\r\n&gt;           },\r\n&gt;           &quot;record&quot;: 0\r\n&gt;         },\r\n&gt;         &quot;data&quot;: &quot;HEAD /healthcheck HTTP/1.1\\r\\n\\r\\n&quot;\r\n&gt;       }\r\n\r\nand \r\n\r\n&gt; {\r\n&gt;         &quot;correlationId&quot;: &quot;2232845a8556cd3219e46ab8&quot;,\r\n&gt;         &quot;leg&quot;: 0,\r\n&gt;         &quot;tag&quot;: &quot;sent&quot;,\r\n&gt;         &quot;offset&quot;: 262971,\r\n&gt;         &quot;len&quot;: 157,\r\n&gt;         &quot;prev&quot;: {\r\n&gt;           &quot;page&quot;: {\r\n&gt;             &quot;file&quot;: 10330,\r\n&gt;             &quot;page&quot;: 6\r\n&gt;           },\r\n&gt;           &quot;record&quot;: 1271\r\n&gt;         },\r\n&gt;         &quot;data&quot;: &quot;HTTP/1.1 200 OK\\r\\nDate: Wed, 14 Feb 2018 12:57:06 GMT\\r\\nServer: \\r\\nConnection: close\\r\\nX-CorrelationID:\r\n&gt; Id-2232845a8556cd3219e46ab8 0\\r\\nContent-Type: text/xml\\r\\n\\r\\n&quot;\r\n&gt;       }\r\n\r\nI wanted to use [jq][1] but didn&#39;t find way how. \r\n\r\nCan you please advise way, how to split it by the document separator? \r\n\r\nThanks, Reddy\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/%20JQ",
        "link": "https://stackoverflow.com/questions/48790861/split-json-array-into-separate-files-objects",
        "title": "Split JSON array into separate files/objects"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1518627941,
                "creation_date": 1518627941,
                "answer_id": 48792621,
                "question_id": 48792105,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq &#39;[ .metrics as $m | range(0; $m | length; 2) \r\n          | {($m[.]): $m[(. + 1)]} ] | add&#39; jsonfile\r\nThe output:\r\n\r\n    {\r\n      &quot;solr.core.shard1&quot;: &quot;QUERY./select&quot;,\r\n      &quot;solr.core.shard2&quot;: &quot;QUERY./update&quot;\r\n    }\r\n\r\nhttps://stedolan.github.io/jq/manual/v1.5/#range(upto),range(from;upto)range(from;upto;by)\r\n",
                "title": "Convert even odd index in array to key value pairs in json using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1518628045,
                "creation_date": 1518628045,
                "answer_id": 48792655,
                "question_id": 48792105,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s a helper function which makes the solution trivial:\r\n\r\n    # Emit a stream consisting of pairs of items taken from `stream`\r\n    def pairwise(stream):\r\n      foreach stream as $i ([]; \r\n          if length == 1 then . + [$i] else [$i] end;\r\n          select(length == 2));\r\n\r\nFrom here there are several good options, e.g. we could start with:\r\n\r\n    .metrics\r\n    | [pairwise(.[]) | {(.[0]): .[1]}]\r\n    | add\r\n\r\nWith your input, this produces:\r\n\r\n    {\r\n      &quot;solr.core.shard1&quot;: &quot;QUERY./select&quot;,\r\n      &quot;solr.core.shard2&quot;: &quot;QUERY./update&quot;\r\n    }\r\n\r\nSo you might want to write:\r\n\r\n     .metrics |= ([pairwise(.[]) | {(.[0]): .[1]}] | add)\r\n\r\n",
                "title": "Convert even odd index in array to key value pairs in json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1518628045,
        "creation_date": 1518626395,
        "question_id": 48792105,
        "body_markdown": "I&#39;m trying to use jq to parse Solr 6.5 metrics into key value pairs:\r\n\r\n    {\r\n    &quot;responseHeader&quot;: {\r\n    &quot;status&quot;: 0,\r\n    &quot;QTime&quot;: 7962\r\n    },\r\n    &quot;metrics&quot;: [\r\n    &quot;solr.core.shard1&quot;,\r\n    &quot;QUERY./select&quot;,\r\n    &quot;solr.core.shard2&quot;,\r\n    &quot;QUERY./update&quot;\r\n    ...\r\n    ]\r\n    }\r\n\r\nI&#39;d like to pick even odd entries in metrics array and put them together into a single object as key value pairs like this:\r\n\r\n    { \r\n       &quot;solr.core.shard1&quot;: &quot;QUERY./select&quot;,\r\n       &quot;solr.core.shard2&quot;: &quot;QUERY./update&quot;,\r\n       ...\r\n    }\r\n\r\nTill now, I am only able to come up with: \r\n\r\n    .metrics | to_entries | .[] | {(select(.key % 2 == 0).value): select(.key % 2 == 1).value}\r\n\r\nBut this returns an error or no results.\r\n\r\nI&#39;d be grateful if someone could point me in the right direction. I feel like the answer is probably in the map operator, but I haven&#39;t been able to figure it out.\r\n",
        "link": "https://stackoverflow.com/questions/48792105/convert-even-odd-index-in-array-to-key-value-pairs-in-json-using-jq",
        "title": "Convert even odd index in array to key value pairs in json using jq"
    },
    {
        "tags": [
            "json",
            "key",
            "jq",
            "missing-data"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1518631126,
                "creation_date": 1518631126,
                "answer_id": 48793474,
                "question_id": 48792711,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "One possibility is to use the `?` suffix operator, e.g.\r\n\r\n    .hits.hits[]\r\n    | { products_ids: ._id,\r\n        cat_id: ._source.category.master_category.id? }\r\n\r\nor if you want to be more inclusive:\r\n\r\n    .hits.hits[]\r\n    | { products_ids: ._id,\r\n        cat_id: (._source.category.master_category.id? // null ) }\r\n\r\nYou could also check whether a property exists using `has/1`.\r\n",
                "title": "how to check if an object exists in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1518691297,
        "creation_date": 1518628213,
        "last_edit_date": 1518691297,
        "question_id": 48792711,
        "body_markdown": "I&#39;ve the following Json\r\n\r\n    {\r\n    &quot;_shards&quot;: {\r\n        &quot;failed&quot;: 0\r\n    }, \r\n    &quot;hits&quot;: {\r\n        &quot;hits&quot;: [\r\n            {\r\n                &quot;_id&quot;: &quot;P16296&quot;, \r\n                &quot;_source&quot;: {\r\n                    &quot;category&quot;: {\r\n                        &quot;all_categories&quot;: [\r\n                            {\r\n                                &quot;id&quot;: 76, \r\n                                &quot;name&quot;: &quot;Souris&quot; \r\n                            }\r\n                        ], \r\n                        &quot;master_category&quot;: {\r\n                            &quot;id&quot;: 76, \r\n                            &quot;name&quot;: &quot;Souris&quot; \r\n                        }\r\n                    }\r\n                }\r\n            }, \r\n            {\r\n                &quot;_id&quot;: &quot;P749525&quot;, \r\n                &quot;_source&quot;: {\r\n                    &quot;category&quot;: {\r\n                        &quot;all_categories&quot;: [\r\n                            {\r\n                                &quot;id&quot;: 1301, \r\n                                &quot;name&quot;: &quot;Produits abim\\u00e9s&quot;, \r\n                            }\r\n                        ], \r\n                        &quot;master_category&quot;: []\r\n                    }\r\n                }\r\n            }\r\n        ]\r\n    }\r\n    }\r\n\r\nHi want to get the id and the master cat id so I&#39;m doing this \r\n\r\n    cat test2.json | jq -c &#39;.hits.hits[]|{products_ids: ._id, cat_id: ._source.category.master_category.id}&#39;\r\n\r\nBut unfortunately I get an error :\r\njq: error (at &lt;stdin&gt;:48): Cannot index array with string &quot;id&quot;\r\n\r\nThat&#39;s because for the second hit, there&#39;s no .source.category.master_category.id\r\n\r\nI trye to test it with if then else and .source.category.master_category.id&gt;0 but there&#39;s still teh error. So I need to test if .source.category.master_category.id but I can&#39;t find how to do it. Thanks",
        "link": "https://stackoverflow.com/questions/48792711/how-to-check-if-an-object-exists-in-jq",
        "title": "how to check if an object exists in jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1518788709,
                "last_edit_date": 1518788709,
                "creation_date": 1518692189,
                "answer_id": 48805541,
                "question_id": 48804655,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "### Icing\r\n\r\n&gt;  ... the one where the base_price is the minimum.\r\n\r\nThe following two interpretations of the problem both assume we can take, as the &quot;minimum&quot; item, any of the admissible items that has the minimal value.\r\n\r\n### First Interpretation of the original question\r\n\r\n\r\n    .hits.hits[]._source\r\n    | (.offers_data | min_by(.base_price)) as $min_offers_data\r\n    | .search_result_data\r\n    | {products_ids: .identifiers.id}\r\n      + ($min_offers_data\r\n        | {best_shop_id: .shop_id,\r\n           best_shop_name: .shop_name,\r\n           best_offer_base_price: .base_price})\r\n\r\n### Output:\r\n\r\n    {\r\n      &quot;products_ids&quot;: 32116,\r\n      &quot;best_shop_id&quot;: 2002,\r\n      &quot;best_shop_name&quot;: &quot;TheOtherShop&quot;,\r\n      &quot;best_offer_base_price&quot;: 198.89\r\n    }\r\n\r\n### Second Interpretation\r\nRestrict consideration to .search_result_data.shop.id:\r\n\r\n    .hits.hits[]._source\r\n    | (.search_result_data.shop.id) as $shop\r\n    | (.offers_data | map(select(.shop_id == $shop)) | min_by(.base_price)) as $min_offers_data\r\n    | .search_result_data\r\n    | {products_ids: .identifiers.id}\r\n      + ($min_offers_data\r\n         | {best_shop_id: .shop_id,\r\n            best_shop_name: .shop_name,\r\n            best_offer_base_price: .base_price})\r\n\r\n\r\n### Output\r\n\r\n    {\r\n      &quot;products_ids&quot;: 32116,\r\n      &quot;best_shop_id&quot;: 2247,\r\n      &quot;best_shop_name&quot;: &quot;MainShop&quot;,\r\n      &quot;best_offer_base_price&quot;: 223\r\n    }\r\n\r\n",
                "title": "How to avoid record duplication in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1518788709,
        "creation_date": 1518689610,
        "last_edit_date": 1518692671,
        "question_id": 48804655,
        "body_markdown": "I&#39;ve the following Json :\r\n\r\n    {\r\n    &quot;hits&quot;: {\r\n        &quot;hits&quot;: [\r\n            {\r\n                &quot;_source&quot;: {\r\n                    &quot;offers_data&quot;: [\r\n                        {\r\n                            &quot;base_price&quot;: 198.89, \r\n                            &quot;shop_id&quot;: 2002, \r\n                            &quot;shop_name&quot;: &quot;TheOtherShop&quot;\r\n                        }, \r\n                        {\r\n                            &quot;base_price&quot;: 223, \r\n                            &quot;shop_id&quot;: 2247, \r\n                            &quot;shop_name&quot;: &quot;MainShop&quot;\r\n                        }, \r\n                        {\r\n                            &quot;base_price&quot;: 225, \r\n                            &quot;shop_id&quot;: 2247, \r\n                            &quot;shop_name&quot;: &quot;MainShop&quot;\r\n                        }\r\n                    ], \r\n                    &quot;search_result_data&quot;: {\r\n                        &quot;identifiers&quot;: {\r\n                            &quot;id&quot;: 32116\r\n                        }, \r\n                        &quot;shop&quot;: {\r\n                            &quot;id&quot;: 2247, \r\n                            &quot;name&quot;: &quot;MainShop&quot; \r\n                        } \r\n                    }\r\n                }\r\n            }\r\n        ]\r\n    }\r\n    }\r\n\r\n\r\nI&#39;m writing the following command :\r\n\r\n    jq -c --raw-output &#39;.hits.hits[]|{products_ids: ._source.search_result_data.identifiers.id,\r\n    best_shop_id: ._source.search_result_data.shop.id,\r\n    best_shop_name: (if ._source.search_result_data.shop.id&gt;0 then ._source.search_result_data.shop.id as $shop_id|._source.offers_data[]|select(.shop_id==$shop_id).shop_name else &quot;&quot; end),\r\n    best_offer_base_price: (if ._source.search_result_data.shop.id&gt;0 then ._source.search_result_data.shop.id as $shop_id|._source.offers_data[]|select(.shop_id==$shop_id).base_price else &quot;&quot; end)}&#39;\r\n    \r\n\r\n\r\nand I get this result :\r\n\r\n    {&quot;products_ids&quot;:32116,&quot;best_shop_id&quot;:2247,&quot;best_shop_name&quot;:&quot;MainShop&quot;,&quot;best_offer_base_price&quot;:223}\r\n    {&quot;products_ids&quot;:32116,&quot;best_shop_id&quot;:2247,&quot;best_shop_name&quot;:&quot;MainShop&quot;,&quot;best_offer_base_price&quot;:225}\r\n    {&quot;products_ids&quot;:32116,&quot;best_shop_id&quot;:2247,&quot;best_shop_name&quot;:&quot;MainShop&quot;,&quot;best_offer_base_price&quot;:223}\r\n    {&quot;products_ids&quot;:32116,&quot;best_shop_id&quot;:2247,&quot;best_shop_name&quot;:&quot;MainShop&quot;,&quot;best_offer_base_price&quot;:225}\r\n\r\n\r\nAs you can see I get 2 duplicates : Of course I&#39;ve two offers from MainShop, so it&#39;s normal that I get 2 records, but if I&#39;m also fetching the base prices, the it duplicates the result again. In my real world case I get 32 records instead of 2 legitimate ones, because I&#39;m fetching other fields. So I&#39;d like to avoid this extra duplication each time I fetch a field.\r\n\r\nThe icing on the cake would be to be able to only get one record, the one where amongst Mainshop offers the base_price is the minimum.\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/48804655/how-to-avoid-record-duplication-in-jq",
        "title": "How to avoid record duplication in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1518698430,
                "last_edit_date": 1518698430,
                "creation_date": 1518698057,
                "answer_id": 48807426,
                "question_id": 48806071,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With `jq`&#39;s **`map`** function:\r\n\r\n    jq &#39;.things |= map(.something = [&quot;changed&quot;])&#39; jsonfile\r\n\r\n- `map(x)` - apply specified filter `x` for each item of the input array\r\n- `.something = [&quot;changed&quot;]` - set key `something` to an object with array `[&quot;changed&quot;]` as a value\r\n\r\nThe output:\r\n\r\n    {\r\n      &quot;things&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;lkj&quot;,\r\n          &quot;something&quot;: [\r\n            &quot;changed&quot;\r\n          ],\r\n          &quot;more_data&quot;: &quot;important&quot;,\r\n          &quot;other_stuff&quot;: &quot;very important&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;iou&quot;,\r\n          &quot;different_more_data&quot;: &quot;very important too&quot;,\r\n          &quot;more_different_data&quot;: [\r\n            &quot;even more&quot;\r\n          ],\r\n          &quot;something&quot;: [\r\n            &quot;changed&quot;\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n",
                "title": "Non destructive assignation with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1518768095,
                "last_edit_date": 1518768095,
                "creation_date": 1518764222,
                "answer_id": 48821544,
                "question_id": 48806071,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can simply modify your query so that it looks like:\r\n\r\n     .things[] |= (.something = [&quot;changed&quot;])\r\n\r\nYou can also use `|=` (or one of its siblings, such as `+=`) instead of `=` in the RHS expression, e.g.\r\n\r\n    .things[] |= (.something += [&quot;changed&quot;])\r\n\r\nIf you want to update some, but not all, items, you can still use the above forms. A straightforward approach is to use `if ... then ... else ... end`, for example:\r\n\r\n     .things[] |= (if .name == &quot;lkj&quot; then .something = [&quot;changed&quot;] else . end)\r\n\r\n\r\n### Using `select` on the LHS of `|=`\r\njq (or at least jq since version 1.4) does support the use of `select` on the LHS of `|=`, e.g.\r\n\r\n    (.things[] | select(.name==&quot;lkj&quot;)) |= (.something += [&quot;changed&quot;])\r\n",
                "title": "Non destructive assignation with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1518768095,
        "creation_date": 1518693807,
        "question_id": 48806071,
        "body_markdown": "I got the following data:\r\n\r\n    {\r\n      &quot;things&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;lkj&quot;,\r\n            &quot;something&quot;: [\r\n                &quot;hike&quot;\r\n            ],\r\n            &quot;more_data&quot;: &quot;important&quot;,\r\n            &quot;other_stuff&quot;: &quot;very important&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;iou&quot;,\r\n            &quot;different_more_data&quot;: &quot;very important too&quot;,\r\n            &quot;more_different_data&quot;: [\r\n                &quot;even more&quot;\r\n            ]\r\n        }\r\n      ]\r\n    }\r\n\r\nEach of `things` has an id called &quot;name&quot;, with `jq` I can edit it like:\r\n\r\n    jq &#39;(.things[]) |= {name,something:[&quot;changed&quot;]}&#39;\r\n\r\n    {\r\n      &quot;things&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;lkj&quot;,\r\n            &quot;something&quot;: [\r\n                &quot;changed&quot;\r\n            ]\r\n        },\r\n    ...\r\n\r\nUnfortunately I lose everything not declared in the right hand of the assignation operation.\r\n\r\nIs there a way to make assignations without losing data? So that the result is like this:\r\n\r\n    {\r\n      &quot;things&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;lkj&quot;,\r\n            &quot;something&quot;: [\r\n                &quot;changed&quot;\r\n            ],\r\n            &quot;more_data&quot;: &quot;important&quot;,\r\n            &quot;other_stuff&quot;: &quot;very important&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;iou&quot;,\r\n            &quot;something&quot;: [\r\n                &quot;changed&quot;\r\n            ],\r\n            &quot;different_more_data&quot;: &quot;very important too&quot;,\r\n            &quot;more_different_data&quot;: [\r\n                &quot;even more&quot;\r\n            ]\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48806071/non-destructive-assignation-with-jq",
        "title": "Non destructive assignation with jq"
    },
    {
        "tags": [
            "json",
            "elasticsearch",
            "cassandra",
            "posix",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1518712002,
                "creation_date": 1518712002,
                "answer_id": 48811913,
                "question_id": 48811733,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "While this is valid JSON, you probably need to parse the `data` element of the object.\r\n\r\nIf you would accept python:\r\n\r\n1. write to a file, say `record.json` (for convenience, you can as well use stdin)\r\n2. python (replace file names or use sys.stdin and sys.stdout)\r\n\r\n\r\n\r\n\r\n        import json\r\n        record = json.load(open(&#39;/path/to/record.json&#39;))\r\n        data = json.loads(record[&#39;data&#39;])\r\n        record[&#39;data&#39;] = data\r\n        json.dump(record, open(&quot;/path/to/result.json&quot;, &quot;w&quot;))\r\n\r\n",
                "title": "How to convert JSON subelement strings to real JSON elements in bash"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1518768381,
                "last_edit_date": 1518768381,
                "creation_date": 1518720043,
                "answer_id": 48814191,
                "question_id": 48811733,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To convert the .data element from a JSON string into a JSON object, you could use the filter:\r\n\r\n    .data |= fromjson\r\n\r\nIf you just want to extract the .data element and convert it, you could use the filter:\r\n\r\n    .data | fromjson\r\n\r\nFor example: `jq -c &#39;.data|fromjson&#39; data.json`\r\n\r\n### Supplemental question\r\n\r\nIf it is uncertain whether or not `fromjson` will succeed, you could use the idiom: `fromjson? // .`, e.g.:\r\n\r\n    .data |= (fromjson? // .)\r\n",
                "title": "How to convert JSON subelement strings to real JSON elements in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1518768381,
        "creation_date": 1518711503,
        "last_edit_date": 1518712074,
        "question_id": 48811733,
        "body_markdown": "I have JSON message exported from Cassandra which I would like to load into Elastic as structured document:\r\n\r\n    {\r\n      &quot;correlationId&quot;: &quot;fb8f855a0eac8985d430896d&quot;,\r\n      &quot;leg&quot;: 65535,\r\n      &quot;tag&quot;: &quot;circuitpath&quot;,\r\n      &quot;offset&quot;: 479306,\r\n      &quot;len&quot;: 508,\r\n      &quot;prev&quot;: {\r\n        &quot;page&quot;: {\r\n          &quot;file&quot;: 10342,\r\n          &quot;page&quot;: 8\r\n        },\r\n        &quot;record&quot;: 216\r\n      },\r\n      &quot;data&quot;: &quot;[ { \\&quot;policy\\&quot;: \\&quot;Health Check\\&quot;, \\&quot;execTime\\&quot;: 0, \\&quot;filters\\&quot;: [  { \\&quot;espk\\&quot;: \\&quot;DEFAULT_PRIMARY_VordelGateway_7.4.0:223\\&quot;, \\&quot;name\\&quot;: \\&quot;Set Message\\&quot;, \\&quot;type\\&quot;: \\&quot;ChangeMessageFilter\\&quot;, \\&quot;class\\&quot;: \\&quot;com.vordel.circuit.conversion.ChangeMessageFilter\\&quot;, \\&quot;status\\&quot;: \\&quot;Pass\\&quot;, \\&quot;filterTime\\&quot;: 1518702587006, \\&quot;execTime\\&quot;: 0 } , { \\&quot;espk\\&quot;: \\&quot;DEFAULT_PRIMARY_VordelGateway_7.4.0:222\\&quot;, \\&quot;name\\&quot;: \\&quot;Reflect\\&quot;, \\&quot;type\\&quot;: \\&quot;ReflectFilter\\&quot;, \\&quot;class\\&quot;: \\&quot;com.vordel.circuit.net.ReflectFilter\\&quot;, \\&quot;status\\&quot;: \\&quot;Pass\\&quot;, \\&quot;filterTime\\&quot;: 1518702587006, \\&quot;execTime\\&quot;: 0 }  ] } ]&quot;\r\n    }\r\n\r\nBut I do not know how by simply way I could convert the &quot;data&quot; content to format which will allow to load it into Elastic. \r\n\r\nI have tried following method where $json is the message above:\r\n\r\n    json2=&quot;${json//\\\\\\&quot;/\\&quot;}&quot;\r\n    json2=&quot;${json2//\\\\\\\\/\\\\}&quot;\r\n    echo &quot;$json2&quot;\r\nthe &quot;data&quot; element then seems like:\r\n\r\n    &quot;data&quot;:&quot;[ { &quot;policy&quot;: &quot;Health Check&quot;, &quot;execTime&quot;: 0, &quot;filters&quot;: [ { &quot;espk&quot;: &quot;DEFAULT_PRIMARY_VordelGateway_7.4.0:223&quot;, &quot;name&quot;: &quot;Set Message&quot;, &quot;type&quot;: &quot;ChangeMessageFilter&quot;, &quot;class&quot;: &quot;com.vordel.circuit.conversion.ChangeMessageFilter&quot;, &quot;status&quot;: &quot;Pass&quot;, &quot;filterTime&quot;: 1518709297006, &quot;execTime&quot;: 0 } , { &quot;espk&quot;: &quot;DEFAULT_PRIMARY_VordelGateway_7.4.0:222&quot;, &quot;name&quot;: &quot;Reflect&quot;, &quot;type&quot;: &quot;ReflectFilter&quot;, &quot;class&quot;: &quot;com.vordel.circuit.net.ReflectFilter&quot;, &quot;status&quot;: &quot;Pass&quot;, &quot;filterTime&quot;: 1518709297006, &quot;execTime&quot;: 0 } ] } ]&quot;\r\n\r\nbut loader is telling me \r\n\r\n&gt; &quot;status&quot;:400,&quot;error&quot;:{&quot;type&quot;:&quot;mapper_parsing_exception&quot;,&quot;reason&quot;:&quot;failed\r\n&gt; to\r\n&gt; parse&quot;,&quot;caused_by&quot;:{&quot;type&quot;:&quot;json_parse_exception&quot;,&quot;reason&quot;:&quot;Unexpected\r\n&gt; character (&#39;p&#39; (code 112)): was expecting comma to separate OBJECT\r\n&gt; entries\\n at [Source:\r\n&gt; org.elasticsearch.common.io.stream.InputStreamStreamInput@3508edee;\r\n&gt; line: 1, column: 170\r\n\r\nIt seems like it has problem with letter &quot;p&quot; in the first sub-sub-element name &quot;policy&quot;\r\n\r\nAny idea how to get it into Elastic? ",
        "link": "https://stackoverflow.com/questions/48811733/how-to-convert-json-subelement-strings-to-real-json-elements-in-bash",
        "title": "How to convert JSON subelement strings to real JSON elements in bash"
    },
    {
        "tags": [
            "json",
            "database",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1518747780,
                "last_edit_date": 1518747780,
                "creation_date": 1518747398,
                "answer_id": 48819205,
                "question_id": 48817992,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you want CSV then you could of course simply use the `@csv` filter, but `@csv` converts `null` to an empty field:\r\n\r\n    &quot;removedforprivacy@gmail.com&quot;,&quot;john&quot;,&quot;smith&quot;,,,&quot;123 road st&quot;,,&quot;Columbia&quot;,&quot;29203&quot;,&quot;SC&quot;,\r\n\r\nTo handle strings and `null` the way you seem to want, you could use `@tsv` as follows in conjunction with the -r command-line option:\r\n\r\n    map(if type == &quot;string&quot; then &quot;\\&quot;\\(.)\\&quot;&quot; else &quot;null&quot; end)\r\n    | @tsv | gsub(&quot;\\t&quot;;&quot;,&quot;) \r\n\r\nWith your input, this produces:\r\n\r\n    &quot;removedforprivacy@gmail.com&quot;,&quot;john&quot;,&quot;smith&quot;,null,null,&quot;123 road st&quot;,null,&quot;Columbia&quot;,&quot;29203&quot;,&quot;SC&quot;,null\r\n\r\nFor other variations, you may wish to use `join/1` and/or the -j command-line option.\r\n\r\n### The -c command-line option\r\nAs the manual states:\r\n\r\n&gt; Using this option will result in more compact output by instead putting each JSON object on a single line.\r\n\r\nHere &quot;JSON object&quot; means &quot;JSON entity&quot;.\r\n",
                "title": "JQ -c / --compact-output not working properly? Json Parsing"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1672735777,
        "creation_date": 1518737787,
        "last_edit_date": 1672735777,
        "question_id": 48817992,
        "body_markdown": "I was just introduced to JQ in a question I posted about an hour ago, I&#39;m parsing a very large database however, with JQ the output looks like this:   \r\n\r\n    &quot;removedforprivacy@gmail.com&quot;  \r\n    &quot;john&quot;  \r\n    &quot;smith&quot;  \r\n    null  \r\n    null  \r\n    &quot;123 road st&quot;  \r\n    null  \r\n    &quot;Columbia&quot;  \r\n    &quot;29203&quot;  \r\n    &quot;SC&quot;  \r\n    null  \r\n   \r\ninstead I want it to look like this: \r\n    \r\n    &quot;removedforprivacy@gmail.com&quot; &quot;john&quot; &quot;smith&quot; null null &quot;123 road st&quot; null &quot;Columbia&quot; &quot;29203&quot; &quot;SC&quot; null\r\n\r\nor even better: \r\n\r\n    &quot;removedforprivacy@gmail.com&quot;,&quot;john&quot;,&quot;smith&quot;,null,null,&quot;123,road,st&quot;,null,&quot;Columbia&quot;,&quot;29203&quot;,&quot;SC&quot;,null\r\n\r\nI&#39;m currently using this command: \r\n\r\n    jq -c &#39;(.email, .first_name, .last_name, .ip, .address, .address1, .address2, .city, .zip, .state, .phone)&#39; file.json &gt; file2.json \r\n\r\nI&#39;ve tried using this command as well: \r\n\r\n    jq -compact-output &#39;(.email, .first_name, .last_name, .ip, .address, .address1, .address2, .city, .zip, .state, .phone)&#39; file.json &gt; file2.json \r\n\r\nbut file2.json still shows data like this: \r\n\r\n    &quot;removedforprivacy@gmail.com&quot;  \r\n    &quot;john&quot;  \r\n    &quot;smith&quot;  \r\n    null  \r\n    null  \r\n    &quot;123 road st&quot;  \r\n    null  \r\n    &quot;Columbia&quot;  \r\n    &quot;29203&quot;  \r\n    &quot;SC&quot;  \r\n    null  \r\n\r\nIn short, I&#39;d like to turn the output into something that looks like a csv or is a csv so I can manage it better. \r\n\r\nThe command isn&#39;t working and just need this command for a one time use.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48817992/jq-c-compact-output-not-working-properly-json-parsing",
        "title": "JQ -c / --compact-output not working properly? Json Parsing"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1518760716,
                "last_edit_date": 1518760716,
                "creation_date": 1518759927,
                "answer_id": 48820768,
                "question_id": 48820138,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "First, let&#39;s define a filter that will tell if an item in the array has been &quot;undone&quot; by a subsequent (in the array and in time) item.  This is straightforward to do using `any/2`:\r\n\r\n    # input: the entire array\r\n    # output: true iff item n is &quot;undone&quot; by a subsequent item\r\n    def undone($n):\r\n      . as $in\r\n      | length as $length\r\n      | .[$n] as $nth\r\n      | if $nth.type != &quot;ITEM_PURCHASED&quot; then false\r\n        else any( range($n+1; $length) | $in[.]; \r\n                  .type == &quot;ITEM_UNDO&quot;\r\n                  and .participantId == $nth.participantId\r\n                  and .beforeId== $nth.itemId\r\n                  and .timestamp &gt; $nth.timestamp)\r\n        end;\r\n\r\n  \r\nNow the query is quite straightforward:  \r\n    \r\n    [ range(0;length) as $i\r\n      | select( (.[$i].type == &quot;ITEM_PURCHASED&quot;) and (undone($i) | not) )\r\n      | .[$i] ]\r\n\r\nInvocation: jq -f program.jq data.json\r\n\r\nOutput: an array with the three items.\r\n\r\n### Style\r\nOne can write:\r\n\r\n    range($n+1; $length) | $in[.]\r\n\r\nmore compactly, and perhaps more idiomatically, as:\r\n\r\n    $in[range($n+1; $length)]\r\n\r\nIn fact, both `$in` and `$length` can be dispensed with altogether, so the snippet in question would become simply:\r\n\r\n    .[range($n+1; length)]\r\n\r\n",
                "title": "jq: Remove items from array that match a condition based on other items in the same array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1518760716,
        "creation_date": 1518755735,
        "question_id": 48820138,
        "body_markdown": "I need help with a somewhat complex jq query.\r\n\r\nGiven\r\n\r\n    [{\r\n      &quot;type&quot;: &quot;ITEM_PURCHASED&quot;,\r\n      &quot;timestamp&quot;: 1710829,\r\n      &quot;participantId&quot;: 2,\r\n      &quot;itemId&quot;: 3089\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;ITEM_PURCHASED&quot;,\r\n      &quot;timestamp&quot;: 1711620,\r\n      &quot;participantId&quot;: 7,\r\n      &quot;itemId&quot;: 2055\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;ITEM_PURCHASED&quot;,\r\n      &quot;timestamp&quot;: 1711621,\r\n      &quot;participantId&quot;: 7,\r\n      &quot;itemId&quot;: 1058\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;ITEM_PURCHASED&quot;,\r\n      &quot;timestamp&quot;: 1714435,\r\n      &quot;participantId&quot;: 9,\r\n      &quot;itemId&quot;: 1037\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;ITEM_UNDO&quot;,\r\n      &quot;timestamp&quot;: 1716107,\r\n      &quot;participantId&quot;: 7,\r\n      &quot;afterId&quot;: 0,\r\n      &quot;beforeId&quot;: 2055\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;ITEM_UNDO&quot;,\r\n      &quot;timestamp&quot;: 1716272,\r\n      &quot;participantId&quot;: 7,\r\n      &quot;afterId&quot;: 0,\r\n      &quot;beforeId&quot;: 1058\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;ITEM_PURCHASED&quot;,\r\n      &quot;timestamp&quot;: 1718091,\r\n      &quot;participantId&quot;: 7,\r\n      &quot;itemId&quot;: 1026\r\n    }]\r\n\r\nDesired output:\r\n\r\n    [{\r\n      &quot;type&quot;: &quot;ITEM_PURCHASED&quot;,\r\n      &quot;timestamp&quot;: 1710829,\r\n      &quot;participantId&quot;: 2,\r\n      &quot;itemId&quot;: 3089\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;ITEM_PURCHASED&quot;,\r\n      &quot;timestamp&quot;: 1714435,\r\n      &quot;participantId&quot;: 9,\r\n      &quot;itemId&quot;: 1037\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;ITEM_PURCHASED&quot;,\r\n      &quot;timestamp&quot;: 1718091,\r\n      &quot;participantId&quot;: 7,\r\n      &quot;itemId&quot;: 1026\r\n    }]\r\n\r\nI would like to filter this array and remove all the purchased items that were &quot;undone&quot;.\r\nA PURCHASE_ITEM object can be undone by adding an ITEM_UNDONE object after it with a higher timestamp, a matching participantId and beforeId==itemId.\r\n\r\nI tried the following approach:\r\n\r\n 1. Collect all the ITEM_UNDO objects\r\n 2. Find all corresponding ITEM_PURCHASED objects\r\n 3. Subtract both from the original list\r\n\r\nStep 2 is giving me trouble.\r\nI have the following code so far which does not work:\r\n\r\n    jq &#39;\r\n    map(select(.type==&quot;ITEM_UNDO&quot;)) as $undos |\r\n     [\r\n        {\r\n          undo: $undos[],\r\n          before_purchases: map( select(.type==&quot;ITEM_PURCHASED&quot;\r\n                                        and .itemId == $undos[].beforeId\r\n                                        and .participantId == $undos[].participantId\r\n                                        )\r\n    \r\n                               )\r\n        }\r\n      ] as $undo_with_purchased | $undo_with_purchased\r\n    &#39;\r\n\r\nI know why it doesn&#39;t work because in the line\r\n\r\n    and .itemId == $undos[].beforeId\r\n    and .participantId == $undos[].participantId\r\n\r\n$undos is expanded twice independently rather than using the same instance for every comparison and then a third time in\r\n\r\n    undo: $undos[],\r\n\r\nI can&#39;t seem to find a good way to force jq to iterate over $undos only once and use the same instance for all comparisons. In general I&#39;m having issues iterating over multiple arrays at the same time, performing operations. This would be a no brainer in any procedural language but what&#39;s the best way to do this kind of stuff in jq?\r\n\r\nThanks for any suggestions!\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48820138/jq-remove-items-from-array-that-match-a-condition-based-on-other-items-in-the-s",
        "title": "jq: Remove items from array that match a condition based on other items in the same array"
    },
    {
        "tags": [
            "json",
            "posix",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1518788027,
                "creation_date": 1518788027,
                "answer_id": 48827958,
                "question_id": 48826688,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It seems you want:\r\n\r\n    .data |= { message: .}",
                "title": "How to move value of JSON element into subelement using bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1518788027,
        "creation_date": 1518783753,
        "question_id": 48826688,
        "body_markdown": "I have an interesting problem. \r\nI have this document:\r\n\r\n    {\r\n      &quot;correlationId&quot;: &quot;6298865a73b477106c98d021&quot;,\r\n      &quot;leg&quot;: 0,\r\n      &quot;tag&quot;: &quot;sent&quot;,\r\n      &quot;offset&quot;: 322858,\r\n      &quot;len&quot;: 178,\r\n      &quot;prev&quot;: {\r\n        &quot;page&quot;: {\r\n          &quot;file&quot;: 10352,\r\n          &quot;page&quot;: 2\r\n        },\r\n        &quot;record&quot;: 911\r\n      },\r\n      &quot;data&quot;: &quot;HTTP/1.1 403 Forbidden\\r\\nDate: Fri, 16 Feb 2018 08:37:54 GMT\\r\\nServer: \\r\\nConnection: close\\r\\nX-CorrelationID: Id-6298865a73b477106c98d021 0\\r\\nContent-Type: text/html\\r\\n\\r\\nAccess Denied&quot;\r\n    }\r\n\r\nBut because the &quot;data&quot; element could contain also regular JSON object I would like to move the value \r\n\r\n&gt; &quot;HTTP/1.1 403 Forbidden\\r\\nDate: Fri, 16 Feb 2018 08:37:54\r\n&gt; GMT\\r\\nServer: \\r\\nConnection: close\\r\\nX-CorrelationID:\r\n&gt; Id-6298865a73b477106c98d021 0\\r\\nContent-Type: text/html\\r\\n\\r\\nAccess\r\n&gt; Denied&quot;\r\n\r\ninto `&quot;data&quot;: { &quot;message&quot;: &quot;HTTP/1.1 403 Forbidden\\r\\nDate: Fri, 16 Feb 2018 08:37:54 GMT\\r\\nServer: \\r\\nConnection: close\\r\\nX-CorrelationID: Id-6298865a73b477106c98d021 0\\r\\nContent-Type: text/html\\r\\n\\r\\nAccess Denied&quot;}` structure. \r\n\r\nI tried to find a solution with jq but I didn&#39;t found any filter which would move it. \r\n\r\nAny idea please? \r\n\r\n",
        "link": "https://stackoverflow.com/questions/48826688/how-to-move-value-of-json-element-into-subelement-using-bash",
        "title": "How to move value of JSON element into subelement using bash"
    },
    {
        "tags": [
            "json",
            "path",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2247163,
                    "reputation": 4651,
                    "user_id": 7417402,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0362a30046be9244cf62d2a9fc6f8568?s=256&d=identicon&r=PG",
                    "display_name": "Devstr",
                    "link": "https://stackoverflow.com/users/7417402/devstr"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1518787893,
                "post_id": 48827898,
                "comment_id": 84659425,
                "content_license": "CC BY-SA 3.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": 1518789037,
                "post_id": 48827898,
                "comment_id": 84660142,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1518788467,
                "last_edit_date": 1518788467,
                "creation_date": 1518788099,
                "answer_id": 48827983,
                "question_id": 48827898,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You cannot use integer indices as keys in the JSON object. For JSON objects, the key must be a string, so you could write:\r\n\r\n    jq &#39;setpath([&quot;0&quot;,&quot;a&quot;]; 1)&#39;  &lt; test.json\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;correlationId&quot;: &quot;6298865a73b477106c98d021&quot;,\r\n      &quot;leg&quot;: 0,\r\n      &quot;tag&quot;: &quot;sent&quot;,\r\n      &quot;offset&quot;: 322858,\r\n      &quot;len&quot;: 178,\r\n      &quot;prev&quot;: {\r\n        &quot;page&quot;: {\r\n          &quot;file&quot;: 10352,\r\n          &quot;page&quot;: 2\r\n        },\r\n        &quot;record&quot;: 911\r\n      },\r\n      &quot;data&quot;: &quot;HTTP/1.1 403 Forbidden\\r\\nDate: Fri, 16 Feb 2018 08:37:54 GMT\\r\\nServer: \\r\\nConnection: close\\r\\nX-CorrelationID: Id-6298865a73b477106c98d021 0\\r\\nContent-Type: text/html\\r\\n\\r\\nAccess Denied&quot;,\r\n      &quot;0&quot;: {\r\n        &quot;a&quot;: 1\r\n      }\r\n    }",
                "title": "jq - setpath - Cannot index object with number"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1518836199,
        "creation_date": 1518787810,
        "last_edit_date": 1518836199,
        "question_id": 48827898,
        "body_markdown": "I would like to add new path into existing document\r\n\r\n    ./jq  &lt; test.json\r\n    {\r\n      &quot;correlationId&quot;: &quot;6298865a73b477106c98d021&quot;,\r\n      &quot;leg&quot;: 0,\r\n      &quot;tag&quot;: &quot;sent&quot;,\r\n      &quot;offset&quot;: 322858,\r\n      &quot;len&quot;: 178,\r\n      &quot;prev&quot;: {\r\n        &quot;page&quot;: {\r\n          &quot;file&quot;: 10352,\r\n          &quot;page&quot;: 2\r\n        },\r\n        &quot;record&quot;: 911\r\n      },\r\n      &quot;data&quot;: &quot;HTTP/1.1 403 Forbidden\\r\\nDate: Fri, 16 Feb 2018 08:37:54 GMT\\r\\nServer: \\r\\nConnection: close\\r\\nX-CorrelationID: Id-6298865a73b477106c98d021 0\\r\\nContent-Type: text/html\\r\\n\\r\\nAccess Denied&quot;\r\n    }\r\n\r\nI am using filter **setpath** described in jq manual. \r\nBut even if I copied the documented string \r\n\r\n    ./jq &#39;setpath([0,&quot;a&quot;]; 1)&#39;  &lt; test.json\r\n\r\nstill getting error:\r\n\r\n    jq: error (at &lt;stdin&gt;:1): Cannot index object with number\r\n\r\nI do not see there any syntax issue. Did I overlooked something? \r\n\r\nRegards and thanks, Reddy",
        "link": "https://stackoverflow.com/questions/48827898/jq-setpath-cannot-index-object-with-number",
        "title": "jq - setpath - Cannot index object with number"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1518886635,
                "creation_date": 1518886635,
                "answer_id": 48843692,
                "question_id": 48843494,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "When it comes to manipulations involving the keys of JSON objects, `to_entries` (and its friend, `with_entries`) are your friends:\r\n\r\n    map(to_entries[] | {(.key): .value})\r\n\r\nNote also the parentheses around `.key`.",
                "title": "How to convert objects to array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1518886635,
        "creation_date": 1518885429,
        "question_id": 48843494,
        "body_markdown": "I would like to transform with jq this JSON\r\n\r\n    [\r\n      {\r\n        &quot;one&quot;: 37,\r\n        &quot;two&quot;: &quot;2017-09-15T19:31:55&quot;\r\n      }\r\n    ]\r\n\r\nto this one\r\n\r\n    [\r\n      {\r\n        &quot;one&quot;: 37\r\n      },\r\n      {\r\n        &quot;two&quot;: &quot;2017-09-15T19:31:55&quot;\r\n      }\r\n    ]\r\n\r\nHow to do it?\r\n\r\nThank you",
        "link": "https://stackoverflow.com/questions/48843494/how-to-convert-objects-to-array-with-jq",
        "title": "How to convert objects to array with jq"
    },
    {
        "tags": [
            "json",
            "path",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1519024686,
                "last_edit_date": 1519024686,
                "creation_date": 1518922775,
                "answer_id": 48848033,
                "question_id": 48847742,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The (or at least a) short answer is:\r\n\r\n    .system.svcs.upsvcs[0].credentials.Date\r\n\r\nWithout a schema, it is often a bit tricky to get the exact path correctly, so you might want to consider using the jq filter `paths`.  In your case:\r\n\r\n     $ jq -c paths input.json | grep Date\r\n     [&quot;system&quot;,&quot;svcs&quot;,&quot;upsvcs&quot;,0,&quot;credentials&quot;,&quot;Date&quot;]\r\n\r\nYou could also use this path (i.e., the above array) directly:\r\n\r\n    $ jq &#39;getpath([&quot;system&quot;,&quot;svcs&quot;,&quot;upsvcs&quot;,0,&quot;credentials&quot;,&quot;Date&quot;])&#39; input.json\r\n    &quot;Feb152018&quot;\r\n\r\nand thus you could use a &quot;path-free&quot; query:\r\n\r\n    $ jq --argjson p $(jq -c paths input.json | grep --max 1 Date) &#39;getpath($p)&#39; input.json\r\n    &quot;Feb152018&quot;\r\n\r\n\r\nAnother approach would be just to retrieve all “truthy” `.Date` values, no matter where they appear:\r\n\r\n    $ jq -c &#39;.. | .Date? // empty&#39; input.json\r\n    &quot;Feb152018&quot;\r\n\r\n### select\r\nSince you mentioned `select`, please note that:\r\n\r\n    $ jq -c &#39;.. | select(.Date?)&#39; input.json\r\n    {&quot;Date&quot;:&quot;Feb152018&quot;,&quot;time&quot;:&quot;1330&quot;}\r\n\r\n### Further information\r\nFor further information about jq in general and the topic of retrieval in particular, see the online tutorial, manual, and FAQ:\r\n\r\n* https://stedolan.github.io/jq/tutorial/\r\n* https://stedolan.github.io/jq/manual/v1.5/\r\n* https://github.com/stedolan/jq/wiki/FAQ",
                "title": "Getting output using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1519024757,
        "creation_date": 1518919092,
        "last_edit_date": 1519024757,
        "question_id": 48847742,
        "body_markdown": "I have the following JSON outp\r\n\r\n    {  \r\n        &quot;environment&quot;: {  \r\n            &quot;reg&quot;: &quot;abc&quot;  \r\n        },  \r\n        &quot;system&quot;: {  \r\n            &quot;svcs&quot;: {  \r\n            &quot;upsvcs&quot;: [  \r\n            {  \r\n                &quot;name&quot;: &quot;monitor&quot;,  \r\n                &quot;tags&quot;: [],  \r\n                &quot;vmnts&quot;: [],  \r\n                &quot;label&quot;: &quot;upsvcs&quot;,  \r\n                &quot;credentials&quot;: {  \r\n                    &quot;Date&quot;: &quot;Feb152018&quot;,  \r\n                    &quot;time&quot;: &quot;1330&quot;   \r\n                }  \r\n            },  \r\n            {  \r\n                &quot;name&quot;: &quot;application&quot;,  \r\n                &quot;tags&quot;: [],  \r\n                &quot;vmnts&quot;: [],  \r\n                &quot;label&quot;: &quot;upsvcs&quot;,  \r\n                &quot;credentials&quot;: {  \r\n                &quot;lastViewed&quot;: &quot;2018-02-07&quot;  \r\n                }  \r\n            }  \r\n            ]  \r\n        }  \r\n    }  \r\nand to retrieve Date value (from credentials). I have tried `curl xxx | jq -r &#39;. | select (.Date)&#39; \r\n\r\nwhich is not returning any value. Can someone please let me know what is the correct syntax and any explanation on how to retrieve elements (or any articles that do so).\r\n\r\nTIA\r\n",
        "link": "https://stackoverflow.com/questions/48847742/getting-output-using-jq",
        "title": "Getting output using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "amazon-web-services",
            "jq",
            "credstash"
        ],
        "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": 1,
                "creation_date": 1518952151,
                "post_id": 48850819,
                "comment_id": 84705343,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1206428,
                    "reputation": 4506,
                    "user_id": 1175948,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://www.gravatar.com/avatar/bb6f9ef4e70a3c2aa4b1c0fa6d614e4e?s=256&d=identicon&r=PG",
                    "display_name": "Mrk Fldig",
                    "link": "https://stackoverflow.com/users/1175948/mrk-fldig"
                },
                "reply_to_user": {
                    "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": 0,
                "creation_date": 1518952531,
                "post_id": 48850819,
                "comment_id": 84705435,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "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": 0,
                "creation_date": 1518952785,
                "post_id": 48850819,
                "comment_id": 84705496,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1206428,
                    "reputation": 4506,
                    "user_id": 1175948,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://www.gravatar.com/avatar/bb6f9ef4e70a3c2aa4b1c0fa6d614e4e?s=256&d=identicon&r=PG",
                    "display_name": "Mrk Fldig",
                    "link": "https://stackoverflow.com/users/1175948/mrk-fldig"
                },
                "reply_to_user": {
                    "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": 0,
                "creation_date": 1518953126,
                "post_id": 48850819,
                "comment_id": 84705578,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1518977237,
                "last_edit_date": 1518977237,
                "creation_date": 1518961126,
                "answer_id": 48852290,
                "question_id": 48850819,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`bash`** + **`jq`** solution:\r\n\r\n    while read -r key val; do \r\n        declare -x &quot;$key&quot;=&quot;$val&quot;\r\n    done &lt; &lt;(jq -r &#39;to_entries[] | [(.key | gsub(&quot;\\\\.&quot;;&quot;_&quot;)), .value] | @tsv&#39; &lt;&lt;&lt;&quot;$creds&quot;)\r\n\r\nCheck declared variable:\r\n\r\n    $ echo &quot;$db_username&quot;\r\n    Some username\r\n\r\n\r\n",
                "title": "Bash export credstash values from script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1518977237,
        "creation_date": 1518951082,
        "last_edit_date": 1518953132,
        "question_id": 48850819,
        "body_markdown": "So i&#39;m trying to implement a build script that pulls down our credstash keys from DynamoDB and then sets them in the environment running the script, I need to the commands afterward to have access to those environment variables to compile some YML.\r\n\r\nHere&#39;s what I have(kinda working):\r\n\r\n        #!/bin/bash\r\n        \r\n        creds=$(credstash getall)\r\n        declare -a arrayKeys=($(echo $creds | ./jq &#39;[to_entries[] | .key]&#39; | tr &#39;,&#39; &#39;\\n&#39;))\r\n        \r\n        for ((i=1; i&lt;(${#arrayKeys[*]} -1); i++));\r\n        do\r\n           key=$( printf &#39;%s:&#39; &quot;${arrayKeys[i]}&quot; )\r\n           key=${key%:}\r\n    \r\n          export key=&quot;foo&quot;\r\n        done\r\n\r\nThis actually seems to run through but when I do printenv after I don&#39;t see the keys that I&#39;m after, note I&#39;m setting them to the value foo just to get the iterator stuff working, when this is finished it&#39;ll use JQ to pull the value from the JSON I fetched earlier.\r\n\r\nSample JSON:\r\n\r\n    {\r\n    &quot;db.password&quot; : &quot;Some password&quot;,\r\n    &quot;db.username&quot; : &quot;Some username&quot;\r\n    }\r\n\r\nNote, as you might be able to tell, I&#39;m no bash scripting expert so this what I&#39;ve cobbled together after doing a bit of reading.\r\n\r\nEDIT\r\n\r\nSo after the comments below I&#39;ve now got:\r\n\r\n    #!/bin/bash\r\n    \r\n    creds=$(credstash getall)\r\n    declare -a arrayKeys=($(echo $creds | ./jq --raw-output &#39;[to_entries[] | .key]&#39; | tr &#39;,&#39; &#39;\\n&#39;))\r\n    \r\n    for ((i=1; i&lt;(${#arrayKeys[*]} -1); i++));\r\n    do\r\n       key=$( printf &#39;%s:&#39; &quot;${arrayKeys[i]}&quot; )\r\n       key=${key%:}\r\n       export eval $key=&#39;foo&#39;\r\n    done\r\n\r\nWhich yields:\r\n\r\n    bash: export: `&quot;db.username&quot;=foo&#39;: not a valid identifier",
        "link": "https://stackoverflow.com/questions/48850819/bash-export-credstash-values-from-script",
        "title": "Bash export credstash values from script"
    },
    {
        "tags": [
            "json",
            "windows",
            "cmd",
            "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": 0,
                "creation_date": 1519044028,
                "post_id": 48865921,
                "comment_id": 84735954,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user7094359"
                },
                "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": 1519044324,
                "post_id": 48865921,
                "comment_id": 84736132,
                "content_license": "CC BY-SA 3.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": 1519045260,
                "post_id": 48865921,
                "comment_id": 84736715,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1519081067,
                "last_edit_date": 1519081067,
                "creation_date": 1519045079,
                "answer_id": 48866768,
                "question_id": 48865921,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Adapting your query:\r\n \r\n    .profiles |= walk( if type == &quot;object&quot; and has(&quot;gameDir&quot;)\r\n                       then .gameDir |=\r\n                         (if type == &quot;null&quot; then &quot;&quot; else . end\r\n                         | scan(&quot;{REPLACE}.*&quot;) | sub(&quot;{REPLACE}&quot;; &quot;{REPLACESTRINGHERE}&quot;))\r\n                       else . \r\n                       end )\r\n\r\n(This can easily be tweaked for greater efficiency.)\r\n\r\nIf your jq does not have `walk`, you can google it (jq “def walk”) or snarf its def from the jq FAQ https://github.com/stedolan/jq/wiki/FAQ\r\n\r\n\r\n### walk-free approach\r\nFor the record, here&#39;s an illustration of a walk-free approach using `paths`.  The following also makes some changes in the computation of the replacement string -- notably it eliminates the use of `scan` -- so it is not logically equivalent, but is likely to be more useful as well as more efficient.\r\n\r\n\r\n    .profiles |= \r\n       ( . as $in\r\n       | reduce (paths | select(.[-1] == &quot;gameDir&quot;)) as $path ($in;\r\n           ($in | getpath($path)\r\n    \t    | if type == &quot;null&quot; then &quot;&quot;\r\n                  else sub(&quot;.*{REPLACE}&quot;; &quot;{REPLACESTRINGHERE}&quot;)\r\n                  end) as $value\r\n           | setpath($path; $value) ))\r\n       \r\n",
                "title": "How to print out the top-level json after modification of descendants"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1519081067,
        "creation_date": 1519042129,
        "last_edit_date": 1519079184,
        "question_id": 48865921,
        "body_markdown": "Hello i managed to create this jq filter `.profiles | recurse | .gameDir? |  if type == &quot;null&quot; then &quot;&quot; else . end | scan(&quot;{REPLACE}.*&quot;) | sub(&quot;{REPLACE}&quot;; &quot;{REPLACESTRINGHERE}&quot;)`. it succesfully replaces what i want (checked at jqplay.org) but now i&#39;d like to print the full json and not just the modified strings",
        "link": "https://stackoverflow.com/questions/48865921/how-to-print-out-the-top-level-json-after-modification-of-descendants",
        "title": "How to print out the top-level json after modification of descendants"
    },
    {
        "tags": [
            "json",
            "bash",
            "awk",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1619313,
                    "reputation": 2734,
                    "user_id": 1496234,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c4338445fd759964cb9d3812b3e95203?s=256&d=identicon&r=PG",
                    "display_name": "liborm",
                    "link": "https://stackoverflow.com/users/1496234/liborm"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1519083230,
                "post_id": 48875623,
                "comment_id": 84755451,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 12980604,
                    "reputation": 1,
                    "user_id": 9383166,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1123deb7294ecf6916a91e2d0429ae31?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "R Carrier",
                    "link": "https://stackoverflow.com/users/9383166/r-carrier"
                },
                "reply_to_user": {
                    "account_id": 1619313,
                    "reputation": 2734,
                    "user_id": 1496234,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c4338445fd759964cb9d3812b3e95203?s=256&d=identicon&r=PG",
                    "display_name": "liborm",
                    "link": "https://stackoverflow.com/users/1496234/liborm"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1519090466,
                "post_id": 48875623,
                "comment_id": 84757359,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1519112247,
                "last_edit_date": 1519112247,
                "creation_date": 1519100902,
                "answer_id": 48877865,
                "question_id": 48875623,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You&#39;re almost there.  Since you&#39;re using `input` and `inputs` (which is definitely the right approach here), you don&#39;t want to &quot;slurp&quot; the file.\r\n\r\n    jq  -nrR &#39;\r\n     ( input  | split(&quot;|&quot;) ) as $keys\r\n     | ( inputs | split(&quot;|&quot;) ) as $vals\r\n     | [[$keys, $vals] | transpose[] | {key:.[0], value:.[1]|tonumber}]\r\n     | from_entries\r\n    &#39;\r\n\r\nBy the way, you could easily combine the awk+jq steps into either one awk or one jq step.  Doing so would save a lot of unnecessary munging.  If you choose to stick with awk, I&#39;d focus on shortening that ridiculously long &quot;print $1, $2, ...&quot; statement. (Would &quot;print $0&quot; not suffice?)\r\n\r\nawk&#39;s FIELDWIDTHS is certainly convenient, so in the next section, a jq filter for emitting an array based on an input string and information about the field widths is presented.\r\n\r\n### Parsing fixed-length fields using jq\r\n\r\n    # Given a string, emit a stream of the fields defined by the array of widths\r\n    def fixedfields(widths):\r\n      foreach widths[] as $w ({s:.}; (.field = .s[:$w]) | (.s |= .[$w:]); .field);\r\n    \r\nIf your jq does not have `foreach`, here&#39;s an alternative implementation:\r\n\r\n    def fixedfields(widths):\r\n      def do_while(cond; f; g): def r: select(cond) | f | (g, r); r;\r\n      {s:., w: widths}\r\n      | do_while(.w|length &gt; 0;\r\n                 .w[0] as $w | {s: .s[$w:], w: .w[1:], field: .s[:$w] };\r\n                 .field);\r\n\r\n\r\n\r\n",
                "title": "Problems converting text from fixed length fields to json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1519112247,
        "creation_date": 1519082363,
        "question_id": 48875623,
        "body_markdown": "I have a working solution that downloads a zipped fixed length field text file from a clients sftp server, uses a password to unzip it, then runs gnu awk on the file to convert it to a pipe delimited text file, then clean up after itself. \r\n\r\nBash script code here:\r\n\r\n    #!/bin/bash\r\n    export ZipPassword=********\r\n    export SSHPASS=********\r\n    export WorkPath=/Users/administrator/Documents/Work/\r\n    export ArcPath=/Users/administrator/Documents/Work/archive/\r\n    export DownPath=/Users/administrator/Documents/Work/down/\r\n    export InPath=/Users/administrator/Documents/Work/input/\r\n    export ReadyPath=/Users/administrator/Documents/Work/preproc/\r\n    export OutPath=/Users/administrator/Documents/Work/Output/\r\n    export AwkPath=/Users/administrator/Documents/Work/scpost.awk\r\n    \r\n    \r\n    cd $DownPath\r\n    \r\n    sshpass -e sftp -oBatchMode=no -b - ****@*****.*******.*** &lt;&lt; !\r\n    \tcd /frommbi\r\n    \tget *.zip\r\n    \trm *.zip\r\n    \texit\r\n    !\r\n    \r\n    \r\n    for f in *.zip\r\n    do \r\n       \tcp -v &quot;$f&quot; &quot;$InPath&quot;\r\n        cp -v &quot;$f&quot; &quot;$ArcPath&quot;\r\n        rm *.zip\r\n    done\t\r\n    \r\n    shopt -s nullglob dotglob     # To include hidden files\r\n    files=($InPath*)\r\n    if [ ${#files[@]} -gt 0 ]; then\r\n    \r\n    \r\n    unzip -P $ZipPassword $InPath*.zip -d $ReadyPath\r\n    \r\n    \r\n    for f in $ReadyPath\r\n    do\r\n      \texport PathName=/Users/administrator/Documents/Work/PreProc/*.TXT\r\n      \techo $PathName\r\n    \texport FileName=`basename $PathName`\r\n    \techo $FileName\r\n    \techo $OutPath$FileName\r\n    \t\r\n    awk -f $AwkPath $PathName &gt; $OutPath$FileName\r\n    \r\n    done\r\n    \r\n    \r\n    \r\n    rm -f $InPath*\r\n    rm -f $ReadyPath*\r\n    \r\n    fi\r\n\r\nawk file content here:\r\n\r\n    BEGIN{FIELDWIDTHS=&quot; 3 2 2 18 5 9 10 10 10 14 16 30 30 30 30 30 30 30 30 45 45 45 45 45 45 45 45 16 28 6 1 1 3 2 6 2 4 3 2 30 3 3 3 40 6 5 6 3 3 3 40 6 5 6 3 3 3 40 6 5 6 3 3 3 40 6 5 6 3 3 3 40 6 5 6 3 3 3 40 6 5 6 3 3 3 40 6 5 6 3 3 3 40 6 5 6 20 7 20 2 6 13 6 6 6 32 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 40 2 6 20 30 11 12 3 1 14 14 1 4 4 4 4 4 4 4 12 28 30 8 2 1 8 8 8 8 8 10 12 8 130 1 7 65 3 82 512 528 1 &quot;; \r\n    OFS=&quot;|&quot;;\r\n    }\r\n    {\r\n    for (i=1;i&lt;=NF;i++) gsub (/^ */,&quot;&quot;,$i);for(i=1;i&lt;=NF;i++) gsub(&quot;^[ \\t]*|[ \\t]*$&quot;,&quot;&quot;,$i);\r\n    }\r\n    {\r\n    print$1,$2,$3,$4,$5,$6,$7,$8,$9,$10,$11,$12,$13,$14,$15,$16,$17,$18,$19,$20,$21,$22,$23,$24,$25,$26,$27,$28,$29,$30,$31,$32,$33,$34,$35,$36,$37,$38,$39,$40,$41,$42,$43,$44,$45,$46,$47,$48,$49,$50,$51,$52,$53,$54,$55,$56,$57,$58,$59,$60,$61,$62,$63,$64,$65,$66,$67,$68,$69,$70,$71,$72,$73,$74,$75,$76,$77,$78,$79,$80,$81,$82,$83,$84,$85,$86,$87,$88,$89,$90,$91,$92,$93,$94,$95,$96,$97,$98,$99,$100,$101,$102,$103,$104,$105,$106,$107,$108,$109,$110,$111,$112,$113,$114,$115,$116,$117,$118,$119,$120,$121,$122,$123,$124,$125,$126,$127,$128,$129,$130,$131,$132,$133,$134,$135,$136,$137,$138,$139,$140,$141,$142,$143,$144,$145,$146,$147,$148,$149,$150,$151,$152,$153,$154,$155,$156,$157,$158,$159,$160,$161,$162,$163,$164,$165,$166,$167,$168,$169,$170,$171\r\n    }\r\n\r\nRecognize that the field names are numbers here to enable mapping in a database later.\r\n\r\nI have installed jq to handle the conversion from pipe separated data to json, but I haven&#39;t be able to get the syntax correct.\r\n\r\nThe modified bash script content is here in lines 52 - 56:\r\n\r\n    #!/bin/bash\r\n    export ZipPassword=********\r\n    export SSHPASS=********\r\n    export WorkPath=/Users/administrator/Documents/Work/\r\n    export ArcPath=/Users/administrator/Documents/Work/archive/\r\n    export DownPath=/Users/administrator/Documents/Work/down/\r\n    export InPath=/Users/administrator/Documents/Work/input/\r\n    export ReadyPath=/Users/administrator/Documents/Work/preproc/\r\n    export OutPath=/Users/administrator/Documents/Work/Output/\r\n    export AwkPath=/Users/administrator/Documents/Work/scpost.awk\r\n    export JsonPath=/Users/administrator/Documents/Work/JSON/\r\n    \r\n    \r\n    cd $DownPath\r\n    \r\n    sshpass -e sftp -oBatchMode=no -b - ****@*****.*******.*** &lt;&lt; !\r\n    \tcd /frommbi\r\n    \tget *.zip\r\n    \trm *.zip\r\n    \texit\r\n    !\r\n    \r\n    \r\n    for f in *.zip\r\n    do \r\n       \tcp -v &quot;$f&quot; &quot;$InPath&quot;\r\n        cp -v &quot;$f&quot; &quot;$ArcPath&quot;\r\n        rm *.zip\r\n    done\t\r\n    \r\n    shopt -s nullglob dotglob     # To include hidden files\r\n    files=($InPath*)\r\n    if [ ${#files[@]} -gt 0 ]; then\r\n    \r\n    \r\n    unzip -P $ZipPassword $InPath*.zip -d $ReadyPath\r\n    \r\n    \r\n    for f in $ReadyPath\r\n    do\r\n      \texport PathName=/Users/administrator/Documents/Work/PreProc/*.TXT\r\n      \techo $PathName\r\n    \texport FileName=`basename $PathName`\r\n    \techo $FileName\r\n    \techo $OutPath$FileName\r\n    \t\r\n    awk -f $AwkPath $PathName &gt; $OutPath$FileName\r\n    \r\n    done\r\n    chmod 776 $OutPath$FileName\r\n    \r\n    jq -Rn  --slurp --raw-input --raw-output \\&#39;\r\n    ( input  | split(&quot;|&quot;) ) as $keys |\r\n    ( inputs | split(&quot;|&quot;) ) as $vals |\r\n    [[$keys, $vals] | transpose[] | {key:.[0],value:.[1]}] | from_entries\r\n    &#39; $OutPath$FileName &gt; $JsonPath$FileName\r\n    \r\n    \r\n    \r\n    rm -f $InPath*\r\n    rm -f $ReadyPath*\r\n    rm -f $JsonPath*\r\n    \r\n    \r\n    fi\r\n\r\n\r\nCan anyone help? Before you ask, I am using this method for the sheer speed of conversion. My Mac Pro can convert 100,000 2850 character records in about 20 seconds and does so daily.conversion to json will speed the next step in the process considerably.\r\n",
        "link": "https://stackoverflow.com/questions/48875623/problems-converting-text-from-fixed-length-fields-to-json",
        "title": "Problems converting text from fixed length fields to json"
    },
    {
        "tags": [
            "json",
            "bash",
            "filtering",
            "jq",
            "edit-in-place"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7310558,
                    "reputation": 740,
                    "user_id": 5569925,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/0435bf08963d1ff53d3b01502f5f3767?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Goldfish",
                    "link": "https://stackoverflow.com/users/5569925/goldfish"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1519101981,
                "post_id": 48878003,
                "comment_id": 84760025,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 19,
                "is_accepted": true,
                "score": 19,
                "last_activity_date": 1560213446,
                "last_edit_date": 1560213446,
                "creation_date": 1519102326,
                "answer_id": 48878072,
                "question_id": 48878003,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your jq filter is not the one you need because `select` selects.  That is, it filters out the objects that don&#39;t match the selection criterion.\r\n\r\nThis jq filter should do what you want:\r\n\r\n    if (.objectName == &quot;contacts&quot;) then .IBM = &quot;Y&quot; else . end\r\n\r\nAs for overwriting the file, many people who have access to `sponge` (part of the [moreutils][1] collection of CLI utilities) use it, e.g.\r\n\r\n    jq &#39;if (.objectName == &quot;contacts&quot;) then .IBM = &quot;Y&quot; else . end&#39; input.json |\r\n      sponge input.json\r\n\r\n\r\n  [1]: https://joeyh.name/code/moreutils/",
                "title": "JQ edit file in place after using JQ Select"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1560213446,
        "creation_date": 1519101902,
        "last_edit_date": 1519102297,
        "question_id": 48878003,
        "body_markdown": "to edit a json file inplace with JQ like `-i` in sed I have found many solutions like\r\n\r\n`jq ... input.json &gt; tmp.json &amp;&amp; mv tmp.json input.json`\r\n\r\nThis works, but I need to filter on my file, add some data, and place it back in the original. (ie. Update a specific object in a file)\r\n\r\nMy file contains over 1000 objects with **different `Element`**. I will always be using a filter on `Element`, I shortened for question. I have a sample file `original.json` ...\r\n\r\n\r\n    {\r\n      &quot;Element&quot;: &quot;acton&quot;,\r\n      &quot;objectName&quot;: &quot;contacts&quot;,\r\n      &quot;Path&quot;: &quot;/contacts&quot;,\r\n      &quot;Scenario&quot;: &quot;&quot;,\r\n      &quot;serviceLevel&quot;: &quot;&quot;,\r\n      &quot;IBM&quot;: &quot;&quot;,\r\n      &quot;Gap&quot;: &quot;&quot;,\r\n      &quot;clientPhase&quot;: &quot;&quot;,\r\n      &quot;parentPhase&quot;: &quot;&quot;,\r\n      &quot;existsToday&quot;: &quot;&quot;\r\n    }\r\n    {\r\n      &quot;Element&quot;: &quot;acton&quot;,\r\n      &quot;objectName&quot;: &quot;optouts&quot;,\r\n      &quot;Path&quot;: &quot;/optouts&quot;,\r\n      &quot;Scenario&quot;: &quot;&quot;,\r\n      &quot;serviceLevel&quot;: &quot;&quot;,\r\n      &quot;IBM&quot;: &quot;&quot;,\r\n      &quot;Dependency&quot;: &quot;&quot;,\r\n      &quot;Gap&quot;: &quot;&quot;,\r\n      &quot;clientPhase&quot;: &quot;&quot;,\r\n      &quot;parentPhase&quot;: &quot;&quot;,\r\n      &quot;existsToday&quot;: &quot;&quot;\r\n    }\r\n    {\r\n      &quot;Element&quot;: &quot;acton&quot;,\r\n      &quot;objectName&quot;: &quot;subscriptionTypes&quot;,\r\n      &quot;Path&quot;: &quot;/subscription-types&quot;,\r\n      &quot;Scenario&quot;: &quot;&quot;,\r\n      &quot;serviceLevel&quot;: &quot;&quot;,\r\n      &quot;IBM&quot;: &quot;&quot;,\r\n      &quot;Dependency&quot;: &quot;&quot;,\r\n      &quot;Gap&quot;: &quot;&quot;,\r\n      &quot;clientPhase&quot;: &quot;&quot;,\r\n      &quot;parentPhase&quot;: &quot;&quot;,\r\n      &quot;existsToday&quot;: &quot;&quot;\r\n    }\r\n\r\nI want to filter by `objectName` for `contacts` add some data to empty IBM field and save to the file\r\n\r\nApplying the same logic to inplace edit the IBM field to `&quot;Y&quot;` on object containing `&quot;objectName&quot;: &quot;contacts&quot;`\r\n\r\n`jq &#39;select(.objectName == &quot;contacts&quot;) | .IBM = &quot;Y&quot;&#39; original.json &gt; tmpjson.json &amp;&amp; mv tmpjson.json original.json`\r\n\r\nNow my file `original.json` shows\r\n\r\n    {\r\n      &quot;Element&quot;: &quot;acton&quot;,\r\n      &quot;objectName&quot;: &quot;contacts&quot;,\r\n      &quot;Path&quot;: &quot;/contacts&quot;,\r\n      &quot;Scenario&quot;: &quot;&quot;,\r\n      &quot;serviceLevel&quot;: &quot;&quot;,\r\n      &quot;IBM&quot;: &quot;Y&quot;,\r\n      &quot;Dependency&quot;: &quot;&quot;,\r\n      &quot;Gap&quot;: &quot;&quot;,\r\n      &quot;clientPhase&quot;: &quot;&quot;,\r\n      &quot;parentPhase&quot;: &quot;&quot;,\r\n      &quot;existsToday&quot;: &quot;&quot;\r\n    }\r\n\r\nExpected Result\r\n\r\n\r\n    {\r\n      &quot;Element&quot;: &quot;acton&quot;,\r\n      &quot;objectName&quot;: &quot;contacts&quot;,\r\n      &quot;Path&quot;: &quot;/contacts&quot;,\r\n      &quot;Scenario&quot;: &quot;&quot;,\r\n      &quot;serviceLevel&quot;: &quot;&quot;,\r\n      &quot;IBM&quot;: &quot;Y&quot;,\r\n      &quot;Gap&quot;: &quot;&quot;,\r\n      &quot;clientPhase&quot;: &quot;&quot;,\r\n      &quot;parentPhase&quot;: &quot;&quot;,\r\n      &quot;existsToday&quot;: &quot;&quot;\r\n    }\r\n    {\r\n      &quot;Element&quot;: &quot;acton&quot;,\r\n      &quot;objectName&quot;: &quot;optouts&quot;,\r\n      &quot;Path&quot;: &quot;/optouts&quot;,\r\n      &quot;Scenario&quot;: &quot;&quot;,\r\n      &quot;serviceLevel&quot;: &quot;&quot;,\r\n      &quot;IBM&quot;: &quot;&quot;,\r\n      &quot;Dependency&quot;: &quot;&quot;,\r\n      &quot;Gap&quot;: &quot;&quot;,\r\n      &quot;clientPhase&quot;: &quot;&quot;,\r\n      &quot;parentPhase&quot;: &quot;&quot;,\r\n      &quot;existsToday&quot;: &quot;&quot;\r\n    }\r\n    {\r\n      &quot;Element&quot;: &quot;acton&quot;,\r\n      &quot;objectName&quot;: &quot;subscriptionTypes&quot;,\r\n      &quot;Path&quot;: &quot;/subscription-types&quot;,\r\n      &quot;Scenario&quot;: &quot;&quot;,\r\n      &quot;serviceLevel&quot;: &quot;&quot;,\r\n      &quot;IBM&quot;: &quot;&quot;,\r\n      &quot;Dependency&quot;: &quot;&quot;,\r\n      &quot;Gap&quot;: &quot;&quot;,\r\n      &quot;clientPhase&quot;: &quot;&quot;,\r\n      &quot;parentPhase&quot;: &quot;&quot;,\r\n      &quot;existsToday&quot;: &quot;&quot;\r\n    }\r\n\r\nIt seems after using select I can no longer use the provided solution https://github.com/stedolan/jq/wiki/FAQ#general-questions",
        "link": "https://stackoverflow.com/questions/48878003/jq-edit-file-in-place-after-using-jq-select",
        "title": "JQ edit file in place after using JQ Select"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "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": 1519240341,
                "post_id": 48878685,
                "comment_id": 84833627,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8011176,
                    "reputation": 4161,
                    "user_id": 6042824,
                    "user_type": "registered",
                    "accept_rate": 94,
                    "profile_image": "https://i.sstatic.net/YoO5z.jpg?s=256",
                    "display_name": "Bilesh Ganguly",
                    "link": "https://stackoverflow.com/users/6042824/bilesh-ganguly"
                },
                "reply_to_user": {
                    "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": 1519276132,
                "post_id": 48878685,
                "comment_id": 84846355,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1519106820,
                "creation_date": 1519106820,
                "answer_id": 48878871,
                "question_id": 48878685,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Found the solution.\r\n\r\nThe shell strips the quotes. So, it is good practice to put the expression within single-quotes.\r\n\r\n    jq &#39;.[].partyResponse[&quot;ns2:Address1&quot;]&#39; random_file_20180220.json\r\n\r\nThe above gives the desired result.\r\n\r\n    &quot;10 test Way&quot;\r\n    &quot;10 test Way&quot;\r\n    &quot;10 test Way&quot;\r\n    &quot;10 test Way&quot;\r\n    &quot;10 test Way&quot;\r\n    &quot;10 test Way&quot;\r\n    &quot;3030 test Freeway&quot;\r\n    &quot;3030 test Freeway&quot;\r\n\r\nThis only works on Linux systems though (I&#39;m using Ubuntu). \r\n",
                "title": "Unable to access the value against a specific key that has a special character"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1519276099,
        "creation_date": 1519105879,
        "last_edit_date": 1519276099,
        "question_id": 48878685,
        "body_markdown": "I was trying to extract relevant data from a given JSON file. The JSON has the following format.\r\n\r\n    [\r\n      {\r\n        &quot;partyResponse&quot; : {\r\n          &quot;ns2:Address1&quot; : &quot;10 test Way&quot;,\r\n          &quot;ns2:Address2&quot; : null,\r\n          ...\r\n        }\r\n      },\r\n      {\r\n        ...\r\n      }\r\n      ...\r\n    ]\r\n\r\nI&#39;m trying to get the value for Address1 but the following just prints out the whole JSON in an odd manner.\r\n\r\n    jq .[].partyResponse[&quot;ns2:Address1&quot;] random_file_20180220.json\r\n\r\nI&#39;m trying to access it like this because the key name has a colon.\r\n\r\nI just want to list out the address as follows.\r\n\r\n    &quot;10 test Way&quot;\r\n    &quot;10 test Way&quot;\r\n    &quot;10 test Way&quot;\r\n    ...",
        "link": "https://stackoverflow.com/questions/48878685/unable-to-access-the-value-against-a-specific-key-that-has-a-special-character",
        "title": "Unable to access the value against a specific key that has a special character"
    },
    {
        "tags": [
            "json",
            "casting",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 92,
                "is_accepted": true,
                "score": 92,
                "last_activity_date": 1548675882,
                "last_edit_date": 1548675882,
                "creation_date": 1519137494,
                "answer_id": 48887712,
                "question_id": 48887711,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` has inbuilt functions, you can pipe your key to [`tonumber`](https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions):\r\n\r\n    jq &#39;to_entries[]| {companyId: (.key)|tonumber, companyTitle: (.value.title), companyCode: (.value.booking_service_code)}&#39; companies.json\r\n\r\nAs per the docs:\r\n\r\n&gt; `tonumber` The `tonumber` function parses its input as a number. It will\r\n&gt; convert correctly-formatted strings to their numeric equivalent,\r\n&gt; leave numbers alone, and give an error on all other input.\r\n&gt; \r\n&gt;  `Example jq &#39;.[] | tonumber&#39; Input\t[1, &quot;1&quot;] Output\t1 1`",
                "title": "How to convert a string to an integer in a JSON file using jq?"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1601044885,
                "creation_date": 1601044885,
                "answer_id": 64066329,
                "question_id": 48887711,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I was trying to turn my string (that converts to a float) to an integer.  I was looking for a &#39;toint&#39; function, one doesn&#39;t exist.\r\n\r\n    jq --arg str &quot;1.435&quot; -n &#39;$str|tonumber&#39;\r\n    1.435\r\n\r\nI threw a floor in there to make sure the number that was created was an integer:\r\n\r\n    jq --arg str &quot;1.435&quot; -n &#39;$str|tonumber|floor&#39;\r\n    1\r\n\r\nThis also properly converts the OP original data as well.  If you want to *guarantee* your result is an integer you will need to floor it.\r\n\r\n",
                "title": "How to convert a string to an integer in a JSON file using jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1715421447,
                "creation_date": 1715421447,
                "answer_id": 78464146,
                "question_id": 48887711,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**Warning**: using tonumber WILL remove any prefixed zeros like: \r\n&quot;data&quot;:{&quot;order_number&quot;:&quot;024058275&quot; =&gt; 24058275\r\n\r\nuse sed ( or awk ) to remove the &#39; &quot; &#39;\r\n\r\n    echo $result | jq &#39;.data.order_number&#39; | sed &#39;s|[&quot;]||g&#39;\r\nThis will return 024058275\r\n",
                "title": "How to convert a string to an integer in a JSON file using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 71,
        "last_activity_date": 1715421447,
        "creation_date": 1519137494,
        "question_id": 48887711,
        "body_markdown": "I use jq to transform a complex json object into a tinier one. My query is:\r\n\r\n    jq &#39;to_entries[]| {companyId: (.key), companyTitle: (.value.title), companyCode: (.value.booking_service_code)}&#39; companies.json\r\n\r\nNow, the `(.key)` is parsed as a string, yet I want `companyId` to be a number.\r\n\r\nMy result currently looks like this:\r\n\r\n    {\r\n      &quot;companyId&quot;: &quot;1337&quot;,\r\n      &quot;companyTitle&quot;: &quot;Some company title&quot;,\r\n      &quot;companyCode&quot;: &quot;oxo&quot;\r\n    }\r\n\r\nyet it should be like:\r\n\r\n    {\r\n      &quot;companyId&quot;: 1337,\r\n      &quot;companyTitle&quot;: &quot;Some company title&quot;,\r\n      &quot;companyCode&quot;: &quot;oxo&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/48887711/how-to-convert-a-string-to-an-integer-in-a-json-file-using-jq",
        "title": "How to convert a string to an integer in a JSON file using jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1519147828,
                "last_edit_date": 1519147828,
                "creation_date": 1519146360,
                "answer_id": 48890562,
                "question_id": 48888057,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This works:\r\n\r\n    [\r\n        foreach (paths | select(.[-1] == &quot;id&quot; and length &gt; 1)[:-1]) as $path ({i:.};\r\n            .o = {\r\n                type: last($path[] | strings),\r\n                node: (.i | getpath($path))\r\n            };\r\n            .o\r\n        )\r\n    ]\r\n\r\nThe trick is to know that any numbers in the path indicates the value is part of an array. You&#39;ll have to adjust the path to get the parent name. But using `last/1` with a string filter makes it simpler.",
                "title": "Elegant way to select nested objects with the associated key based on a specific criteria"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1519192461,
                "last_edit_date": 1519192461,
                "creation_date": 1519146778,
                "answer_id": 48890704,
                "question_id": 48888057,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since the actual requirements aren’t clear to me, I’ll assume that the given implementation defines the functional requirements, and propose a shorter and hopefully sleeker version:\r\n\r\n    . as $document\r\n    | paths\r\n    | select(length &gt; 1 and .[-1] == &quot;id&quot;)\r\n    | .[0:-1] as $path\r\n    | { &quot;type&quot;: last($path[] | strings),\r\n        &quot;node&quot;: $document | getpath($path) }\r\n\r\nThis produces a stream, so if you want an array, you could simply enclose the above in square brackets.\r\n\r\n`last(stream)` emits null if the stream is empty, which accords with the behavior of `.[-1]`.\r\n",
                "title": "Elegant way to select nested objects with the associated key based on a specific criteria"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1519192461,
        "creation_date": 1519138525,
        "last_edit_date": 1519142213,
        "question_id": 48888057,
        "body_markdown": "Given an example document in JSON similar to this:\r\n\r\n    {\r\n      &quot;id&quot;: &quot;post-1&quot;,\r\n      &quot;type&quot;: &quot;blog-post&quot;,\r\n      &quot;tags&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;tag-1&quot;,\r\n          &quot;name&quot;: &quot;Tag 1&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;tag-2&quot;,\r\n          &quot;name&quot;: &quot;Tag 2&quot;\r\n        }\r\n      ],\r\n      &quot;heading&quot;: &quot;Post 1&quot;,\r\n      &quot;body&quot;: &quot;this is my first blog post&quot;,\r\n      &quot;links&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;post-2&quot;,\r\n          &quot;heading&quot;: &quot;Post 2&quot;,\r\n          &quot;tags&quot;: [\r\n            {\r\n              &quot;id&quot;: &quot;tag-1&quot;,\r\n              &quot;name&quot;: &quot;Tag 1&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: &quot;tag-3&quot;,\r\n              &quot;name&quot;: &quot;Tag 3&quot;\r\n            }\r\n          ]\r\n        }\r\n      ],\r\n      &quot;metadata&quot;: {\r\n        &quot;user&quot;: {\r\n          &quot;social&quot;: [\r\n            {\r\n              &quot;id&quot;: &quot;twitter&quot;,\r\n              &quot;handle&quot;: &quot;@user&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: &quot;facebook&quot;,\r\n              &quot;handle&quot;: &quot;123456&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: &quot;youtube&quot;,\r\n              &quot;handle&quot;: &quot;ABC123xyz&quot;\r\n            }\r\n          ]\r\n        },\r\n        &quot;categories&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;Category 1&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;Category 2&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nI would like to select any object (regardless of depth) that has an attribute `&quot;id&quot;`, as well as the attribute name of the parent object. The above example should be taken as just that, an example. The actual data, that I&#39;m not at liberty to share, can have any depth and just about any structure. Attributes can be introduced and removed at any time. Using the Blog Post style is just because it is quite popular for examples and I have very limited imagination.\r\n\r\nThe attribute signifies a particular type within the domain, that might also be (but is not necessarily) coded into the value of the attribute.\r\n\r\nIf an object does not have the `&quot;id&quot;` attribute it is not interesting and should not be selected.\r\n\r\nA very important special case is when the value of an attribute is an array of objects, in that case I need to keep the attribute name and associate it with each element in the array.\r\n\r\nAn example of the desired output would be:\r\n\r\n    [\r\n      {\r\n        &quot;type&quot;: &quot;tags&quot;,\r\n        &quot;node&quot;: {\r\n          &quot;id&quot;: &quot;tag-1&quot;,\r\n          &quot;name&quot;: &quot;Tag 1&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;tags&quot;,\r\n        &quot;node&quot;: {\r\n          &quot;id&quot;: &quot;tag-2&quot;,\r\n          &quot;name&quot;: &quot;Tag 2&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;links&quot;,\r\n        &quot;node&quot;: {\r\n          &quot;id&quot;: &quot;post-2&quot;,\r\n          &quot;heading&quot;: &quot;Post 2&quot;,\r\n          &quot;tags&quot;: [\r\n            {\r\n              &quot;id&quot;: &quot;tag-1&quot;,\r\n              &quot;name&quot;: &quot;Tag 1&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: &quot;tag-3&quot;,\r\n              &quot;name&quot;: &quot;Tag 3&quot;\r\n            }\r\n          ]\r\n        }\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;tags&quot;,\r\n        &quot;node&quot;: {\r\n          &quot;id&quot;: &quot;tag-1&quot;,\r\n          &quot;name&quot;: &quot;Tag 1&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;tags&quot;,\r\n        &quot;node&quot;: {\r\n          &quot;id&quot;: &quot;tag-3&quot;,\r\n          &quot;name&quot;: &quot;Tag 3&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;social&quot;,\r\n        &quot;node&quot;: {\r\n          &quot;id&quot;: &quot;twitter&quot;,\r\n          &quot;handle&quot;: &quot;@user&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;social&quot;,\r\n        &quot;node&quot;: {\r\n          &quot;id&quot;: &quot;facebook&quot;,\r\n          &quot;handle&quot;: &quot;123456&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;social&quot;,\r\n        &quot;node&quot;: {\r\n          &quot;id&quot;: &quot;youtube&quot;,\r\n          &quot;handle&quot;: &quot;ABC123xyz&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\nIt isn&#39;t strictly necessary that the output is identical, order for instance is irrelevant for my use-case it could be grouped as well. Since the top level object has an attribute `&quot;id&quot;` it could be included with a special name, but I&#39;d prefer if it was not included at all.\r\n\r\nI&#39;ve tried to use `walk`, `reduce` and `recurse` to no avail, I&#39;m afraid my `jq` skills are too limited. But I imagine that a good solution would make use of at least one of them.\r\n\r\nI would like an expression something like\r\n\r\n    to_entries[] | .value | .. | select(has(&quot;id&quot;)?)\r\n\r\nwhich would select the correct objects, but with `..` I&#39;m no longer able to keep the associated attribute name.\r\n\r\nThe best I&#39;ve come up with is\r\n\r\n    . as $document\r\n    | [paths | if length &gt; 1 and .[-1] == &quot;id&quot; then .[0:-1] else empty end] \r\n    | map(. as $path \r\n          | $document \r\n          | { &quot;type&quot;: [$path[] | if type == &quot;string&quot; then . else empty end][-1],\r\n               &quot;node&quot;: getpath($path) })\r\n\r\nWhich works, but feels quite complicated and involves first extracting all paths, ignoring any path that does not have `&quot;id&quot;` as the last element, then remove the `&quot;id&quot;` segment to get the path to the actual object and storing the (by now last) segment that is a string, which corresponds to the parent objects attribute containing the interesting object. Finally the actual object is selected through `getpath`.\r\n\r\nIs there a more elegant, or at the least shorter way to express this?\r\n\r\nI should note that I&#39;d like to use `jq` for the convenience of having bindings to other languages as well as being able to run the program on the command line.\r\n\r\nFor the scope of this question, I&#39;m not really interested in alternatives to `jq` as I can imagine how to solve this differently using other tooling, but I would really like to &quot;just&quot; use `jq`.",
        "link": "https://stackoverflow.com/questions/48888057/elegant-way-to-select-nested-objects-with-the-associated-key-based-on-a-specific",
        "title": "Elegant way to select nested objects with the associated key based on a specific criteria"
    },
    {
        "tags": [
            "arrays",
            "json",
            "indexing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1519204292,
                "creation_date": 1519204292,
                "answer_id": 48901951,
                "question_id": 48898983,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Because apparently `index` takes a subsequence of elements to find, with a scalar being a special case equivalent to an one element sequence.\r\n\r\nCompare the three cases:\r\n\r\n    echo &quot;[0,2,0,3,0,6,0,2]&quot; | jq &#39;index(2)&#39;\r\n    echo &quot;[0,2,0,3,0,6,0,2]&quot; | jq &#39;index([2])&#39;\r\n    echo &quot;[0,2,0,3,0,6,0,2]&quot; | jq &#39;index([2,0])&#39;\r\n\r\nThey all return 1.\r\n\r\nSo in your case it is trying to find a single element subsequence consisting of an object in a list that contains a list (and not directly an object).",
                "title": "jq: index/1 not working when element is an array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1519247664,
                "last_edit_date": 1519247664,
                "creation_date": 1519215434,
                "answer_id": 48905741,
                "question_id": 48898983,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In the jq manual, there is a hint about the semantics of `index` under the heading `indices`. In brief, the seemingly buggy behavior is actually a “feature”.  That is, the following illustrates the intended behavior:\r\n\r\n    $ jq &#39;index([1,2])&#39;\r\n    [1,2]\r\n    0\r\n    $ jq &#39;index([[1,2]])&#39;\r\n    [[1,2]]\r\n    0\r\n    $ \r\n\r\nSo to search for a JSON entity X, using `index([X])` is always safe. Unfortunately, because of the way `index` is currently implemented, it is not as efficient as it could (should) be, but that’s a different topic. \r\n\r\nHowever it&#39;s worth knowing about `.[[X]]` and `IN/1`.\r\n\r\n### .[[X]]\r\n\r\nA little-known fact is that postfix square-brackets provide &quot;index-of&quot; functionality:\r\n\r\n    $ jq -nc &#39;[1,2,30,3,3][[3]]&#39;\r\n    [3,4]\r\n\r\n    $ jq -nc &#39;[[1],2,30,3][[1]]&#39;\r\n    []\r\n\r\n    $ jq -nc &#39;[[1],2,30,3][[[1]]]&#39;\r\n    [0]\r\n\r\n    $ jq -nc &#39;[{a:1},2,30,3][[ {a:1} ]]&#39;\r\n    [0]\r\n    \r\nSo to recover the least index of X in the input array:\r\n\r\n    .[[X]][0]\r\n\r\nAs with `index/1`, this returns null if X is not in the input array:\r\n\r\n    $ jq -n &#39;[1,2,3][ [4] ][0]&#39;\r\n    null\r\n\r\n### IN/1\r\n\r\nThe “master” version of jq has a pair of straightforward stream-oriented filters (named `IN`) for checking whether an item is in a stream.  Here is an efficient def of `IN/1` which can be used if your jq has `first/1`:\r\n\r\n    def IN(s): . as $in | first( if (s == $in) then true else empty end ) // false;\r\n\r\nHere `s` is the stream to search.\r\n\r\n",
                "title": "jq: index/1 not working when element is an array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1519247664,
        "creation_date": 1519192432,
        "last_edit_date": 1519215608,
        "question_id": 48898983,
        "body_markdown": "    echo &quot;[[{\\&quot;t\\&quot;:4}]]&quot; | jq &#39;index(.[0])&#39;\r\n\r\nI was expecting this to return 0.\r\nInstead it&#39;s returning null.\r\nIndex works fine for arrays with scalars only but once there are nested arrays it returns null.\r\nWhy?",
        "link": "https://stackoverflow.com/questions/48898983/jq-index-1-not-working-when-element-is-an-array",
        "title": "jq: index/1 not working when element is an array"
    },
    {
        "tags": [
            "json",
            "filter",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 15,
                "is_accepted": true,
                "score": 15,
                "last_activity_date": 1519218565,
                "last_edit_date": 1519218565,
                "creation_date": 1519213091,
                "answer_id": 48904944,
                "question_id": 48904371,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq -r &#39;. as $o | keys_unsorted[] | select(endswith(&quot;/&quot;)) | $o[.].type&#39; file.json\r\nThe output:\r\n\r\n    token\r\n    userpass\r\n\r\n",
                "title": "jq: filter input based on if key ends with specified string"
            },
            {
                "up_vote_count": 35,
                "is_accepted": false,
                "score": 35,
                "last_activity_date": 1519246318,
                "last_edit_date": 1519246318,
                "creation_date": 1519218724,
                "answer_id": 48906860,
                "question_id": 48904371,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`to_entries` is worth knowing about, not least because it often leads to easy-to-read (variable-free) pipelines, as here:\r\n\r\n    to_entries[] | select(.key|endswith(&quot;/&quot;)) | .value.type",
                "title": "jq: filter input based on if key ends with specified string"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 16,
        "last_activity_date": 1519246318,
        "creation_date": 1519211377,
        "last_edit_date": 1519218988,
        "question_id": 48904371,
        "body_markdown": "I get this JSON data mess in and I need to extract the list of types:\r\n\r\n    {\r\n      &quot;token/&quot;: {\r\n        &quot;accessor&quot;: &quot;auth_token_909d6a81&quot;,\r\n        &quot;config&quot;: {\r\n          &quot;default_lease_ttl&quot;: 0,\r\n          &quot;max_lease_ttl&quot;: 0\r\n        },\r\n        &quot;description&quot;: &quot;token based credentials&quot;,\r\n        &quot;local&quot;: false,\r\n        &quot;seal_wrap&quot;: false,\r\n        &quot;type&quot;: &quot;token&quot;           &lt;-- I need to extract this value ...\r\n      },\r\n      &quot;userpass/&quot;: {\r\n        &quot;similar_to&quot;: {\r\n          &quot;above&quot;: null\r\n        },\r\n        &quot;description&quot;: &quot;&quot;,\r\n        &quot;local&quot;: false,\r\n        &quot;seal_wrap&quot;: false,\r\n        &quot;type&quot;: &quot;userpass&quot;        &lt;-- ... and this one\r\n      },\r\n      &quot;request_id&quot;: &quot;f2a4c135-f699-f29d-ca7c-3320dce0a550&quot;,\r\n      &quot;more_keys&quot;: &quot;more_values&quot;,\r\n      &quot;data&quot;: {\r\n        &quot;more_data&quot;: {\r\n          &quot;even_more_data&quot;: &quot;snipped&quot;\r\n        }\r\n      },\r\n      &quot;you_get_the&quot;: &quot;idea&quot;\r\n    }\r\n\r\nSorry for the inline comments messing up the data when copying &amp; pasting, but that seems the best way to clarify my goal:\r\nFor all root keys that end with `/`, I need the value of `.type`, so that the final result for the above example is `token userpass`.\r\n\r\nI managed to create a working filter for the root keys:\r\n\r\n    host:~ user$ jq -r &#39;. | keys[] | endswith(&quot;/&quot;)&#39; &lt;&lt;&lt; &quot;${json_data}&quot;\r\n    false\r\n    false\r\n    false\r\n    true\r\n    true\r\n    false\r\n\r\nand I can use that filter to get only the wanted keys, but that is the keys alone and not the entire data structures underneath them:\r\n\r\n    host:~ user$ jq -r &#39;. | keys[] | select(. | endswith(&quot;/&quot;))&#39; &lt;&lt;&lt; &quot;${json_data}&quot;\r\n    token/\r\n    userpass/\r\n\r\nI just can&#39;t seem to put this all together...\r\n\r\nCan anyone help me ?\r\n",
        "link": "https://stackoverflow.com/questions/48904371/jq-filter-input-based-on-if-key-ends-with-specified-string",
        "title": "jq: filter input based on if key ends with specified string"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "variable-expansion"
        ],
        "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": 1519235001,
                "post_id": 48911678,
                "comment_id": 84830827,
                "content_license": "CC BY-SA 3.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": 1519235341,
                "post_id": 48911678,
                "comment_id": 84831012,
                "content_license": "CC BY-SA 3.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": 1519235508,
                "post_id": 48911678,
                "comment_id": 84831098,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7894528,
                    "reputation": 27745,
                    "user_id": 6770384,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/kXCNG.png?s=256",
                    "display_name": "Socowi",
                    "link": "https://stackoverflow.com/users/6770384/socowi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1519237360,
                "post_id": 48911678,
                "comment_id": 84832081,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2842382,
                    "reputation": 83,
                    "user_id": 2441730,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/0f881e96eee5bbfc7432f3ba7e40cd0e?s=256&d=identicon&r=PG",
                    "display_name": "JRD",
                    "link": "https://stackoverflow.com/users/2441730/jrd"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1519322403,
                "post_id": 48911678,
                "comment_id": 84875108,
                "content_license": "CC BY-SA 3.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": 1519535044,
                "post_id": 48911678,
                "comment_id": 84946191,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1519239109,
                "last_edit_date": 1519239109,
                "creation_date": 1519238732,
                "answer_id": 48913272,
                "question_id": 48911678,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As pointed out in the comments, you&#39;d be much better off making jq do as much work as possible.  But to use jq, you&#39;ll need to fix the JSON.  Also, it&#39;s not clear to me that you need to compute $numberOfDataFolders at all, so in the interests of simplicity, this is what I&#39;d suggest:\r\n\r\n    #!/bin/bash\r\n    \r\n    json_path=input.json\r\n    \r\n    BUILD_FOLDER=mybuildfolder\r\n    \r\n    jq -r --arg bf &quot;$BUILD_FOLDER&quot; &#39;.data_folders[] | sub(&quot;\\\\${BUILD_FOLDER}&quot;;$bf)&#39; &quot;${json_path}&quot; |\r\n      while read -r writeFolder\r\n        do\r\n        echo mkdir -p &quot;${writeFolder}&quot;\r\n      done \r\n\r\nOnce the input has been fixed, this produces:\r\n\r\n    mkdir -p /Users/me/Desktop/POD_INSTALLS/pod_DB/mybuildfolder/data/table1/\r\n    mkdir -p /Users/me/Desktop/POD_INSTALLS/pod_DB/mybuildfolder/data/table2/\r\n\r\nNotice also that the -r option circumvents the need to use `tr`.",
                "title": "Expanding bash variable within a string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1519534618,
        "creation_date": 1519233027,
        "last_edit_date": 1519534618,
        "question_id": 48911678,
        "body_markdown": "I am trying to get a variable within a string to expand - its a path:\r\n\r\n/path/to/${variable}/here\r\n  \r\n1. The string originates in a json file.  \r\n2. It is subsequently read by jq - at this point I need the expansion to occur.\r\n\r\nHere is the json file:  \r\n\r\n    {\r\n        &quot;server_1&quot;:{\r\n          &quot;tag&quot;: &quot;storage_1&quot;,\r\n          &quot;user&quot;: &quot;me&quot;,\r\n          &quot;sshKey&quot;: &quot;/Users/me/.ssh/id_rsa&quot;,\r\n          &quot;target_folder&quot;: &quot;/Users/me/Desktop/&quot;,\r\n          &quot;pubIp&quot;: &quot;127.0.0.1&quot;,\r\n          &quot;data_folders&quot;: [\r\n            &quot;/Users/me/Desktop/POD_INSTALLS/pod_DB/${BUILD_FOLDER}/data/table1/&quot;,\r\n            &quot;/Users/me/Desktop/POD_INSTALLS/pod_DB/${BUILD_FOLDER}/data/table2/&quot;\r\n          ]\r\n        }\r\n    }\r\n\r\nHere is the jq code (now with working code - thanks all):\r\n\r\n      writeFolder=$(jq -r --arg bf &quot;${BUILD_FOLDER}&quot; &#39;.server_&#39;${id}&#39;.data_folders[] | sub(&quot;\\\\${BUILD_FOLDER}&quot;;$bf)&#39; &quot;${json_path}&quot;)\r\n      for folder in $writeFolder\r\n      do\r\n        ssh -q -o ForwardX11=no -i ${sshKey} ${user}@${pubIp} &quot;mkdir -p ${folder}&quot;\r\n      done\r\n\r\nOriginally - within the expanded $writeFolder variable, the path could be seen but the ${BUILD_FOLDER} variable remained unexpanded as it was taken literally. (when I used set -x I could see it was surrounded by single quotes).\r\n\r\nEventually used accepted solution from peak to make better use of jq.\r\n  \r\n\r\n\r\n\r\n \r\n\r\n",
        "link": "https://stackoverflow.com/questions/48911678/expanding-bash-variable-within-a-string",
        "title": "Expanding bash variable within a string"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1519249630,
                "creation_date": 1519249630,
                "answer_id": 48916033,
                "question_id": 48915926,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** approach:\r\n\r\n    jq &#39;.foo as $foo | .stuff[] | select(.foo == $foo)&#39; file.json",
                "title": "Filter an array of objects based on value of inner object equaling value of outer object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1519535167,
        "creation_date": 1519249150,
        "last_edit_date": 1519535167,
        "question_id": 48915926,
        "body_markdown": "I have some data like this:\r\n\r\n    {\r\n      &quot;foo&quot;: &quot;bar&quot;,\r\n      &quot;stuff&quot;: [\r\n        {\r\n          &quot;foo&quot;: &quot;baz&quot;\r\n        },\r\n        {\r\n          &quot;foo&quot;: &quot;bar&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI want to get the objects inside `stuff` which have the same value for `foo` as the outer object does. So in this case I would like to get:\r\n\r\n    {\r\n      &quot;foo&quot;: &quot;bar&quot;\r\n    }\r\n\r\nHow do I do this using `jq`?",
        "link": "https://stackoverflow.com/questions/48915926/filter-an-array-of-objects-based-on-value-of-inner-object-equaling-value-of-oute",
        "title": "Filter an array of objects based on value of inner object equaling value of outer object"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1519334260,
                "creation_date": 1519334260,
                "answer_id": 48937326,
                "question_id": 48937230,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The right way with **`jq`** tool:\r\n\r\n    jq -r &#39;.issues[0] | .key, .fields.project.key&#39; file.json\r\n\r\nThe output:\r\n\r\n    TECH-456\r\n    TECH\r\n\r\n",
                "title": "Searching JSON file using bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1519334288,
        "creation_date": 1519333865,
        "last_edit_date": 1519334288,
        "question_id": 48937230,
        "body_markdown": "i have JSON file and want to extract only some values \r\n\r\nHow to extract only &quot;key&quot;: `&quot;TECH-456&quot;`,\r\nand &quot;key&quot;: `&quot;TECH&quot;`, (values after key)\r\n\r\n    {\r\n        &quot;expand&quot;: &quot;names,schema&quot;,\r\n        &quot;issues&quot;: [\r\n            {\r\n                &quot;expand&quot;: &quot;operations,versionedRepresentations,editmeta,changelog,renderedFields&quot;,\r\n                &quot;fields&quot;: {\r\n                    &quot;aggregateprogress&quot;: {\r\n                        &quot;percent&quot;: 100,\r\n                        &quot;progress&quot;: 86400,\r\n                        &quot;total&quot;: 86400\r\n                    },\r\n                    &quot;aggregatetimeestimate&quot;: 0,\r\n                    &quot;aggregatetimeoriginalestimate&quot;: 57600,\r\n                    &quot;aggregatetimespent&quot;: 86400,\r\n                    &quot;assignee&quot;: {\r\n                        &quot;active&quot;: true,\r\n                        &quot;avatarUrls&quot;: {\r\n                            &quot;16x16&quot;: &quot;https://secure.gravatar.com/avatar/5d92f3ce51d4a090cdcb9b77ee890989?d=mm&amp;s=16&quot;,\r\n                            &quot;24x24&quot;: &quot;https://secure.gravatar.com/avatar/5d92f3ce51d4a090cdcb9b77ee890989?d=mm&amp;s=24&quot;,\r\n                            &quot;32x32&quot;: &quot;https://secure.gravatar.com/avatar/5d92f3ce51d4a090cdcb9b77ee890989?d=mm&amp;s=32&quot;,\r\n                            &quot;48x48&quot;: &quot;https://secure.gravatar.com/avatar/5d92f3ce51d4a090cdcb9b77ee890989?d=mm&amp;s=48&quot;\r\n                        },\r\n                        &quot;displayName&quot;: &quot;user1&quot;,\r\n                        &quot;emailAddress&quot;: &quot;user1@gmail.com&quot;,\r\n                        &quot;key&quot;: &quot;user1&quot;,\r\n                        &quot;name&quot;: &quot;user1&quot;,\r\n                        &quot;self&quot;: &quot;https://mycompany/rest/api/2/user?username=user1&quot;,\r\n                        &quot;timeZone&quot;: &quot;Europe/Belgrade&quot;\r\n                    },\r\n                    &quot;components&quot;: [],\r\n                    &quot;created&quot;: &quot;2018-01-10T10:23:01.000+0000&quot;,\r\n                    &quot;creator&quot;: {\r\n                        &quot;active&quot;: true,\r\n                        &quot;avatarUrls&quot;: {\r\n                            &quot;16x16&quot;: &quot;https://mycompany/secure/useravatar?size=xsmall&amp;avatarId=10349&quot;,\r\n                            &quot;24x24&quot;: &quot;https://mycompany/secure/useravatar?size=small&amp;avatarId=10349&quot;,\r\n                            &quot;32x32&quot;: &quot;https://mycompany/secure/useravatar?size=medium&amp;avatarId=10349&quot;,\r\n                            &quot;48x48&quot;: &quot;https://mycompany/secure/useravatar?avatarId=10349&quot;\r\n                        },\r\n                        &quot;displayName&quot;: &quot;user2&quot;,\r\n                        &quot;emailAddress&quot;: &quot;user2@gmail.com&quot;,\r\n                        &quot;key&quot;: &quot;user2&quot;,\r\n                        &quot;name&quot;: &quot;user2&quot;,\r\n                        &quot;self&quot;: &quot;https://mycompany/rest/api/2/user?username=user2&quot;,\r\n                        &quot;timeZone&quot;: &quot;Zulu&quot;\r\n                    },\r\n                    &quot;customfield_10000&quot;: null,\r\n                    &quot;customfield_10001&quot;: null,\r\n                    &quot;customfield_10002&quot;: null,\r\n                    &quot;customfield_10004&quot;: &quot;0|i00n0f:&quot;,\r\n                    &quot;customfield_10005&quot;: null,\r\n                    &quot;customfield_10006&quot;: null,\r\n                    &quot;customfield_10100&quot;: null,\r\n                    &quot;customfield_10101&quot;: [],\r\n                    &quot;customfield_10102&quot;: null,\r\n                    &quot;customfield_10103&quot;: null,\r\n                    &quot;customfield_10107&quot;: {\r\n                        &quot;id&quot;: &quot;10400&quot;,\r\n                        &quot;self&quot;: &quot;https://mycompany/rest/api/2/customFieldOption/10400&quot;,\r\n                        &quot;value&quot;: &quot;Hentsu Internal&quot;\r\n                    },\r\n                    &quot;customfield_10108&quot;: null,\r\n                    &quot;customfield_10200&quot;: null,\r\n                    &quot;customfield_10201&quot;: &quot;2018-01-12&quot;,\r\n                    &quot;customfield_10202&quot;: &quot;2018-01-12&quot;,\r\n                    &quot;customfield_10203&quot;: null,\r\n                    &quot;customfield_10204&quot;: null,\r\n                    &quot;customfield_10205&quot;: null,\r\n                    &quot;customfield_10206&quot;: null,\r\n                    &quot;customfield_10300&quot;: &quot;com.atlassian.servicedesk.plugins.approvals.internal.customfield.ApprovalsCFValue@40efdb56&quot;,\r\n                    &quot;customfield_10301&quot;: null,\r\n                    &quot;customfield_10302&quot;: null,\r\n                    &quot;customfield_10600&quot;: null,\r\n                    &quot;customfield_10700&quot;: null,\r\n                    &quot;customfield_11000&quot;: null,\r\n                    &quot;customfield_11001&quot;: null,\r\n                    &quot;customfield_11002&quot;: null,\r\n                    &quot;customfield_11003&quot;: null,\r\n                    &quot;customfield_11004&quot;: null,\r\n                    &quot;customfield_11005&quot;: null,\r\n                    &quot;customfield_11006&quot;: null,\r\n                    &quot;customfield_11007&quot;: null,\r\n                    &quot;customfield_11008&quot;: null,\r\n                    &quot;customfield_11009&quot;: null,\r\n                    &quot;customfield_11010&quot;: null,\r\n                    &quot;customfield_11011&quot;: null,\r\n                    &quot;customfield_11012&quot;: null,\r\n                    &quot;customfield_11013&quot;: null,\r\n                    &quot;customfield_11014&quot;: null,\r\n                    &quot;customfield_11015&quot;: null,\r\n                    &quot;customfield_11016&quot;: null,\r\n                    &quot;customfield_11017&quot;: null,\r\n                    &quot;customfield_11018&quot;: null,\r\n                    &quot;customfield_11019&quot;: null,\r\n                    &quot;customfield_11100&quot;: null,\r\n                    &quot;customfield_11101&quot;: null,\r\n                    &quot;customfield_11102&quot;: null,\r\n                    &quot;description&quot;: &quot;.&quot;,\r\n                    &quot;duedate&quot;: null,\r\n                    &quot;environment&quot;: null,\r\n                    &quot;fixVersions&quot;: [],\r\n                    &quot;issuelinks&quot;: [],\r\n                    &quot;issuetype&quot;: {\r\n                        &quot;avatarId&quot;: 10318,\r\n                        &quot;description&quot;: &quot;A task that needs to be done.&quot;,\r\n                        &quot;iconUrl&quot;: &quot;https://mycompany/secure/viewavatar?size=xsmall&amp;avatarId=10318&amp;avatarType=issuetype&quot;,\r\n                        &quot;id&quot;: &quot;10100&quot;,\r\n                        &quot;name&quot;: &quot;Task&quot;,\r\n                        &quot;self&quot;: &quot;https://mycompany/rest/api/2/issuetype/10100&quot;,\r\n                        &quot;subtask&quot;: false\r\n                    },\r\n                    &quot;labels&quot;: [],\r\n                    &quot;lastViewed&quot;: &quot;2018-02-22T15:47:47.792+0000&quot;,\r\n                    &quot;priority&quot;: {\r\n                        &quot;iconUrl&quot;: &quot;https://mycompany/images/icons/priorities/medium.svg&quot;,\r\n                        &quot;id&quot;: &quot;3&quot;,\r\n                        &quot;name&quot;: &quot;Medium&quot;,\r\n                        &quot;self&quot;: &quot;https://mycompany/rest/api/2/priority/3&quot;\r\n                    },\r\n                    &quot;progress&quot;: {\r\n                        &quot;percent&quot;: 100,\r\n                        &quot;progress&quot;: 86400,\r\n                        &quot;total&quot;: 86400\r\n                    },\r\n                    &quot;project&quot;: {\r\n                        &quot;avatarUrls&quot;: {\r\n                            &quot;16x16&quot;: &quot;https://mycompany/secure/projectavatar?size=xsmall&amp;pid=10001&amp;avatarId=10201&quot;,\r\n                            &quot;24x24&quot;: &quot;https://mycompany/secure/projectavatar?size=small&amp;pid=10001&amp;avatarId=10201&quot;,\r\n                            &quot;32x32&quot;: &quot;https://mycompany/secure/projectavatar?size=medium&amp;pid=10001&amp;avatarId=10201&quot;,\r\n                            &quot;48x48&quot;: &quot;https://mycompany/secure/projectavatar?pid=10001&amp;avatarId=10201&quot;\r\n                        },\r\n                        &quot;id&quot;: &quot;10001&quot;,\r\n                        &quot;key&quot;: &quot;TECH&quot;,\r\n                        &quot;name&quot;: &quot;Technology&quot;,\r\n                        &quot;self&quot;: &quot;https://mycompany/rest/api/2/project/10001&quot;\r\n                    },\r\n                    &quot;reporter&quot;: {\r\n                        &quot;active&quot;: true,\r\n                        &quot;avatarUrls&quot;: {\r\n                            &quot;16x16&quot;: &quot;https://mycompany/secure/useravatar?size=xsmall&amp;avatarId=10349&quot;,\r\n                            &quot;24x24&quot;: &quot;https://mycompany/secure/useravatar?size=small&amp;avatarId=10349&quot;,\r\n                            &quot;32x32&quot;: &quot;https://mycompany/secure/useravatar?size=medium&amp;avatarId=10349&quot;,\r\n                            &quot;48x48&quot;: &quot;https://mycompany/secure/useravatar?avatarId=10349&quot;\r\n                        },\r\n                        &quot;displayName&quot;: &quot;user2&quot;,\r\n                        &quot;emailAddress&quot;: &quot;user2@gmail.com&quot;,\r\n                        &quot;key&quot;: &quot;user2&quot;,\r\n                        &quot;name&quot;: &quot;user2&quot;,\r\n                        &quot;self&quot;: &quot;https://mycompany/rest/api/2/user?username=user2&quot;,\r\n                        &quot;timeZone&quot;: &quot;Zulu&quot;\r\n                    },\r\n                    &quot;resolution&quot;: null,\r\n                    &quot;resolutiondate&quot;: null,\r\n                    &quot;status&quot;: {\r\n                        &quot;description&quot;: &quot;&quot;,\r\n                        &quot;iconUrl&quot;: &quot;https://mycompany/images/icons/statuses/inprogress.png&quot;,\r\n                        &quot;id&quot;: &quot;3&quot;,\r\n                        &quot;name&quot;: &quot;In-Progress&quot;,\r\n                        &quot;self&quot;: &quot;https://mycompany/rest/api/2/status/3&quot;,\r\n                        &quot;statusCategory&quot;: {\r\n                            &quot;colorName&quot;: &quot;yellow&quot;,\r\n                            &quot;id&quot;: 4,\r\n                            &quot;key&quot;: &quot;indeterminate&quot;,\r\n                            &quot;name&quot;: &quot;In Progress&quot;,\r\n                            &quot;self&quot;: &quot;https://mycompany/rest/api/2/statuscategory/4&quot;\r\n                        }\r\n                    },\r\n                    &quot;subtasks&quot;: [],\r\n                    &quot;summary&quot;: &quot;Build the Fortimanage Portal&quot;,\r\n                    &quot;timeestimate&quot;: 0,\r\n                    &quot;timeoriginalestimate&quot;: 57600,\r\n                    &quot;timespent&quot;: 86400,\r\n                    &quot;updated&quot;: &quot;2018-01-31T15:22:06.000+0000&quot;,\r\n                    &quot;versions&quot;: [],\r\n                    &quot;votes&quot;: {\r\n                        &quot;hasVoted&quot;: false,\r\n                        &quot;self&quot;: &quot;https://mycompany/rest/api/2/issue/TECH-456/votes&quot;,\r\n                        &quot;votes&quot;: 0\r\n                    },\r\n                    &quot;watches&quot;: {\r\n                        &quot;isWatching&quot;: false,\r\n                        &quot;self&quot;: &quot;https://mycompany/rest/api/2/issue/TECH-456/watchers&quot;,\r\n                        &quot;watchCount&quot;: 1\r\n                    },\r\n                    &quot;workratio&quot;: 150\r\n                },\r\n                &quot;id&quot;: &quot;15377&quot;,\r\n                &quot;key&quot;: &quot;TECH-456&quot;,\r\n                &quot;self&quot;: &quot;https://mycompany/rest/api/2/issue/15377&quot;\r\n            }\r\n        ],\r\n        &quot;maxResults&quot;: 50,\r\n        &quot;startAt&quot;: 0,\r\n        &quot;total&quot;: 1\r\n    }\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48937230/searching-json-file-using-bash",
        "title": "Searching JSON file using bash"
    },
    {
        "tags": [
            "json",
            "templates",
            "jq",
            "inode"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1519358308,
                "last_edit_date": 1519358308,
                "creation_date": 1519342708,
                "answer_id": 48939006,
                "question_id": 48938815,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The short answer to your question is:\r\n(1) you will have to adopt a slightly different approach as the &quot;template&quot; file is neither valid JSON nor valid as a jq program\r\n(2) use `--argjson` instead of `--arg`, at least for the numbers (if your jq does not support --argjson, it&#39;s very old -- definitely time to upgrade :0)\r\n\r\nThe [jq Cookbook][1] has a section describing two simple approaches to templating with jq.  You&#39;d be much better off using one of those approaches if at all possible.\r\n\r\nThe following illustrates the &quot;$-variables&quot; approach using your template, modified so that the template variables are jq &quot;$-variables&quot;:\r\n\r\n    $ cat inode-template.jq\r\n    {\r\n      &quot;name&quot;: &quot;inodeparse&quot;,\r\n      &quot;metrics&quot;: [\r\n        {\r\n          &quot;event_type&quot;: &quot;test&quot;,\r\n          &quot;provider&quot;: &quot;test&quot;,\r\n          &quot;fileSystem&quot;: &quot;FILESYS&quot;,\r\n    \t  &quot;InodesTotal&quot;: $NODESTOTAL,\r\n          &quot;InodesUsed&quot;: $NODESUSED,\r\n          &quot;InodesFree&quot;: $NODESFREE,\r\n          &quot;InodeUsedPercent&quot;: $NODESPERCENT\r\n        }\r\n      ]\r\n    }\r\n\r\nNow we can instantiate the template using the --argjson command-line option of jq:\r\n\r\n    $ jq -n --argjson NODESTOTAL 1 --argjson NODESUSED 2 --argjson NODESFREE 3 --argjson NODESPERCENT 4 -f inode-template.jq\r\n    {\r\n      &quot;name&quot;: &quot;inodeparse&quot;,\r\n      &quot;metrics&quot;: [\r\n        {\r\n          &quot;event_type&quot;: &quot;test&quot;,\r\n          &quot;provider&quot;: &quot;test&quot;,\r\n          &quot;fileSystem&quot;: &quot;FILESYS&quot;,\r\n          &quot;InodesTotal&quot;: 1,\r\n          &quot;InodesUsed&quot;: 2,\r\n          &quot;InodesFree&quot;: 3,\r\n          &quot;InodeUsedPercent&quot;: 4\r\n        }\r\n      ]\r\n    }\r\n\r\nThe other approach is perfectly fine too.\r\n\r\nOf course, you could also use the field-assignment approach.  Indeed, all three approaches are mutually compatible.\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/Cookbook#using-jq-as-a-template-engine",
                "title": "jq &quot;Invalid numeric literal&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1519377766,
        "creation_date": 1519341493,
        "last_edit_date": 1519377766,
        "question_id": 48938815,
        "body_markdown": "I&#39;m trying to parse the output of a `df -i` command into a json template using jq, but I am receiving the following error when reading in numeric values from an array into the json template:\r\n\r\n    parse error: Invalid numeric literal at line 10, column 31\r\n\r\nHere is the script:\r\n\r\n    #!/bin/sh\r\n    \r\n    JSON=`cat inode-template.json`\r\n    \r\n    #get number of rows in output\r\n    numLines=`df -ih | wc -l`\r\n    \r\n    #row iterator (start at 2 to skip the header row)\r\n    for ((row=2; row&lt;=$numLines; row++))\r\n    do\r\n      arrCounter=0 #array counter reset\r\n      #for each value in col (minus &#39;mounted on&#39;):\r\n      for ((val=1; val&lt;=5; val++))\r\n      do\r\n        value=$(df -iP | awk -v value=$val &#39;NR==&#39;$row&#39;{sub( &quot;%&quot;, &quot;&quot;, $value); print $value }&#39;) #get each value\r\n        tempArr[$arrCounter]=$value #store row value\r\n        arrCounter=$((arrCounter + 1))\r\n      done\r\n      echo &quot;${tempArr[@]}&quot;\r\n      #Assign values in json template\r\n      JSON=$(jq -c --arg filesys &quot;${tempArr[0]}&quot; --arg iTotal ${tempArr[1]} --arg iUsed ${tempArr[2]} --arg iFree ${tempArr[3]} --arg iPercent ${tempArr[4]} &#39;.metrics[].fileSystem |= $filesys | .metrics[].InodesTotal |= $iTotal | .metrics[].InodesUsed |= $iUsed | .metrics[].InodesFree |= $iFree | .metrics[].InodeUsedPercent |= $iPercent&#39; inode-template.json)\r\n    \r\n      echo &quot;${JSON}&quot;\r\n      tempArr=() #reset array\r\n    done\r\n\r\nAnd here is the json template being read in:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;inodeparse&quot;,\r\n      &quot;metrics&quot;: [\r\n        {\r\n          &quot;event_type&quot;: &quot;test&quot;,\r\n          &quot;provider&quot;: &quot;test&quot;,\r\n          &quot;fileSystem&quot;: &quot;FILESYS&quot;,\r\n          &quot;InodesTotal&quot;:NODESTOTAL,\r\n          &quot;InodesUsed&quot;:NODESUSED,\r\n          &quot;InodesFree&quot;:NODESFREE,\r\n          &quot;InodeUsedPercent&quot;:NODESPERCENT\r\n        }\r\n      ]\r\n    }\r\n\r\nIs there any option to declare an array item as an integer before using jq to replace the value in the template?",
        "link": "https://stackoverflow.com/questions/48938815/jq-invalid-numeric-literal",
        "title": "jq &quot;Invalid numeric literal&quot;"
    },
    {
        "tags": [
            "c#",
            "bash",
            "shell",
            "datetime",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1519574333,
                "last_edit_date": 1519574333,
                "creation_date": 1519416666,
                "answer_id": 48955564,
                "question_id": 48954626,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I figured it out, I was doing the math wrong for the datetime tick conversion, the correct code looks like this:\r\n\r\n    getting_data_from_dynamo | jq -r &#39;\r\n      (.compoundid.s | split(&quot;-&quot;)[:2]) + \r\n       [.typeid.n, \r\n       (.datetime.n\r\n        | tonumber \r\n        | (. - 621355968000000000) / 10000000 \r\n        | strftime(&quot;%F %X&quot;))] \r\n      | @csv&#39;",
                "title": "Passing chained inputs to strftime"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1519574333,
        "creation_date": 1519412652,
        "last_edit_date": 1519441233,
        "question_id": 48954626,
        "body_markdown": "I am reading data from a Dynamo table and am trying to parse the input in `jq`. The date column is in C# ticks so I am trying to convert it to a normal datetime format that I can actually make insights with. I keep getting:\r\n\r\n    Assertion failed: (jv_get_kind(j) == JV_KIND_ARRAY), function jv_array_get, file jv.c, line 324.\r\n    Abort trap: 6\r\n\r\nThis is the code snippet I am trying to use:\r\n\r\n    getting_data_from_dynamo | jq -r &#39;[(.compoundid.s | split(&quot;-&quot;)[0]),\r\n    (.compoundid.s | split(&quot;-&quot;)[1]), .typeid.n, (.datetime.n | tonumber | . \r\n    - 62135596800 | strftime(&quot;%Y-%m-%d&quot;))] | @csv&#39;",
        "link": "https://stackoverflow.com/questions/48954626/passing-chained-inputs-to-strftime",
        "title": "Passing chained inputs to strftime"
    },
    {
        "tags": [
            "json",
            "bash",
            "equality",
            "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": 1,
                "creation_date": 1519419155,
                "post_id": 48956030,
                "comment_id": 84918899,
                "content_license": "CC BY-SA 3.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": 1519419203,
                "post_id": 48956030,
                "comment_id": 84918917,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7936404,
                    "reputation": 67,
                    "user_id": 5992235,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/da56dda4fd199249d39106da6120e2df?s=256&d=identicon&r=PG",
                    "display_name": "mohbar",
                    "link": "https://stackoverflow.com/users/5992235/mohbar"
                },
                "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": 1,
                "creation_date": 1519420941,
                "post_id": 48956030,
                "comment_id": 84919625,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1777232,
                    "reputation": 22015,
                    "user_id": 1620779,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://i.sstatic.net/dlgGb.png?s=256",
                    "display_name": "sjsam",
                    "link": "https://stackoverflow.com/users/1620779/sjsam"
                },
                "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": 1519421525,
                "post_id": 48956030,
                "comment_id": 84919844,
                "content_license": "CC BY-SA 3.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"
                },
                "reply_to_user": {
                    "account_id": 1777232,
                    "reputation": 22015,
                    "user_id": 1620779,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://i.sstatic.net/dlgGb.png?s=256",
                    "display_name": "sjsam",
                    "link": "https://stackoverflow.com/users/1620779/sjsam"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1519421591,
                "post_id": 48956030,
                "comment_id": 84919878,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1519421297,
                "last_edit_date": 1519421297,
                "creation_date": 1519420988,
                "answer_id": 48956415,
                "question_id": 48956030,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    jq &#39;.incidents[]| select(.links.policy_id==199383)&#39; file.json\r\n\r\nshould do it.\r\n\r\n**Output**\r\n\r\n    {\r\n      &quot;links&quot;: {\r\n        &quot;policy_id&quot;: 199383,\r\n        &quot;violations&quot;: [\r\n          69892478\r\n        ]\r\n      },\r\n      &quot;incident_preference&quot;: &quot;PER_CONDITION_AND_TARGET&quot;,\r\n      &quot;closed_at&quot;: 1519408001909,\r\n      &quot;opened_at&quot;: 1519407125437,\r\n      &quot;id&quot;: 17821334\r\n    }\r\n    {\r\n      &quot;links&quot;: {\r\n        &quot;policy_id&quot;: 199383,\r\n        &quot;violations&quot;: [\r\n          69889831\r\n        ]\r\n      },\r\n      &quot;incident_preference&quot;: &quot;PER_CONDITION_AND_TARGET&quot;,\r\n      &quot;closed_at&quot;: 1519408011851,\r\n      &quot;opened_at&quot;: 1519406230858,\r\n      &quot;id&quot;: 17820349\r\n    }\r\n    {\r\n      &quot;links&quot;: {\r\n        &quot;policy_id&quot;: 199383,\r\n        &quot;violations&quot;: [\r\n          69892488\r\n        ]\r\n      },\r\n      &quot;incident_preference&quot;: &quot;PER_CONDITION_AND_TARGET&quot;,\r\n      &quot;closed_at&quot;: 1519402345676,\r\n      &quot;opened_at&quot;: 1519401235467,\r\n      &quot;id&quot;: 17821334\r\n    }\r\n\r\nFrom [json.org](http://json.org/)\r\n\r\n&gt; A string is a sequence of zero or more Unicode characters, wrapped in\r\n&gt; **double quotes**, using backslash escapes. A character is represented as\r\n&gt; a single character string. A string is very much like a C or Java\r\n&gt; string.)\r\n\r\nand \r\n\r\n&gt; A number is very much like a C or Java number, except that the octal\r\n&gt; and hexadecimal formats are **not** used.\r\n\r\n\r\nSo `199383` is clearly different from `&quot;199383&quot;`. They are number and string respectively.\r\n\r\n&lt;sup&gt;**Note :** Emphasis in quoted text are mine. &lt;/sup&gt;",
                "title": "How to filter arrays in json based on specific value using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1519443193,
        "creation_date": 1519419054,
        "last_edit_date": 1519443193,
        "question_id": 48956030,
        "body_markdown": "I am trying to make a filter using jq to filter the arrays in this json to get only the arrays that have **&quot;policy_id&quot;: 199383** and exclude the arrays that contain different policy_id value. \r\n\r\n    {\r\n      &quot;links&quot;: {\r\n        &quot;policy_id&quot;: 199383,\r\n        &quot;violations&quot;: [\r\n          69892478\r\n        ]\r\n      },\r\n      &quot;incident_preference&quot;: &quot;PER_CONDITION_AND_TARGET&quot;,\r\n      &quot;closed_at&quot;: 1519408001909,\r\n      &quot;opened_at&quot;: 1519407125437,\r\n      &quot;id&quot;: 17821334\r\n    }\r\n    {\r\n      &quot;links&quot;: {\r\n        &quot;policy_id&quot;: 199383,\r\n        &quot;violations&quot;: [\r\n          69889831\r\n        ]\r\n      },\r\n      &quot;incident_preference&quot;: &quot;PER_CONDITION_AND_TARGET&quot;,\r\n      &quot;closed_at&quot;: 1519408011851,\r\n      &quot;opened_at&quot;: 1519406230858,\r\n      &quot;id&quot;: 17820349\r\n    }\r\n    {\r\n      &quot;links&quot;: {\r\n        &quot;policy_id&quot;: 194774,\r\n        &quot;violations&quot;: [\r\n          68446755\r\n        ]\r\n      },\r\n      &quot;incident_preference&quot;: &quot;PER_POLICY&quot;,\r\n      &quot;closed_at&quot;: 1518835775531,\r\n      &quot;opened_at&quot;: 1518835745303,\r\n      &quot;id&quot;: 17422347\r\n    }\r\n    {\r\n      &quot;links&quot;: {\r\n        &quot;policy_id&quot;: 199383,\r\n        &quot;violations&quot;: [\r\n          69892488\r\n        ]\r\n      },\r\n      &quot;incident_preference&quot;: &quot;PER_CONDITION_AND_TARGET&quot;,\r\n      &quot;closed_at&quot;: 1519402345676,\r\n      &quot;opened_at&quot;: 1519401235467,\r\n      &quot;id&quot;: 17821334\r\n    }\r\n\r\n\r\nI tried this :\r\njq &#39;.incidents[] | select (.links.policy_id == &quot;199383&quot;)&#39; file.json. But not having anything in return ? Can anyone help.\r\n\r\nThank you",
        "link": "https://stackoverflow.com/questions/48956030/how-to-filter-arrays-in-json-based-on-specific-value-using-jq",
        "title": "How to filter arrays in json based on specific value using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "logging",
            "jq",
            "jsonlines"
        ],
        "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": 1,
                "creation_date": 1519492537,
                "post_id": 48963263,
                "comment_id": 84936742,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 133765,
                    "reputation": 189,
                    "user_id": 1333746,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3bdeaaaa15fc2322ea78faab58921c9b?s=256&d=identicon&r=PG",
                    "display_name": "nelasx",
                    "link": "https://stackoverflow.com/users/1333746/nelasx"
                },
                "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": 1519495806,
                "post_id": 48963263,
                "comment_id": 84937721,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1519492232,
                "last_edit_date": 1519492232,
                "creation_date": 1519491542,
                "answer_id": 48965305,
                "question_id": 48963263,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "One way to add the item in temp.obj to the array in stats.json:\r\n\r\n    jq —-slurpfile temp temp.obj &#39;. + $temp&#39; stats.json\r\n\r\nAnother way:\r\n\r\n    jq —s &#39;.[0] + [.[1]]&#39; stats.json temp.json\r\n\r\n(If you want to overwrite stats.json, then I’d suggest using `sponge` as illustrated below.)\r\n\r\nHowever, if at all possible, it would almost certainly be better to maintain stats.json as a log file in JSONL format: http://jsonlines.org/\r\n\r\nThat is, each object in temp.json would be appended as a single line to stats.json:\r\n\r\n    jq -c temp.json &gt;&gt; stats.json\r\n\r\nThis of course assumes that stats.json is initially empty or already in the JSONL format.  To convert your existing stats.json to JSONL, you could do something like this:\r\n    \r\n    cp -p stats.json stats.json.bak\r\n\r\n    jq -c .[] stats.json | sponge stats.json",
                "title": "Append to array in json file from another json file with &quot;jq&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1575391020,
        "creation_date": 1519478031,
        "last_edit_date": 1575391020,
        "question_id": 48963263,
        "body_markdown": "i have a file &quot;stats.json&quot; with the following initial structure&quot;\r\n\r\n    [{\r\n    &quot;price&quot;: 66.55,\r\n    &quot;created&quot;: &quot;2018-02-24T14:32:57&quot;\r\n    }]\r\n\r\nWith a bash/curl script i take every 10 minutes data from an api and save it to &quot;temp.json&quot;\r\n\r\n    {\r\n    &quot;price&quot;: 88.55,\r\n    &quot;created&quot;: &quot;2018-02-24T15:32:57&quot;\r\n    }\r\n\r\nI would like to merge the temp.json (which is updated every 10min) and to fill the stats.json file. I tried to do it with &quot;jq&quot; but without success.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48963263/append-to-array-in-json-file-from-another-json-file-with-jq",
        "title": "Append to array in json file from another json file with &quot;jq&quot;"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1022874,
                    "reputation": 35264,
                    "user_id": 1032785,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/30816b3d787c2bd9d6f036318304f225?s=256&d=identicon&r=PG",
                    "display_name": "jordanm",
                    "link": "https://stackoverflow.com/users/1032785/jordanm"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1519629381,
                "post_id": 48983196,
                "comment_id": 84971225,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7795850,
                    "reputation": 53,
                    "user_id": 5896969,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/834d78c75af14971dcf1b5ef8c0bf372?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "m.brocks",
                    "link": "https://stackoverflow.com/users/5896969/m-brocks"
                },
                "reply_to_user": {
                    "account_id": 1022874,
                    "reputation": 35264,
                    "user_id": 1032785,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/30816b3d787c2bd9d6f036318304f225?s=256&d=identicon&r=PG",
                    "display_name": "jordanm",
                    "link": "https://stackoverflow.com/users/1032785/jordanm"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1519630543,
                "post_id": 48983196,
                "comment_id": 84971707,
                "content_license": "CC BY-SA 3.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": 0,
                "creation_date": 1519632058,
                "post_id": 48983196,
                "comment_id": 84972291,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1519636305,
                "creation_date": 1519636305,
                "answer_id": 48984894,
                "question_id": 48983196,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Short **`jq`** solution:\r\n\r\n    jq &#39;.features |= . + [.[-1]]&#39; red_line_nodes.json\r\nThe output:\r\n\r\n    {\r\n      &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n      &quot;features&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;Feature&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;LINE&quot;: &quot;RED&quot;,\r\n            &quot;STATION&quot;: &quot;Harvard&quot;\r\n          },\r\n          &quot;geometry&quot;: {\r\n            &quot;type&quot;: &quot;Point&quot;,\r\n            &quot;coordinates&quot;: [\r\n              -71.11890607237821,\r\n              42.37402923068516\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;Feature&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;LINE&quot;: &quot;RED&quot;,\r\n            &quot;STATION&quot;: &quot;Ashmont&quot;\r\n          },\r\n          &quot;geometry&quot;: {\r\n            &quot;type&quot;: &quot;Point&quot;,\r\n            &quot;coordinates&quot;: [\r\n              -71.06343014438998,\r\n              42.28388354622532\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;Feature&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;LINE&quot;: &quot;RED&quot;,\r\n            &quot;STATION&quot;: &quot;Ashmont&quot;\r\n          },\r\n          &quot;geometry&quot;: {\r\n            &quot;type&quot;: &quot;Point&quot;,\r\n            &quot;coordinates&quot;: [\r\n              -71.06343014438998,\r\n              42.28388354622532\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\n",
                "title": "How can I duplicate an existing object within a JSON array using jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1519655394,
                "creation_date": 1519655394,
                "answer_id": 48990793,
                "question_id": 48983196,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "For reference, an alternative to using `|= . + ...` is to use `+=`. In your case, however, you would have to write:\r\n\r\n    .features += [.features[-1]]\r\n\r\nso it&#39;s no shorter.",
                "title": "How can I duplicate an existing object within a JSON array using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1519655394,
        "creation_date": 1519629218,
        "last_edit_date": 1519629481,
        "question_id": 48983196,
        "body_markdown": "I have the following geojson file:\r\n\r\n    {\r\n    \t&quot;type&quot;: &quot;FeatureCollection&quot;,\r\n    \t&quot;features&quot;: [{\r\n    \t\t\t&quot;type&quot;: &quot;Feature&quot;,\r\n    \t\t\t&quot;properties&quot;: {\r\n    \t\t\t\t&quot;LINE&quot;: &quot;RED&quot;,\r\n    \t\t\t\t&quot;STATION&quot;: &quot;Harvard&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;geometry&quot;: {\r\n    \t\t\t\t&quot;type&quot;: &quot;Point&quot;,\r\n    \t\t\t\t&quot;coordinates&quot;: [-71.118906072378209, 42.37402923068516]\r\n    \t\t\t}\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;type&quot;: &quot;Feature&quot;,\r\n    \t\t\t&quot;properties&quot;: {\r\n    \t\t\t\t&quot;LINE&quot;: &quot;RED&quot;,\r\n    \t\t\t\t&quot;STATION&quot;: &quot;Ashmont&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;geometry&quot;: {\r\n    \t\t\t\t&quot;type&quot;: &quot;Point&quot;,\r\n    \t\t\t\t&quot;coordinates&quot;: [-71.063430144389983, 42.283883546225319]\r\n    \t\t\t}\r\n    \t\t}\r\n    \t]\r\n    }\r\n\r\nI would like to append the second object within the &quot;features&quot; array to the end of it, creating 3 total objects. Using the below snippet errors out with &quot;array ([{&quot;type&quot;:&quot;F...) and object ({&quot;type&quot;:&quot;Fe...) cannot be added&quot;. Is there a way to do this using jq without hardcoding the key:value pairs as seen [here][1]?\r\n\r\n    cat red_line_nodes.json | jq &#39;.features |= . + .[length-1]&#39; &gt; red_line_nodes_2.json\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/42245288/add-a-new-element-to-an-existing-json-array-using-jq",
        "link": "https://stackoverflow.com/questions/48983196/how-can-i-duplicate-an-existing-object-within-a-json-array-using-jq",
        "title": "How can I duplicate an existing object within a JSON array using jq?"
    },
    {
        "tags": [
            "json",
            "powershell",
            "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": 1519644511,
                "post_id": 48986743,
                "comment_id": 84979341,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1519644659,
                "last_edit_date": 1519644659,
                "creation_date": 1519643762,
                "answer_id": 48987220,
                "question_id": 48986743,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Unless otherwise instructed, jq produces valid JSON. `&quot;ve\\rsion&quot;` is not valid JSON. So one option would be to use the -r command-line option to convert the JSON string to “raw” text but this will only affect output entities that are actually strings; this option will also remove the outer quotation marks from such strings. \r\n\r\nYou might also want to consider post-processing of the output.\r\n\r\nThere may be other options, but without knowing your more detailed requirements, it’s hard to say which would be best.",
                "title": "JQ avoid adding extra backslash in produced json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1519644659,
        "creation_date": 1519642301,
        "last_edit_date": 1519643113,
        "question_id": 48986743,
        "body_markdown": "I&#39;m using powershell with JQ to create new value and append it to the existing valyue:\r\n\r\n    $resp.Content | jq --arg newtag &quot;ve\\rsion&quot; &#39;.items[] | del(.href, .version, .Config) | .tag |= $newtag | {&quot;Clusters&quot;: {&quot;desired_config&quot;: .}}&#39; &gt; newconfig.json\r\n\r\nProblem is that produced json file will have `&quot;ve\\\\rsion&quot;` instead of `&quot;ve\\rsion&quot;`\r\n\r\nhow can I keep only one backslash.",
        "link": "https://stackoverflow.com/questions/48986743/jq-avoid-adding-extra-backslash-in-produced-json",
        "title": "JQ avoid adding extra backslash in produced json"
    },
    {
        "tags": [
            "bash",
            "shell",
            "unix",
            "echo",
            "jq"
        ],
        "comments": [
            {
                "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": 1519657652,
                "post_id": 48991435,
                "comment_id": 84987705,
                "content_license": "CC BY-SA 3.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": 2,
                "creation_date": 1519657771,
                "post_id": 48991435,
                "comment_id": 84987775,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4863301,
                    "reputation": 332,
                    "user_id": 3922336,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/a5b875fbf3258d9f12180ffb0bd24857?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "umesh",
                    "link": "https://stackoverflow.com/users/3922336/umesh"
                },
                "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": 1519658990,
                "post_id": 48991435,
                "comment_id": 84988485,
                "content_license": "CC BY-SA 3.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": 1519661747,
                "post_id": 48991435,
                "comment_id": 84990271,
                "content_license": "CC BY-SA 3.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": 1519661852,
                "post_id": 48991435,
                "comment_id": 84990325,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1519659899,
                "creation_date": 1519659899,
                "answer_id": 48992095,
                "question_id": 48991435,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use the slurp option:\r\n\r\n    jq -s . in.json &gt; out.json\r\n\r\n**in.json**\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    {\r\n      &quot;key1&quot;: &quot;value1&quot;,\r\n      &quot;key2&quot;: &quot;value2&quot;\r\n    }\r\n    {\r\n      &quot;key1&quot;: &quot;value1&quot;,\r\n      &quot;key2&quot;: &quot;value2&quot;\r\n    }\r\n\r\n**out.json**\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    [\r\n      {\r\n        &quot;key1&quot;: &quot;value1&quot;,\r\n        &quot;key2&quot;: &quot;value2&quot;\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;key1&quot;: &quot;value1&quot;,\r\n        &quot;key2&quot;: &quot;value2&quot;\r\n      }\r\n    ]\r\n",
                "title": "Convert values from array in json object using bash shell"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1519661895,
                "last_edit_date": 1519661895,
                "creation_date": 1519660951,
                "answer_id": 48992402,
                "question_id": 48991435,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1) Your existing &quot;value=&quot; line can be simplified to:\r\n\r\n    value=$(jq -n --arg key1 &quot;$value1&quot; --arg key2 &quot;$value2&quot; &#39;\\\r\n       {key1: $value1, key2: $value2}&#39;)\r\n\r\nbecause `--arg` always interprets the provided value as a string, and because jq expressions need not follow all the rules of JSON.\r\n\r\n2) From your script, arr_value is a bash array of JSON values.  To convert it into a JSON array, you should be able to use an incantation such as:\r\n\r\n    for r in &quot;${a[@]}&quot; ; do printf &quot;%s&quot; &quot;$r&quot; ; done | jq -s .\r\n\r\n3) There is almost surely a much better way to achieve your ultimate goal. Perhaps it would help if you thought about calling jq just once.\r\n\r\n\r\n\r\n",
                "title": "Convert values from array in json object using bash shell"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1519661895,
        "creation_date": 1519657465,
        "last_edit_date": 1519658861,
        "question_id": 48991435,
        "body_markdown": "I am totaly new to shell..... let me ut the proper use case.\r\nUse case:- \r\nI have written two get method in my shell script, and when a user calls that script I will perform some operation for many id&#39;s using a for loop. like below\r\n\r\n    test_get1(){\r\n    \r\n    value1=//performing some operation and storing it\r\n    value2=//performing some operation and storing it\r\n    \r\n    //below line I am converting the o/p of value1 and value2 in json\r\n    \r\n    value=$JQ_TOOL -n --arg key1 &quot;$value1&quot; --arg key2 &quot;$value2&quot; &#39;{&quot;key1&quot;:&quot;\\($value1)&quot;,&quot;key2&quot;:&quot;\\($value2)&quot;}&#39;\r\n    \r\n    }\r\n    \r\n    test_get2(){\r\n    arr=(1,2,3)\r\n    local arr_values=()\r\n    for value in arr\r\n    do \r\n    // Calling test_get1 for each iteraion of this loop, like below\r\n    val=$(test_get1 $value)\r\n    //below line will store the values in array\r\n    arr_values+=(&quot;$val&quot;)\r\n    done \r\n    }\r\n\r\nWhen I am doing echo for the above arr_values, I am getting the below output\r\nOutput.\r\n    \r\n    arr_values={\r\n        &quot;key1&quot;:&quot;value1&quot;,\r\n        &quot;key2&quot;:&quot;value2&quot;\r\n        }\r\n        {\r\n        &quot;key1&quot;:&quot;value1&quot;,\r\n        &quot;key2&quot;:&quot;value2&quot;\r\n        }\r\n\r\n    \r\nI want to convert the above value in json format like below.\r\n    \r\n    json_value=[\r\n    {\r\n    &quot;key1&quot;:&quot;value1&quot;,\r\n    &quot;key2&quot;:&quot;value2&quot;\r\n    },\r\n    {\r\n    &quot;key1&quot;:&quot;value1&quot;,\r\n    &quot;key2&quot;:&quot;value2&quot;\r\n    }\r\n    ]\r\nI tried to do it with JQ, but unable to get the proper result.",
        "link": "https://stackoverflow.com/questions/48991435/convert-values-from-array-in-json-object-using-bash-shell",
        "title": "Convert values from array in json object using bash shell"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1519673289,
                "creation_date": 1519673289,
                "answer_id": 48995737,
                "question_id": 48994889,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Ended up using nested loop\r\n\r\n    for project in `cat 1.json  | jq -r .issues[].key`; do\r\n    \r\n      for parent in `cat 1.json  | jq -r .issues[].fields.project.key`; do\r\n         for custom_field in `cat 1.json  | jq -r .issues[].fields.customfield_10107.id`; do\r\n    \r\n          echo $i&gt;/tmp/ja.txt\r\n    \r\n    done\r\n      done\r\n        echo $project $parent  $custom_field\r\n        curl -D- -u user:pass -X POST --data &quot;{\\&quot;fields\\&quot;:{\\&quot;project\\&quot;:{\\&quot;key\\&quot;:\\&quot;$project\\&quot;},\\&quot;parent\\&quot;:{\\&quot;key\\&quot;:\\&quot;$parent\\&quot;},\\&quot;    summary\\&quot;:\\&quot;Test ChargenNr\\&quot;,\\&quot;description\\&quot;:\\&quot;some description\\&quot;,\\&quot;issuetype\\&quot;:{\\&quot;name\\&quot;:\\&quot;Sub-task\\&quot;},\\&quot;customfield_10107\\&quot;:{\\&quot;id\\&quot;:\\&quot;$custom_field\\&quot;}}}&quot; -H &quot;Content-Type:application/json&quot; https://jira.company.com/rest/api/latest/issue/\r\n        done\r\n\r\n",
                "title": "bash-for each value in JSON file execute command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1519673289,
        "creation_date": 1519669992,
        "last_edit_date": 1519671945,
        "question_id": 48994889,
        "body_markdown": "I have json file (1.json), i can iterate through it to find project,parent keys and custom fields\r\n\r\n    jq -r &#39;.issues[] | .key&#39; 1.json\r\n    jq -r &#39;.issues[] | .fields.project.key&#39; 1.json\r\n    jq -r &#39;.issues[] | .fields.customfield_10107.id&#39; 1.json\r\n\r\n\r\nOutput:\r\n\r\n    TECH-540\r\n    TECH-531\r\n    TECH-627\r\n    TECH-538\r\n    TECH-577\r\n    TECH-572\r\n    TECH-520\r\n    TECH-565\r\n    TECH-567\r\n    TECH\r\n    TECH\r\n    TECH\r\n    TECH\r\n    TECH\r\n    TECH\r\n    TECH\r\n    TECH\r\n    TECH\r\n    10400\r\n    10400\r\n    10400\r\n    10400\r\n    10400\r\n    10400\r\n    10400\r\n    10400\r\n    10400\r\n\r\nI want to store TECH-XXX to project=`jq -r &#39;.issues[] | .key&#39; 1.json`\r\nTECH to parent=`jq -r &#39;.issues[] | .fields.project.key&#39; 1.json`\r\n10400 to custom_field=`jq -r &#39;.issues[] | .fields.customfield_10107.id&#39; 1.json`\r\nvariable\r\nfor each value found in 1.json file do for loop following code (in this case run curl 9 times):\r\n\r\n    curl -D- -u user:pass -X POST --data &quot;{\\&quot;fields\\&quot;:{\\&quot;project\\&quot;:{\\&quot;key\\&quot;:\\&quot;$project\\&quot;},\\&quot;parent\\&quot;:{\\&quot;key\\&quot;:\\&quot;$parent\\&quot;},\\&quot;summary\\&quot;:\\&quot;Test ChargenNr\\&quot;,\\&quot;description\\&quot;:\\&quot;some description\\&quot;,\\&quot;issuetype\\&quot;:{\\&quot;name\\&quot;:\\&quot;Sub-task\\&quot;},\\&quot;customfield_10107\\&quot;:{\\&quot;id\\&quot;:\\&quot;$custom_field\\&quot;}}}&quot; -H &quot;Content-Type:application/json&quot; https://jira.company.com/rest/api/latest/issue/\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48994889/bash-for-each-value-in-json-file-execute-command",
        "title": "bash-for each value in JSON file execute command"
    },
    {
        "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": 1519675778,
                "post_id": 48996252,
                "comment_id": 84997908,
                "content_license": "CC BY-SA 3.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": 4,
                "creation_date": 1519675833,
                "post_id": 48996252,
                "comment_id": 84997929,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 13027965,
                    "reputation": 41,
                    "user_id": 9415313,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-nAAMp2B7QIQ/AAAAAAAAAAI/AAAAAAAAAfU/1fO7BP6tglg/s256-rj/photo.jpg",
                    "display_name": "Jorixine",
                    "link": "https://stackoverflow.com/users/9415313/jorixine"
                },
                "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": 1519676416,
                "post_id": 48996252,
                "comment_id": 84998203,
                "content_license": "CC BY-SA 3.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": 1519677079,
                "post_id": 48996252,
                "comment_id": 84998508,
                "content_license": "CC BY-SA 3.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": 1519677488,
                "post_id": 48996252,
                "comment_id": 84998689,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1519678325,
                "last_edit_date": 1592644375,
                "creation_date": 1519676453,
                "answer_id": 48996469,
                "question_id": 48996252,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**If** you can parse based on the first colon, this will do it:\n\n    jq -Rn &#39;[inputs | capture(&quot;(?&lt;key&gt;[^:]*): *(?&lt;value&gt;.*)&quot;)] | from_entries&#39;\n\nYou might want to add a filter to do further trimming.  (jq has `ltrimstr` and `rtrimstr` in case that helps.)\n\n## regex-free\nOr (apart from the trimming):\n\n    jq -Rn &#39;[inputs | index(&quot;:&quot;) as $i | {key: .[:$i], value: .[1+$i:]}] | from_entries&#39;\n\n## ldapsearch\nldapsearch has an option:\n\n&gt; -B\n&gt;\n&gt; Do not suppress display of non-ASCII values. ",
                "title": "Convert output to JSON using jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1668815222,
                "last_edit_date": 1668815222,
                "creation_date": 1668807652,
                "answer_id": 74495616,
                "question_id": 48996252,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Considering you are using ldapsearch with nowrap, you can use:\r\n\r\n    ldapsearch -LLL -E pr=1000/noprompt -o ldif-wrap=no &lt;put your stuff here&gt; |\r\n    jq --slurp --raw-input &#39;split(&quot;\\n\\n&quot;)|map(split(&quot;\\n&quot;)|map(select(.[0:1]!=&quot;#&quot; and length&gt;0)) |select(length &gt; 0)|map(capture(&quot;^(?&lt;key&gt;[^:]*:?): *(?&lt;value&gt;.*)&quot;) |if .key[-1:.key|length] == &quot;:&quot; then .key=.key[0:-1]|.value=(.value|@base64d) else . end)| group_by(.key) | map({key:.[0].key,value:[.[].value]})| from_entries)&#39;\r\n\r\nExplaining:\r\n\r\n    # Split entries by empty new lines\r\n    split(&quot;\\n\\n&quot;)|\r\n    # for each entry\r\n    map(\r\n      # split attribute on each entry\r\n      split(&quot;\\n&quot;)|\r\n      # drop comments and empty lines\r\n      map(select(.[0:1]!=&quot;#&quot; and length&gt;0)) |\r\n      # and empty arrays\r\n      select(length &gt; 0) |\r\n      # for each attribute\r\n      map(\r\n        # Capture key and value, keeping a trailing &quot;:&quot; for base64 \r\n        capture(&quot;^(?&lt;key&gt;[^:]*:?): *(?&lt;value&gt;.*)&quot;) |\r\n        # for those base64, decode the value and chomp the extra &quot;:&quot;\r\n        if .key[-1:.key|length] == &quot;:&quot; then .key=.key[0:-1]|.value=(.value|@base64d) else . end\r\n      )|\r\n     # Now group repeated attributes by attribute name\r\n     group_by(.key) |\r\n     # And join values\r\n     map({key:.[0].key,value:[.[].value]})|\r\n     # Finally, convert key/values to json\r\n     from_entries\r\n    )\r\n\r\n",
                "title": "Convert output to JSON using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1669190869,
                "creation_date": 1669190869,
                "answer_id": 74543510,
                "question_id": 48996252,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This can also be done without &quot;from_entries&quot; function:\r\n\r\n    jq -Rn &#39;[ inputs |split(&quot;: &quot;) |{ (.[0]):.[1] } ] |add&#39;",
                "title": "Convert output to JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1669190869,
        "creation_date": 1519675559,
        "question_id": 48996252,
        "body_markdown": "I need to convert this kind of output:\r\n\r\n    samaccountname: displayname\r\n    samaccountname2: displayname2\r\n\r\nto something like this:\r\n\r\n    {\r\n    &quot;samaccountname&quot;: &quot;displayname&quot;,\r\n    &quot;samaccountname2&quot;: &quot;displayname2&quot;\r\n    }\r\n\r\n\r\nCould you please give me a hand?\r\n\r\nThanks!\r\n\r\nBTW, this is the output of an LDAP Search Query, so it needs to work receiving the data from pipe / stdin.\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/48996252/convert-output-to-json-using-jq",
        "title": "Convert output to JSON using jq"
    },
    {
        "tags": [
            "json",
            "select",
            "edit",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2724027,
                    "reputation": 1414,
                    "user_id": 2455413,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/d5f605b90e549940e68194f6575132df?s=256&d=identicon&r=PG",
                    "display_name": "markling",
                    "link": "https://stackoverflow.com/users/2455413/markling"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1614079733,
                "post_id": 48997962,
                "comment_id": 117269408,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1519683452,
                "creation_date": 1519683452,
                "answer_id": 48998014,
                "question_id": 48997962,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq &#39;.BackupCfg |= map(select(.type == &quot;filesystem&quot;))&#39; file.json\r\nThe output:\r\n\r\n    {\r\n      &quot;BackupCfg&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;filesystem&quot;,\r\n          &quot;repository&quot;: &quot;trunk&quot;,\r\n          &quot;url&quot;: &quot;test.example.com&quot;,\r\n          &quot;port&quot;: &quot;394&quot;,\r\n          &quot;cfg&quot;: [\r\n            {\r\n              &quot;Default&quot;: &quot;true&quot;,\r\n              &quot;ID&quot;: &quot;trunk00&quot;,\r\n              &quot;Paths&quot;: [\r\n                &quot;/etc&quot;,\r\n                &quot;/home&quot;,\r\n                &quot;/var&quot;,\r\n                &quot;/usr/local&quot;,\r\n                &quot;/opt&quot;,\r\n                &quot;/root&quot;\r\n              ],\r\n              &quot;Cron&quot;: &quot;33 0 * * *&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;filesystem&quot;,\r\n          &quot;repository&quot;: &quot;trunk02&quot;,\r\n          &quot;url&quot;: &quot;test.example.com&quot;,\r\n          &quot;port&quot;: &quot;394&quot;,\r\n          &quot;cfg&quot;: [\r\n            {\r\n              &quot;ID&quot;: &quot;trunk01&quot;,\r\n              &quot;Paths&quot;: [\r\n                &quot;/opt/example&quot;,\r\n                &quot;/opt/var_example&quot;\r\n              ],\r\n              &quot;Cron&quot;: &quot;*/30 0-23 * * *&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nhttps://stedolan.github.io/jq/manual/v1.5/#select(boolean_expression)",
                "title": "jq json filter and keep original structure"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1519712070,
        "creation_date": 1519683175,
        "last_edit_date": 1519712070,
        "question_id": 48997962,
        "body_markdown": "I am really new to the command jq, and I am trying do some filtering to remove blocks of data that I don&#39;t want/need.\r\n\r\nHere is an example of my JSON structure:\r\n\r\n    {\r\n      &quot;BackupCfg&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;filesystem&quot;,\r\n          &quot;repository&quot;: &quot;trunk&quot;,\r\n          &quot;url&quot;: &quot;test.example.com&quot;,\r\n          &quot;port&quot;: &quot;394&quot;,\r\n          &quot;cfg&quot;: [\r\n            {\r\n              &quot;Default&quot;: &quot;true&quot;,\r\n              &quot;ID&quot;: &quot;trunk00&quot;,\r\n              &quot;Paths&quot;: [\r\n                &quot;/etc&quot;,\r\n                &quot;/home&quot;,\r\n                &quot;/var&quot;,\r\n                &quot;/usr/local&quot;,\r\n                &quot;/opt&quot;,\r\n                &quot;/root&quot;\r\n              ],\r\n              &quot;Cron&quot;: &quot;33 0 * * *&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;filesystem&quot;,\r\n          &quot;repository&quot;: &quot;trunk02&quot;,\r\n          &quot;url&quot;: &quot;test.example.com&quot;,\r\n          &quot;port&quot;: &quot;394&quot;,\r\n          &quot;cfg&quot;: [\r\n            {\r\n              &quot;ID&quot;: &quot;trunk01&quot;,\r\n              &quot;Paths&quot;: [\r\n                &quot;/opt/example&quot;,\r\n                &quot;/opt/var_example&quot;\r\n              ],\r\n              &quot;Cron&quot;: &quot;*/30 0-23 * * *&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;database&quot;,\r\n          &quot;repository&quot;: &quot;trunk-db&quot;,\r\n          &quot;url&quot;: &quot;test.example.com&quot;,\r\n          &quot;port&quot;: &quot;399&quot;,\r\n          &quot;cfg&quot;: [\r\n            {\r\n              &quot;Default&quot;: &quot;true&quot;,\r\n              &quot;ID&quot;: &quot;trunk00&quot;,\r\n              &quot;db_type&quot;: &quot;mysql&quot;,\r\n              &quot;db_hostname&quot;: &quot;localhost&quot;,\r\n              &quot;db_port&quot;: &quot;3306&quot;,\r\n              &quot;db_user&quot;: &quot;root&quot;,\r\n              &quot;db_pwd&quot;: &quot;password&quot;,\r\n              &quot;databases&quot;: [],\r\n              &quot;Cron&quot;: &quot;40 0 * * *&quot;\r\n            },\r\n            {\r\n              &quot;ID&quot;: &quot;trunk01&quot;,\r\n              &quot;db_type&quot;: &quot;mysql&quot;,\r\n              &quot;db_hostname&quot;: &quot;localhost&quot;,\r\n              &quot;db_port&quot;: &quot;3307&quot;,\r\n              &quot;db_user&quot;: &quot;riit&quot;,\r\n              &quot;db_pwd&quot;: &quot;passwird&quot;,\r\n              &quot;databases&quot;: [],\r\n              &quot;Cron&quot;: &quot;33 3 * * *&quot;\r\n            },\r\n            {\r\n              &quot;Default&quot;: &quot;false&quot;,\r\n              &quot;ID&quot;: &quot;trunk02&quot;,\r\n              &quot;db_type&quot;: &quot;postgres&quot;,\r\n              &quot;db_hostname&quot;: &quot;localhost&quot;,\r\n              &quot;db_port&quot;: &quot;3308&quot;,\r\n              &quot;db_user&quot;: &quot;ruut&quot;,\r\n              &quot;db_pwd&quot;: &quot;passwurd&quot;,\r\n              &quot;databases&quot;: [],\r\n              &quot;Cron&quot;: &quot;0 10 * * *&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nI want to filter this in order to have only the &quot;type&quot;: &quot;filesystem&quot;, and get the following output:\r\n\r\n    {\r\n      &quot;BackupCfg&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;filesystem&quot;,\r\n          &quot;repository&quot;: &quot;trunk&quot;,\r\n          &quot;url&quot;: &quot;test.example.com&quot;,\r\n          &quot;port&quot;: &quot;394&quot;,\r\n          &quot;cfg&quot;: [\r\n            {\r\n              &quot;Default&quot;: &quot;true&quot;,\r\n              &quot;ID&quot;: &quot;trunk00&quot;,\r\n              &quot;Paths&quot;: [\r\n                &quot;/etc&quot;,\r\n                &quot;/home&quot;,\r\n                &quot;/var&quot;,\r\n                &quot;/usr/local&quot;,\r\n                &quot;/opt&quot;,\r\n                &quot;/root&quot;\r\n              ],\r\n              &quot;Cron&quot;: &quot;33 0 * * *&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;filesystem&quot;,\r\n          &quot;repository&quot;: &quot;trunk02&quot;,\r\n          &quot;url&quot;: &quot;test.example.com&quot;,\r\n          &quot;port&quot;: &quot;394&quot;,\r\n          &quot;cfg&quot;: [\r\n            {\r\n              &quot;ID&quot;: &quot;trunk01&quot;,\r\n              &quot;Paths&quot;: [\r\n                &quot;/opt/example&quot;,\r\n                &quot;/opt/var_example&quot;\r\n              ],\r\n              &quot;Cron&quot;: &quot;*/30 0-23 * * *&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nI have try some commands like\r\n\r\n    jq  &#39;.[][] | select(.type | contains(&quot;filesystem&quot;))&#39;\r\n\r\nBut it destroys the original structure.\r\n\r\nI have searched around, and found lots of example, but lots doesn&#39;t work, or doesn&#39;t give me what I need. \r\n\r\nHas someone any ideas?\r\nIf someone has also any good learning website in order to understand jq, that would be awesome!\r\n\r\nThanks in advance!",
        "link": "https://stackoverflow.com/questions/48997962/jq-json-filter-and-keep-original-structure",
        "title": "jq json filter and keep original structure"
    },
    {
        "tags": [
            "json",
            "try-catch",
            "posix",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1519749519,
                "last_edit_date": 1592644375,
                "creation_date": 1519749519,
                "answer_id": 49013651,
                "question_id": 49004447,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I wanted to try\n&gt;\n&gt;    jq -r &#39;try .data |= fromjson catch &quot;STRING&quot;&#39;\n\nThis is one of the occasions when you have to help the parser by using parentheses:\n\n    jq -r &#39;try (.data |= fromjson) catch &quot;STRING&quot;&#39;",
                "title": "Unable to handle error in jq when value is not object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1519776465,
        "creation_date": 1519720949,
        "last_edit_date": 1519776465,
        "question_id": 49004447,
        "body_markdown": "I am trying to simplify &quot;try-catch&quot; for checking if value of &quot;.data&quot; element contain next object or simple string. And on top of that want to eliminate errors reported to standard output (other way then generic redirection to /dev/null)\r\n\r\nI am using currently this:\r\n\r\n        json2=`$APPFOLDER/jq -c &#39;.data |= fromjson&#39; &lt;&lt;&lt; $json`\r\n\r\n        if [[ ! $json2 ]]\r\n          then\r\n            json2=`$APPFOLDER/jq -c &#39;.data |= { text: .}&#39; &lt;&lt;&lt; $json`\r\n            json2=`$APPFOLDER/jq -c &#39;.data |= { message: .}&#39; &lt;&lt;&lt; $json2`\r\n        fi\r\nin order to move eventual simple string into **.data.message.text** element\r\n\r\nBut isn&#39;t there simplier way how to do it? \r\nOf course it reports error to standard output like \r\n\r\n    jq: error (at &lt;stdin&gt;:1): Invalid numeric literal at line 1, column 9 (while parsing &#39;HTTP/1.1 403 Forbidden\r\n    Date: Tue, 27 Feb 2018 08:13:32 GMT\r\n    Server:\r\n    Connection: close\r\n    X-CorrelationID: Id-2c13955ae3bb6c3cc943460b 0\r\n    Content-Type: text/html\r\n    \r\n    Access Denied&#39;)\r\n\r\nI wanted to try \r\n\r\n    jq -r &#39;try .data |= fromjson catch &quot;STRING&quot;&#39;\r\nbut it is giving me error:\r\n\r\n    jq: error: syntax error, unexpected catch, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    try .data |= fromjson catch &quot;STRING&quot;                      \r\n    jq: 1 compile error\r\n    exit status 3\r\n\r\nhere is sample message:\r\n\r\n&gt; {&quot;correlationId&quot;:&quot;2c13955ae3bb6c3cc943460b&quot;,&quot;leg&quot;:0,&quot;tag&quot;:&quot;sent&quot;,&quot;offset&quot;:167408,&quot;len&quot;:178,&quot;prev&quot;:{&quot;page&quot;:{&quot;file&quot;:10481,&quot;page&quot;:2},&quot;record&quot;:1736},&quot;data&quot;:&quot;HTTP/1.1\r\n&gt; 403 Forbidden\\r\\nDate: Tue, 27 Feb 2018 08:13:32 GMT\\r\\nServer:\r\n&gt; \\r\\nConnection: close\\r\\nX-CorrelationID: Id-2c13955ae3bb6c3cc943460b\r\n&gt; 0\\r\\nContent-Type: text/html\\r\\n\\r\\nAccess Denied&quot;}\r\n",
        "link": "https://stackoverflow.com/questions/49004447/unable-to-handle-error-in-jq-when-value-is-not-object",
        "title": "Unable to handle error in jq when value is not object"
    },
    {
        "tags": [
            "json",
            "traversal",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1519753171,
                "post_id": 49014616,
                "comment_id": 85034282,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2087726,
                    "reputation": 733,
                    "user_id": 3735961,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6505b08e8dd3f3967dbd95a4de09c0e9?s=256&d=identicon&r=PG",
                    "display_name": "Cristian",
                    "link": "https://stackoverflow.com/users/3735961/cristian"
                },
                "reply_to_user": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1519760063,
                "post_id": 49014616,
                "comment_id": 85038088,
                "content_license": "CC BY-SA 3.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": 1519803094,
                "post_id": 49014616,
                "comment_id": 85052942,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2087726,
                    "reputation": 733,
                    "user_id": 3735961,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6505b08e8dd3f3967dbd95a4de09c0e9?s=256&d=identicon&r=PG",
                    "display_name": "Cristian",
                    "link": "https://stackoverflow.com/users/3735961/cristian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1519818249,
                "post_id": 49014616,
                "comment_id": 85061720,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1519760425,
                "last_edit_date": 1519760425,
                "creation_date": 1519754880,
                "answer_id": 49015229,
                "question_id": 49014616,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "### &quot;The question&quot;\r\n\r\nIn answer to **The question**: Yes. jq 1.5 has `keys_unsorted`, so you can use the following def of `walk/1`, which is now standard in the “master” version of jq:\r\n  \r\n    # Apply f to composite entities recursively, and to atoms\r\n    def walk(f):\r\n      . as $in\r\n      | if type == &quot;object&quot; then\r\n          reduce keys_unsorted[] as $key\r\n            ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\r\n      elif type == &quot;array&quot; then map( walk(f) ) | f\r\n      else f\r\n      end;\r\n\r\nFor further details and examples, see the “development” version of the jq manual, the jq FAQ https://github.com/stedolan/jq/wiki/FAQ, etc.\r\n\r\n### &quot;No duplicates are allowed within the elements of an array&quot;\r\nThis is readily accomplished using `index/1`; you might like to use a helper function such as:\r\n\r\n    def ensure_has($x): if index([$x]) then . else . + [$x] end;\r\n\r\n### &quot;If any of the parents of .name do not exist, should be able to add them on the fly&quot;\r\n\r\nIf I understand this requirement correctly, it will useful for you to know that jq will create objects based on assignments, e.g.\r\n\r\n    {} | .a.b.c = 1\r\n\r\nyields \r\n\r\n    {&quot;a&quot;:{&quot;b&quot;:{&quot;c&quot;:1}}}\r\n\r\nThus, using your example, you will probably want to include something like this in your `walk`:\r\n\r\n    if type == &quot;object&quot; and has(&quot;spec&quot;)\r\n       then (.spec.template.spec.containers? // null) as $existing\r\n       | if $existing then .spec.template.spec.containers |= ... \r\n\t     else .spec.template.spec.containers = ...\r\n         end\r\n    else .\r\n\tend",
                "title": "jq 1.5 - Change existing element or add new if does not exist"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1519817742,
                "last_edit_date": 1519817742,
                "creation_date": 1519787449,
                "answer_id": 49021363,
                "question_id": 49014616,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Managed to reach a very good form:\r\n\r\n1. Added the following functions in `~/.jq`:\r\n\r\n\t\tdef arr:\r\n\t\t\tif length&lt;=0 then .[0] else .[] end;\r\n\r\n\t\tdef arr(f):\r\n\t\t\tif length&lt;=0 then\r\n\t\t\t\t.[0]\r\n\t\t\telse\r\n\t\t\t\t.[]|select(f)\r\n            end//.[length];\r\n\t\t\t\r\n\t\tdef when(COND; ACTION):\r\n\t\t\tif COND? // null then ACTION else . end;\r\n\r\n        # Apply f to composite entities recursively, and to atoms\r\n        def walk(f):\r\n          . as $in\r\n          | if type == &quot;object&quot; then\r\n              reduce keys_unsorted[] as $key\r\n                ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\r\n          elif type == &quot;array&quot; then map( walk(f) ) | f\r\n          else f\r\n          end;\r\n\r\n        def updobj(f):\r\n          walk(when(type==&quot;object&quot;; f));\r\n\r\n2. A typical filter will look like this:\r\n\r\n        jq -r &#39;{name:&quot;CHANGEME&quot;,value: &quot;xx&quot;} as $v |\r\n            map( when(.kind == &quot;StatefulSet&quot;;\r\n                      .spec.template.spec.containers|arr|.env|arr(.name==$v.name)) |= $v)&#39;\r\n\r\nThe result will be that all objects that do not exist already will be created. The convention here is to use the `arr` functions for each object that you want to be an array, and at the end use a boolean condition and an object to replace the matched one or add to the parent array, if not matched.\r\n\r\n3. If you know the path is always there, and so are the object you want to update, `walk` is more elegant:\r\n\r\n        jq -r &#39;map(updobj(select(.name==&quot;CHANGEME&quot;).value|=&quot;xx&quot;))&#39;\r\n\r\n\r\n----------\r\n\r\n\r\nThank you @peak for your effort and inspiring the solution.",
                "title": "jq 1.5 - Change existing element or add new if does not exist"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1521584411,
        "creation_date": 1519752570,
        "last_edit_date": 1521584411,
        "question_id": 49014616,
        "body_markdown": "# Using:\r\n\r\n- jq-1.5-1-a5b5cbe (Ubuntu 17.10)\r\n- Compose the queries: https://jqplay.org/\r\n\r\n# Goals and conditions:\r\n\r\n1. Replace an child object value with another value, at any depth, having parents objects or arrays, for example:\r\n    - if .spec.template.spec.containers[**n**].env[**n**]**.name** == &quot;CHANGEME&quot; then\r\n    - .spec.template.spec.containers[**n**].env[**n**]**.value** = &quot;xx&quot;\r\n    - where **n** &gt;=0\r\n2. If any of the parents of **.name** do not exist, should be able to add them on the fly instead of exiting with an error\r\n3. The output JSON should have at least the same elements as the input JSON, no existing elements should be lost\r\n4. No duplicates are allowed within the elements of an array, but the order **must be preserved**, so functions like `unique` cannot be used\r\r\n\r\n# Sample input JSON:\r\n\r\nThe structure is actually imposed, so I have to obey it. An object &quot;path&quot; usually is something like: `.spec.template.spec.containers[0].spec.env[1].name`. You could also have .containers[1], and so on. This is highly variable, and sometimes some elements **could** exist or not, depends on a schema definition of that particular JSON.\r\n\r\n    [\r\n      {\r\n        &quot;kind&quot;: &quot;StatefulSet&quot;,\r\n        &quot;spec&quot;: {\r\n          &quot;serviceName&quot;: &quot;cassandra&quot;,\r\n          &quot;template&quot;: {\r\n            &quot;spec&quot;: {\r\n              &quot;containers&quot;: [\r\n                {\r\n                  &quot;name&quot;: &quot;cassandra&quot;,\r\n                  &quot;env&quot;: [\r\n                    {\r\n                      &quot;name&quot;: &quot;CASSANDRA_SEEDS&quot;,\r\n                      &quot;value&quot;: &quot;cassandra-0.cassandra.kong.svc.cluster.local&quot;\r\n                    },\r\n                    {\r\n                      &quot;name&quot;: &quot;CHANGEME&quot;,\r\n                      &quot;value&quot;: &quot;K8&quot;\r\n                    }\r\n                  ]\r\n                }\r\n              ]\r\n            }\r\n          }\r\n        }\r\n      }\r\n    ]\r\n\r\n# Scenarios\r\n\r\n1. Replace an existing value while preserving the input structure, works as expected:\r\n    - `jq -r &#39;map({name:&quot;CHANGEME&quot;,value: &quot;xx&quot;} as $v | (.spec.template.spec.containers[].env[] | select(.name==$v.name))|=$v)&#39;`\r\n2. Let&#39;s assume I want to do the same, only that .env1 is the parent array of the object {name:&quot;&quot;,value:&quot;&quot;}. The expected output should be:\r\n\r\n        [\r\n          {\r\n            &quot;kind&quot;: &quot;StatefulSet&quot;,\r\n            &quot;spec&quot;: {\r\n              &quot;serviceName&quot;: &quot;cassandra&quot;,\r\n              &quot;template&quot;: {\r\n                &quot;spec&quot;: {\r\n                  &quot;containers&quot;: [\r\n                    {\r\n                      &quot;name&quot;: &quot;cassandra&quot;,\r\n                      &quot;env&quot;: [\r\n                        {\r\n                          &quot;name&quot;: &quot;CASSANDRA_SEEDS&quot;,\r\n                          &quot;value&quot;: &quot;cassandra-0.cassandra.kong.svc.cluster.local&quot;\r\n                        },\r\n                        {\r\n                          &quot;name&quot;: &quot;CHANGEME&quot;,\r\n                          &quot;value&quot;: &quot;K8&quot;\r\n                        }\r\n                      ],\r\n                      &quot;env1&quot;: [\r\n                        {\r\n                          &quot;name&quot;: &quot;CHANGEME&quot;,\r\n                          &quot;value&quot;: &quot;xx&quot;\r\n                        }\r\n                      ]\r\n                    }\r\n                  ]\r\n                }\r\n              }\r\n            }\r\n          }\r\n        ]\r\n\r\n    - For this, I have tried to add an object env1 on the fly:\r\n        - `jq -r &#39;map({name:&quot;CHANGEME&quot;,value: &quot;xx&quot;} as $v | (.spec.template.spec.containers[] | if .env1 ==  null then .+={env1:[$v]} | .env1  else .env1 end | .[] | select(.name==$v.name))|=$v)&#39;`\r\n            - works if **.env1** exists, else:\r\n            - error: Invalid path expression near attempt to access element &quot;env1&quot; of {&quot;name&quot;:&quot;cassandra&quot;,&quot;env&quot;..\r\n            - same results if using notations like `.env//[$v]` or `.env//=.env[$v]`\r\n        - `jq -r &#39;map({name:&quot;CHANGEME&quot;,value: &quot;xx&quot;} as $v | (.spec.template.spec.containers[].env1 | .[if length&lt;0 then 0 else length end]) |= $v)&#39;`\r\n            - works if .env1 does **not** exist\r\n            - adds another element if the array .env1 exists, potentially duplicating objects\r\n    - Eventually I have managed to create a working filter:\r\n        - `jq -r &#39;def defarr: if length&lt;=0 then .[0] else .[] end; def defarr(item): if length&lt;=0 then .[0] else foreach .[] as $item ([]; if $item.name == item then $item else empty end; .) end; map({name:&quot;CHANGEME&quot;,value: &quot;xx&quot;} as $v | (.spec.template.spec | .containers1 | defarr | .env1 | defarr($v.name) ) |=$v)&#39;`\r\n            - this works as expected, however is too long and heavy and have to add the custom functions after each potential array in the object hierarchy\r\n\r\n# The question \r\nIs there any way to simplify all this, make it a bit more generic to handle any number of parents, arrays or not?\r\n\r\nThank you.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/49014616/jq-1-5-change-existing-element-or-add-new-if-does-not-exist",
        "title": "jq 1.5 - Change existing element or add new if does not exist"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3866180,
                    "reputation": 2931,
                    "user_id": 3202696,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://i.sstatic.net/QmN8u.png?s=256",
                    "display_name": "TobiSH",
                    "link": "https://stackoverflow.com/users/3202696/tobish"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1519820844,
                "post_id": 49029532,
                "comment_id": 85063325,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1519824599,
                "creation_date": 1519824599,
                "answer_id": 49030756,
                "question_id": 49029532,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq &#39;. as $o | [ keys_unsorted[] \r\n                    | {(.) : (reduce $o[.].list[] as $i (0; . + $i.count))} ] | add&#39; file.json\r\nThe output:\r\n\r\n    {\r\n      &quot;groupId1&quot;: 5,\r\n      &quot;groupId2&quot;: 4\r\n    }\r\n\r\n",
                "title": "How group and sum items using jq?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1519839816,
                "creation_date": 1519839816,
                "answer_id": 49035601,
                "question_id": 49029532,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This is one of those cases where having the following definition in your ~/.jq or jq &quot;standard library&quot; really helps:\r\n\r\n    def sigma(stream): reduce stream as $x (null; . + $x );\r\n\r\nWith that, you can just write the very readable:\r\n\r\n    map_values( sigma(.list[] | .count ))\r\n",
                "title": "How group and sum items using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1519839816,
        "creation_date": 1519820653,
        "question_id": 49029532,
        "body_markdown": "I have following JSON:\r\n\r\n    {  \r\n      &quot;groupId1&quot; : {\r\n         &quot;list&quot; : [\r\n           {\r\n           &quot;field1&quot;: &quot;somevalue&quot;,\r\n           &quot;count&quot;: 2,\r\n           &quot;field3&quot;: &quot;somevalue&quot;\r\n           },\r\n           {\r\n           &quot;field1&quot;: &quot;somevalue&quot;,\r\n           &quot;count&quot;: 3,\r\n           &quot;field3&quot;: &quot;somevalue&quot;\r\n           }\r\n         ]\r\n       },\r\n      &quot;groupId2&quot; : {\r\n         &quot;list&quot; : [\r\n           {\r\n           &quot;field1&quot;: &quot;somevalue&quot;,\r\n           &quot;count&quot;: 0,\r\n           &quot;field3&quot;: &quot;somevalue&quot;\r\n           },\r\n           {\r\n           &quot;field1&quot;: &quot;somevalue&quot;,\r\n           &quot;count&quot;: 4,\r\n           &quot;field3&quot;: &quot;somevalue&quot;\r\n           }\r\n         ]\r\n       },     \r\n     ...\r\n    }\r\n\r\nAnd result i want to achieve(using jq) is:\r\n\r\n    [\r\n      &quot;groupId1&quot;:5,\r\n      &quot;groupId2&quot;:4\r\n    ]\r\nEach group has exactly one &quot;list&quot; element.\r\n\r\nI understand that i shoud use group by and sum, but i can&#39;t get it work.",
        "link": "https://stackoverflow.com/questions/49029532/how-group-and-sum-items-using-jq",
        "title": "How group and sum items using jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "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": 1519832718,
                "post_id": 49032866,
                "comment_id": 85071445,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 52868,
                    "reputation": 2541,
                    "user_id": 158026,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/7fe97c752a2ceafa12a11387ceaaa5d5?s=256&d=identicon&r=PG",
                    "display_name": "rbanffy",
                    "link": "https://stackoverflow.com/users/158026/rbanffy"
                },
                "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": 1519921166,
                "post_id": 49032866,
                "comment_id": 85112794,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1519837697,
                "creation_date": 1519837697,
                "answer_id": 49035009,
                "question_id": 49032866,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I have no idea how robust this is, but it gets the desired result in this case.\r\n\r\n    jq -S &#39;.&#39; | jq &#39;{id} + .&#39;",
                "title": "Almost automatically sorting keys with `jq`, but keep &quot;id&quot; key, if present, on top"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1519849184,
                "last_edit_date": 1519849184,
                "creation_date": 1519848857,
                "answer_id": 49037808,
                "question_id": 49032866,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming you are using jq 1.4 or later, the following will do what is requested for all the JSON objects in the input, not only those at the top level:\r\n\r\n    def reorder:\r\n      (if has(&quot;id&quot;) then {id} else null end) + (to_entries | sort | from_entries );\r\n\r\n    walk(if type == &quot;object&quot; then reorder else . end)\r\n\r\nIf your jq does not have `walk/1`, you can snarf its def from the jq FAQ https://github.com/stedolan/jq/wiki/FAQ or from the &quot;master&quot; version of [builtin.jq][1]  \r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/blob/master/src/builtin.jq",
                "title": "Almost automatically sorting keys with `jq`, but keep &quot;id&quot; key, if present, on top"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1519849184,
        "creation_date": 1519831014,
        "question_id": 49032866,
        "body_markdown": "Is there a way to sort the keys of a JSON using `jq` but keeping keys named &quot;id&quot; as first descendants on all trees? It&#39;s nice to have a way to easily compare JSON files to one another and normalizing key order and formatting is a great way to ensure they are easy to match, but sometimes the &quot;id&quot; key is the one we are looking for and it&#39;s not always easy to find if it&#39;s buried in the middle of the tree.\r\n\r\nAs an example, this:\r\n\r\n    {\r\n        &quot;z-displacement&quot;: 3,\r\n        &quot;absorption&quot;: 0.4,\r\n        &quot;collections&quot;: [\r\n            {\r\n                &quot;b&quot;: 12,\r\n                &quot;a&quot;: 18,\r\n                &quot;id&quot; 190:,\r\n            },\r\n            {\r\n                &quot;m&quot;: 22,\r\n                &quot;id&quot;: 169,\r\n                &quot;n&quot;: 3,\r\n            },\r\n        ],\r\n        &quot;id&quot;: 256767\r\n    }\r\n\r\nWould become something like:\r\n\r\n    {\r\n        &quot;id&quot;: 256767,\r\n        &quot;absorption&quot;: 0.4,\r\n        &quot;collections&quot;: [\r\n            {\r\n                &quot;id&quot; 190:,\r\n                &quot;a&quot;: 18,\r\n                &quot;b&quot;: 12\r\n            },\r\n            {\r\n                &quot;id&quot;: 169,\r\n                &quot;m&quot;: 22,\r\n                &quot;n&quot;: 3\r\n            }\r\n        ],\r\n        &quot;z-displacement&quot;: 3\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/49032866/almost-automatically-sorting-keys-with-jq-but-keep-id-key-if-present-on-t",
        "title": "Almost automatically sorting keys with `jq`, but keep &quot;id&quot; key, if present, on top"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6990379,
                    "reputation": 185,
                    "user_id": 5359860,
                    "user_type": "registered",
                    "accept_rate": 73,
                    "profile_image": "https://www.gravatar.com/avatar/95e09cd53d732ddf946e65c3ff2a3f84?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "C.Astraea",
                    "link": "https://stackoverflow.com/users/5359860/c-astraea"
                },
                "reply_to_user": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1519836790,
                "post_id": 49034571,
                "comment_id": 85074167,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1519839988,
                "last_edit_date": 1519839988,
                "creation_date": 1519837010,
                "answer_id": 49034797,
                "question_id": 49034571,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using [tag:bash] and [tag:jq] :\r\n\r\n    #!/bin/bash\r\n    \r\n    file=&quot;$1&quot;\r\n    c=0\r\n    while true; do\r\n        track=$(jq -r &quot;.streams[$c].track&quot; &quot;$file&quot; 2&gt;/dev/null)\r\n        link=$(jq -r &quot;.streams[$c].link&quot; &quot;$file&quot; 2&gt;/dev/null)\r\n        [[ ! $stream || ! $link ]] &amp;&amp; break\r\n        ffmpeg -v verbose -i &quot;$link&quot; -c copy -flags -global_header -hls_time 10 \\\r\n            -hls_list_size 6 -hls_wrap 10 -start_number 1 &quot;$track&quot; \r\n        ((c++))\r\n    done\r\n\r\n## Usage : \r\n\r\n    ./script.bash file.json",
                "title": "Passing key and values to external command from jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1519841159,
                "last_edit_date": 1519841159,
                "creation_date": 1519839851,
                "answer_id": 49035615,
                "question_id": 49034571,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using [tag:nodejs] to generate the [tag:shell] commands :\r\n\r\n(replace `file.json` with your own path/file)\r\n\r\n    #!/bin/bash\r\n    \r\n    node&lt;&lt;EOF\r\n    var j=$(&lt;file.json);\r\n    for (var i = 0; i&lt;j.streams.length; i++) {\r\n       console.log(&quot;ffmpeg -v verbose -i &#39;&quot; + j.streams[i].link + &quot;&#39; -c copy -flags -global_header -hls_time 10 -hls_list_size 6 -hls_wrap 10 -start_number 1 &#39;&quot; + j.streams[i].track + &quot;&#39;&quot;);\r\n    }\r\n    EOF\r\n\r\n## Output : \r\n\r\n    ffmpeg -v verbose -i &#39;http://playertest.longtailvideo.com/adaptive/bipbop/bipbop.m3u8&#39; -c copy -flags -global_header -hls_time 10 -hls_list_size 6 -hls_wrap 10 -start_number 1 &#39;/var/www/html/stream1.m3u8&#39;\r\n    ffmpeg -v verbose -i &#39;https://mnmedias.api.telequebec.tv/m3u8/29880.m3u8&#39; -c copy -flags -global_header -hls_time 10 -hls_list_size 6 -hls_wrap 10 -start_number 1 &#39;/var/www/html/stream2.m3u8&#39;\r\n    ffmpeg -v verbose -i &#39;http://www.streambox.fr/playlists/test_001/stream.m3u8&#39; -c copy -flags -global_header -hls_time 10 -hls_list_size 6 -hls_wrap 10 -start_number 1 &#39;/var/www/html/stream3.m3u8&#39;",
                "title": "Passing key and values to external command from jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1519850938,
                "last_edit_date": 1519850938,
                "creation_date": 1519840389,
                "answer_id": 49035731,
                "question_id": 49034571,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The *shortest possible change* to your original code is just to add the quotes that were missing:\r\n\r\n    jq -r &#39;.streams[] | &quot;ffmpeg -v verbose -i  \\(.link | @sh) -c copy -flags -global_header -hls_time 10 -hls_list_size 6 -hls_wrap 10 -start_number 1 \\(.Track | @sh)&quot;&#39; streams.json | sh\r\n    #                   ^-- this was missing\r\n\r\nNote that `&quot;ffmpeg ...&quot;` is a *string*, and is contained in quotes. That said, you&#39;re relying on `jq` to generate safe code for your shell -- since it has features explicitly built for the purpose, this isn&#39;t as bad as an idea as it might be otherwise; but it&#39;s still better practice to avoid code generation wherever possible.\r\n\r\n---\r\n\r\nAs an alternate approach that avoids code generation and is safe with all possible filenames, use [jq](https://stedolan.github.io/jq/manual/) to generate a NUL-delimited stream of track / link pairs, and a [BashFAQ #1](http://mywiki.wooledge.org/BashFAQ/001) loop to iterate over them:\r\n\r\n    #!/usr/bin/env bash\r\n\r\n    while IFS= read -r -d &#39;&#39; track &amp;&amp; IFS= read -r -d &#39;&#39; link; do\r\n      ffmpeg -v verbose -i &quot;$link&quot; -c copy -flags -global_header -hls_time 10 \\\r\n             -hls_list_size 6 -hls_wrap 10 -start_number 1 &quot;$track&quot; \r\n    done &lt; &lt;(jq -j &#39;.streams[] | ( .track + &quot;\\u0000&quot; + .link + &quot;\\u0000&quot; )&#39; streams.json) ",
                "title": "Passing key and values to external command from jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1519850938,
        "creation_date": 1519836262,
        "last_edit_date": 1519849522,
        "question_id": 49034571,
        "body_markdown": "What I&#39;m trying to do: \r\n\r\n Use jq to pass along parameters to ffmpeg in a bash script.\r\n Have a JSON in this external file that I generate regularly. \r\n\r\n    {\r\n       &quot;streams&quot;:[\r\n          {\r\n             &quot;track&quot;:&quot;/var/www/html/stream1.m3u8&quot;,\r\n             &quot;link&quot;:&quot;http://playertest.longtailvideo.com/adaptive/bipbop/bipbop.m3u8&quot;\r\n          },\r\n          {\r\n             &quot;track&quot;:&quot;/var/www/html/stream2.m3u8&quot;,\r\n             &quot;link&quot;:&quot;https://mnmedias.api.telequebec.tv/m3u8/29880.m3u8&quot;\r\n          },\r\n          {\r\n             &quot;track&quot;:&quot;/var/www/html/stream3.m3u8&quot;,\r\n             &quot;link&quot;:&quot;http://www.streambox.fr/playlists/test_001/stream.m3u8&quot;\r\n          }\r\n       ]\r\n    }\r\n\r\nThis is the command I&#39;ve tried based on the response found here https://github.com/stedolan/jq/issues/503\r\n\r\n    jq -r &#39;.streams[] | ffmpeg -v verbose -i  \\(.link | @sh) -c copy -flags -global_header -hls_time 10 -hls_list_size 6 -hls_wrap 10 -start_number 1 \\(.Track | @sh)&quot;&#39; streams.json | sh\r\n\r\nHowever I get this error message: \r\n\r\n    jq: error: syntax error, unexpected IDENT, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .streams[] | ffmpeg -v verbose -i  \\(.link | @sh) -c copy -flags -global_header -hls_time 10 -hls_list_size 6 -hls_wrap 10 -start_number 1 \\(.Track | @sh)&quot;                       \r\n    jq: 1 compile error\r\n     \r\n\r\n",
        "link": "https://stackoverflow.com/questions/49034571/passing-key-and-values-to-external-command-from-jq",
        "title": "Passing key and values to external command from jq"
    },
    {
        "tags": [
            "json",
            "join",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 20,
                "is_accepted": true,
                "score": 20,
                "last_activity_date": 1519852903,
                "creation_date": 1519852903,
                "answer_id": 49038774,
                "question_id": 49037956,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq -s &#39;[ .[0] + .[1] | group_by(.name)[] \r\n              | select(length &gt; 1) | add ]&#39; registration.json useredits.json\r\nThe output:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;User1&quot;,\r\n        &quot;registration&quot;: &quot;2009-04-18T21:55:40Z&quot;,\r\n        &quot;editcount&quot;: 164\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;User2&quot;,\r\n        &quot;registration&quot;: &quot;2010-11-17T15:09:43Z&quot;,\r\n        &quot;editcount&quot;: 150\r\n      }\r\n    ]\r\n\r\n",
                "title": "How to merge arrays from two files into one array with jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1519853567,
                "last_edit_date": 1519853567,
                "creation_date": 1519853218,
                "answer_id": 49038847,
                "question_id": 49037956,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following assumes you have jq 1.5 or later, and that:\r\n\r\n* joins.jq as shown below is in the directory ~/.jq/ or the directory ~/.jq/joins/\r\n* there is no file named joins.jq in the pwd\r\n* registration.json has been fixed to make it valid JSON (btw, this can be done by jq itself).\r\n\r\nThe invocation to use would then be:\r\n\r\n    jq -s &#39;include &quot;joins&quot;; joins(.name)&#39; registration.json useredits.json\r\n\r\n\r\n### joins.jq\r\n\r\n    # joins.jq Version 1 (12-12-2017)\r\n    \r\n    def distinct(s):\r\n      reduce s as $x ({}; .[$x | (type[0:1] + tostring)] = $x)\r\n      |.[];\r\n    \r\n    # Relational Join\r\n    # joins/6 provides similar functionality to the SQL INNER JOIN statement:\r\n    #   SELECT (Table1|p1), (Table2|p2)\r\n    #     FROM Table1\r\n    #     INNER JOIN Table2 ON (Table1|filter1) = (Table2|filter2)\r\n    # where filter1, filter2, p1 and p2 are filters.\r\n    \r\n    # joins(s1; s2; filter1; filter2; p1; p2)\r\n    # s1 and s2 are streams of objects corresponding to rows in Table1 and Table2;\r\n    # filter1 and filter2 determine the join criteria;\r\n    # p1 and p2 are filters determining the final results.\r\n    # Input: ignored\r\n    # Output: a stream of distinct pairs [p1, p2]\r\n    # Note: items in s1 for which filter1 == null are ignored, otherwise all rows are considered.\r\n    #\r\n    def joins(s1; s2; filter1; filter2; p1; p2):\r\n      def it: type[0:1] + tostring;\r\n      def ix(s;f):\r\n        reduce s as $x ({};  ($x|f) as $y | if $y == null then . else .[$y|it] += [$x] end);\r\n      # combine two dictionaries using the cartesian product of distinct elements\r\n      def merge:\r\n        .[0] as $d1 | .[1] as $d2\r\n        | ($d1|keys_unsorted[]) as $k\r\n        | if $d2[$k] then distinct($d1[$k][]|p1) as $a | distinct($d2[$k][]|p2) as $b | [$a,$b]\r\n          else empty end;\r\n    \r\n       [ix(s1; filter1), ix(s2; filter2)] | merge;\r\n    \r\n    def joins(s1; s2; filter1; filter2):\r\n      joins(s1; s2; filter1; filter2; .; .) | add ;\r\n    \r\n    # Input: an array of two arrays of objects\r\n    # Output: a stream of the joined objects\r\n    def joins(filter1; filter2):\r\n      joins(.[0][]; .[1][]; filter1; filter2);\r\n    \r\n    # Input: an array of arrays of objects.\r\n    # Output: a stream of the joined objects where f defines the join criterion.\r\n    def joins(f):\r\n      # j/0 is defined so TCO is applicable\r\n      def j:\r\n        if length &lt; 2 then .[][]\r\n        else [[ joins(.[0][]; .[1][]; f; f)]] + .[2:] | j\r\n        end;\r\n       j ;\r\n\r\n",
                "title": "How to merge arrays from two files into one array with jq?"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1519854450,
                "last_edit_date": 1519854450,
                "creation_date": 1519854026,
                "answer_id": 49039053,
                "question_id": 49037956,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Although not strictly answering the question, the command below\r\n\r\n    jq -s &#39;flatten | group_by(.name) | map(reduce .[] as $x ({}; . * $x))&#39;\r\n          registration.json useredits.json\r\n\r\ngenerates this output:\r\n\r\n    [\r\n        { &quot;name&quot;: &quot;User1&quot;, &quot;editcount&quot;: 164, &quot;registration&quot;: &quot;2009-04-18T21:55:40Z&quot; },\r\n        { &quot;name&quot;: &quot;User2&quot;, &quot;editcount&quot;: 150, &quot;registration&quot;: &quot;2010-11-17T15:09:43Z&quot; },\r\n        { &quot;name&quot;: &quot;User3&quot;, &quot;editcount&quot;: 10 }\r\n    ]\r\n\r\nSource:\r\nhttps://stackoverflow.com/questions/36880891/jq-error-when-merging-two-json-files-cannot-be-multiplied",
                "title": "How to merge arrays from two files into one array with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 12,
        "last_activity_date": 1519888397,
        "creation_date": 1519849552,
        "last_edit_date": 1519888397,
        "question_id": 49037956,
        "body_markdown": "I would like to merge two files containing JSON. They each contain an array of JSON objects.\r\n\r\nregistration.json\r\n\r\n    [\r\n        { &quot;name&quot;: &quot;User1&quot;, &quot;registration&quot;: &quot;2009-04-18T21:55:40Z&quot; },\r\n        { &quot;name&quot;: &quot;User2&quot;, &quot;registration&quot;: &quot;2010-11-17T15:09:43Z&quot; }\r\n    ]\r\n\r\nuseredits.json\r\n\r\n    [\r\n        { &quot;name&quot;: &quot;User1&quot;, &quot;editcount&quot;: 164 },\r\n        { &quot;name&quot;: &quot;User2&quot;, &quot;editcount&quot;: 150 },\r\n        { &quot;name&quot;: &quot;User3&quot;, &quot;editcount&quot;: 10 }\r\n    ]\r\n\r\nIn the ideal scenario, I would like to have the following as a result of the merge operation:\r\n\r\n    [\r\n        { &quot;name&quot;: &quot;User1&quot;, &quot;editcount&quot;: 164, &quot;registration&quot;: &quot;2009-04-18T21:55:40Z&quot; },\r\n        { &quot;name&quot;: &quot;User2&quot;, &quot;editcount&quot;: 150, &quot;registration&quot;: &quot;2010-11-17T15:09:43Z&quot; }\r\n    ]\r\n\r\nI have found https://github.com/stedolan/jq/issues/1247#issuecomment-348817802 but I get\r\n\r\n    jq: error: module not found: jq\r\n",
        "link": "https://stackoverflow.com/questions/49037956/how-to-merge-arrays-from-two-files-into-one-array-with-jq",
        "title": "How to merge arrays from two files into one array with jq?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "match",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1519877862,
                "creation_date": 1519877862,
                "answer_id": 49042540,
                "question_id": 49040090,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The requirement that &quot;If the price hasn&#39;t been updated, the entry should be removed.&quot; seems to be at odds with the example, so the following assumes the example is definitive.\r\n\r\nFirst, a small helper function for producing a (fast) lookup table:\r\n\r\n    def dict(f): reduce .[] as $x ({}; .[$x|f] = $x);\r\n\r\nIn the following, as in the text of the question, `$pri` refers to the array with the old prices, and `$sec` to the array with new prices:\r\n\r\n    ($sec|dict(.id)) as $new\r\n    | reduce $pri[] as $x ([];\r\n        $new[$x.id] as $y\r\n        | if ($y.p == $x.p) then .\r\n          else . + [$x | (.c = $y.p)]\r\n          end )\r\n\r\nThe result is as given.\r\n        \r\n\r\n",
                "title": "JQ: Enrich primary array with secondary array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1520281987,
        "creation_date": 1519858837,
        "last_edit_date": 1520281987,
        "question_id": 49040090,
        "body_markdown": "I have two arrays containing prices for items:\r\n\r\n`[{&quot;id&quot;:&quot;a&quot;,&quot;p&quot;:5},{&quot;id&quot;:&quot;b&quot;,&quot;p&quot;:7},{&quot;id&quot;:&quot;c&quot;,&quot;p&quot;:8}]`\r\n\r\nand\r\n\r\n`[{&quot;id&quot;:&quot;a&quot;,&quot;p&quot;:9},{&quot;id&quot;:&quot;b&quot;,&quot;p&quot;:7},{&quot;id&quot;:&quot;d&quot;,&quot;p&quot;:4}]`\r\n\r\nI want the primary array to be enriched with the prices from the secondary array, if available. If the price hasn&#39;t been updated, the entry should be removed. Thus the wanted output is (&quot;b&quot; removed because prices are equal and &quot;c&quot; kept):\r\n\r\n`[{&quot;id&quot;:&quot;a&quot;,&quot;p&quot;:5,&quot;c&quot;:9},{&quot;id&quot;:&quot;c&quot;,&quot;p&quot;:8,&quot;c&quot;:null}]`\r\n\r\nI tried using select but this removes items not available in both arrays:\r\n\r\n`echo &#39;$pri&#39; | jq -c --argjson sec &#39;$sec&#39; &#39;.[]|. as {id:$id,p:$c}|{id,p,&quot;c&quot;:($sec[]|select(.id==$id and .p!=$c).p)}&#39;`\r\n\r\nEDIT:\r\npeak&#39;s answer brought me in the right direction. Once it was working I improved it even more.\r\n\r\nThe updated prices are always an array containing all items in an unsorted manner. I want to avoid disc writes when there&#39;s no real update.\r\n\r\nThus I save the last price response already in dictionary format like:\r\n\r\n`wget ... | jq -c &#39;reduce .[] as $x ({}; .[$x|.id|tostring]=$x)&#39; &gt;lastprices`\r\n\r\nThis step converts the input array\r\n\r\n    {&quot;id&quot;:28460,&quot;price&quot;:&quot;1.119&quot;,&quot;time&quot;:&quot;2018-03-05T18:33:43Z&quot;,&quot;camp&quot;:null}\r\n    {&quot;id&quot;:11438,&quot;price&quot;:&quot;1.119&quot;,&quot;time&quot;:&quot;2018-03-05T18:58:26Z&quot;,&quot;camp&quot;:null}\r\n    {&quot;id&quot;:11627,&quot;price&quot;:&quot;1.119&quot;,&quot;time&quot;:&quot;2018-03-05T18:47:45Z&quot;,&quot;camp&quot;:null}\r\n    {&quot;id&quot;:6905,&quot;price&quot;:&quot;1.119&quot;,&quot;time&quot;:&quot;2018-03-05T19:03:59Z&quot;,&quot;camp&quot;:null}\r\n\r\nto an index-sorted output array (a dictionary)\r\n\r\n    { &quot;6905&quot;  : { &quot;id&quot;:6905,  &quot;price&quot;:&quot;1.119&quot;, &quot;time&quot;:&quot;2018-03-05T19:03:59Z&quot;, &quot;camp&quot;:null },\r\n      &quot;11438&quot; : { &quot;id&quot;:11438, &quot;price&quot;:&quot;1.119&quot;, &quot;time&quot;:&quot;2018-03-05T18:58:26Z&quot;, &quot;camp&quot;:null },\r\n      &quot;11627&quot; : { &quot;id&quot;:11627, &quot;price&quot;:&quot;1.119&quot;, &quot;time&quot;:&quot;2018-03-05T18:47:45Z&quot;, &quot;camp&quot;:null },\r\n      &quot;28460&quot; : { &quot;id&quot;:28460, &quot;price&quot;:&quot;1.119&quot;, &quot;time&quot;:&quot;2018-03-05T18:33:43Z&quot;, &quot;camp&quot;:null } }\r\n\r\nIn the next iteration I compare the `update.time != last.time` and only keep (=`select`) items that have been updated:\r\n\r\n`wget ... | jq -c --argfile last lastprices &#39;[.[]|select(.time!=$last[.id|tostring].time)]&#39;`\r\n\r\nIf the comparison evaluated a non-empty array I [convert it to CSV][1] and append it to the &quot;database&quot; (saving as JSON would require to rewrite the whole array every time):\r\n\r\n`echo &quot;$COMPARISON&quot; | jq -rc &#39;(.[0] | keys_unsorted) as $keys | map([.[ $keys[] ]])[]|@csv&#39;&gt;&gt;gasdb.csv`\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/32960857/how-to-convert-arbirtrary-simple-json-to-csv-using-jq",
        "link": "https://stackoverflow.com/questions/49040090/jq-enrich-primary-array-with-secondary-array",
        "title": "JQ: Enrich primary array with secondary array"
    },
    {
        "tags": [
            "linux",
            "shell",
            "jq"
        ],
        "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": 1,
                "creation_date": 1519921055,
                "post_id": 49048412,
                "comment_id": 85112715,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8436221,
                    "reputation": 245,
                    "user_id": 6330341,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/8bb990f3fe9fa1211a9e74a6d8f0e6d5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Rajiv Rai",
                    "link": "https://stackoverflow.com/users/6330341/rajiv-rai"
                },
                "reply_to_user": {
                    "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": 1519967062,
                "post_id": 49048412,
                "comment_id": 85131307,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1519909039,
                "last_edit_date": 1519909039,
                "creation_date": 1519903994,
                "answer_id": 49048839,
                "question_id": 49048412,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using a `-` tries to do an arithmetic subtraction on the items. I recommend to use [String interpolation][1]. It will automatically cast input to a string:\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Stringinterpolation-%5C(foo)\r\n\r\n    jq -r --arg var1 $var1 --arg var2 $var2 &#39;(.[].appId=&quot;\\($var1)-\\($var2)&quot;)&#39; service.json \r\n",
                "title": "Escaping a symbol in jq expression in a shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1519909039,
        "creation_date": 1519902645,
        "last_edit_date": 1519903587,
        "question_id": 49048412,
        "body_markdown": "I have two variables `var1` and `var2` exported in my shell.\r\n\r\n    var1=root \r\n    var2=webserver\r\n\r\nI want a jq query which can replace a JSON key with the given value in the JSON file. something like that,\r\n\r\n    jq -r --arg var1 $var1 --arg var2 $var2 &#39;(.[].appId=$var1-$var2)&#39; service.json\r\n\r\nIt is giving error that var1 and var2 can&#39;t be subtracted. But i want the variable to be replaced with `$var1-$var2` as a string. \r\n\r\nI tried with `&quot;-&quot;`, But it&#39;s giving compilation error. \r\n\r\nservice.json content is following.\r\n\r\n    [ {\r\n          &quot;appId&quot;: &quot;Eternal Flame&quot;,\r\n          &quot;age&quot;: 1000000,\r\n          &quot;secretIdentity&quot;: &quot;Unknown&quot;,\r\n          &quot;powers&quot;: [\r\n            &quot;Immortality&quot;,\r\n            &quot;Heat Immunity&quot;,\r\n            &quot;Inferno&quot;,\r\n            &quot;Teleportation&quot;,\r\n            &quot;Interdimensional travel&quot;\r\n          ]\r\n        } ]\r\n\r\nappId value should be replaced with &quot;root-webserver&quot;",
        "link": "https://stackoverflow.com/questions/49048412/escaping-a-symbol-in-jq-expression-in-a-shell-script",
        "title": "Escaping a symbol in jq expression in a shell script"
    },
    {
        "tags": [
            "json",
            "object",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1519941347,
                "creation_date": 1519941347,
                "answer_id": 49059319,
                "question_id": 49059107,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; How do I add parent keys ?\r\n\r\nEasily, at least once the syntax errors in the input file have been fixed.\r\nThe key is to wrap parentheses around `.name` to form the new key:\r\n\r\n\r\n    map( {(.name): del(.name)} )",
                "title": "How do I add parent keys in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1519947248,
        "creation_date": 1519940346,
        "last_edit_date": 1519947248,
        "question_id": 49059107,
        "body_markdown": "I want to promote a value from inside an array element to be the parent key for the entire element.\r\n\r\nInput:\r\n\r\n    [\r\n        {\r\n            &quot;name&quot;: &quot;foo&quot;,\r\n            &quot;value1&quot;: &quot;fooval1&quot;,\r\n            &quot;value2&quot;: &quot;fooval2&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;bar&quot;,\r\n            &quot;value1&quot;: &quot;barval1&quot;,\r\n            &quot;value2&quot;: &quot;barval2&quot;\r\n        }\r\n    ]\r\n\r\nOutput:\r\n\r\n    {\r\n        &quot;foo&quot;:{\r\n            &quot;value1&quot;: &quot;fooval1&quot;,\r\n            &quot;value2&quot;: &quot;fooval2&quot;\r\n        },\r\n        &quot;bar&quot;:{\r\n            &quot;value1&quot;: &quot;barval1&quot;,\r\n            &quot;value2&quot;: &quot;barval2&quot;\r\n        }\r\n    }\r\n\r\nTo start with, I wanted to just add .name as a parent key to each entry. But this doesnt&#39; work:\r\n\r\n`jq &#39;map(.name: {.})&#39;`",
        "link": "https://stackoverflow.com/questions/49059107/how-do-i-add-parent-keys-in-jq",
        "title": "How do I add parent keys in jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "chronological"
        ],
        "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": 1520662062,
                "post_id": 49062033,
                "comment_id": 85416953,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 13050604,
                    "reputation": 21,
                    "user_id": 9431077,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/1772823719435613/picture?type=large",
                    "display_name": "Keo",
                    "link": "https://stackoverflow.com/users/9431077/keo"
                },
                "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": 1520734572,
                "post_id": 49062033,
                "comment_id": 85436038,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1520738221,
                "last_edit_date": 1520738221,
                "creation_date": 1519962190,
                "answer_id": 49062505,
                "question_id": 49062033,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In this response, I&#39;ll assume the following input, which seems to capture the essence of the problem:\r\n\r\n    {\r\n      &quot;FUX9A2m4LcuF6YG&quot;: {\r\n        &quot;name&quot;: &quot;KitchenDay&quot;,\r\n        &quot;lastupdated&quot;: &quot;2018-02-25T03:35:57&quot;\r\n      },\r\n      &quot;later&quot;: {\r\n        &quot;name&quot;: &quot;KitchenNight&quot;,\r\n        &quot;lastupdated&quot;: &quot;2018-02-25T23:35:57&quot;\r\n      }\r\n    }\r\n\r\nWith that as input, the following filter:\r\n\r\n    to_entries | [max_by(.value.lastupdated)] | from_entries\r\n\r\nproduces:\r\n\r\n    {\r\n      &quot;later&quot;: {\r\n        &quot;name&quot;: &quot;KitchenNight&quot;,\r\n        &quot;lastupdated&quot;: &quot;2018-02-25T23:35:57&quot;\r\n      }\r\n    }\r\n\r\nThe key here is that the max of the &quot;lastupdated&quot; field corresponds to the most recent time.\r\n\r\nIf you just want the key name, you could instead write:\r\n\r\n    to_entries | max_by(.value.lastupdated) | .key",
                "title": "How do I use jq to pull the newest HUE Scene from the JSON dump?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1520738221,
        "creation_date": 1519958802,
        "last_edit_date": 1519963101,
        "question_id": 49062033,
        "body_markdown": "I am trying to use jq to find the ID of a hue scene when I pass the scene name.  The problem is if I update the scene it makes another scene with a new ID assigned to it.  So as I make changes to the scene more than one result returns.  How Do I find the newest scene?  I see there is an object that is lastupdated.\r\n\r\nHere is what I have so far:\r\n\r\n    curl -s ${BASEURL}/scenes/ | /usr/local/bin/jq -r -e --arg SCENENAME &quot;${SCENENAME}&quot; &#39;. as $object | keys[] | select($object[.].name == $SCENENAME)&#39;\r\n\r\nHere is what the json output looks like:\r\n\r\n      &quot;FUX9A2m4LcuF6YG&quot;: {\r\n        &quot;name&quot;: &quot;KitchenDay&quot;,\r\n        &quot;lights&quot;: [\r\n          &quot;6&quot;,\r\n          &quot;7&quot;,\r\n          &quot;10&quot;,\r\n          &quot;11&quot;\r\n        ],\r\n        &quot;owner&quot;: &quot;43594f081bb6d23e9ccd254927fa47&quot;,\r\n        &quot;recycle&quot;: true,\r\n        &quot;locked&quot;: false,\r\n        &quot;appdata&quot;: {},\r\n        &quot;picture&quot;: &quot;&quot;,\r\n        &quot;lastupdated&quot;: &quot;2018-02-25T03:35:57&quot;,\r\n        &quot;version&quot;: 2   }",
        "link": "https://stackoverflow.com/questions/49062033/how-do-i-use-jq-to-pull-the-newest-hue-scene-from-the-json-dump",
        "title": "How do I use jq to pull the newest HUE Scene from the JSON dump?"
    },
    {
        "tags": [
            "json",
            "jq",
            "conditional-operator"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1519980008,
                "last_edit_date": 1519980008,
                "creation_date": 1519978805,
                "answer_id": 49065200,
                "question_id": 49064828,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "One possibility that is very straightforward is simply to test whether .creator is an array or not:\r\n\r\n    if .creator|type == &quot;array&quot; then .creator[] else .creator end\r\n    | .url\r\n\r\n\r\n### Streaming parser\r\nAt the other end of the spectrum of straightforwardness, here is another possibility that would be relevant if (a) the input JSON document was ginormous, and (b) the goal is to list all .url values that occur as immediate children of .creator, no matter where the keys are located in the input JSON document.  The invocation would use the **--stream** command-line option, e.g.\r\n\r\n     jq --stream -f filter.jq input.json\r\n\r\nThe jq filter in this case is:\r\n\r\n    select(length==2 and \r\n           (.[0][-1] == &quot;url&quot;) and\r\n           last( .[0][:-1][]| strings ) == &quot;creator&quot;)\r\n    | .[1]\r\n",
                "title": "How to write jq script to extract elements that might appear as singleton or list?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1519998502,
        "creation_date": 1519977198,
        "last_edit_date": 1519998502,
        "question_id": 49064828,
        "body_markdown": "How can one write a jq query that will extract a property from an element that may appear as singleton or list?\r\n\r\nFor example, extract the URL property from the creator in both example JSON strings below.\r\n\r\n**Example #1:**\r\n\r\n    {\r\n    &quot;@type&quot;: &quot;example1&quot;,\r\n    &quot;creator&quot;:{\r\n       &quot;@type&quot;:&quot;Organization&quot;,\r\n       &quot;url&quot;: &quot;https://www.ncei.noaa.gov/&quot;\r\n     }\r\n    }\r\n\r\n**Example #2:**\r\n\r\n    { \r\n     &quot;@type&quot;: &quot;example2&quot;,\r\n     &quot;creator&quot;: [{\r\n        &quot;@type&quot;:&quot;Person&quot;,\r\n        &quot;url&quot;: &quot;https://www.example.com/homepage&quot;\r\n    },\r\n    {\r\n     &quot;url&quot;: &quot;https://www.example.com/another&quot;\r\n     }]\r\n    }\r\n\r\nI have tried using `.creator` for the first one and `.creator[]` for the second one, but these two are not compatible. Is there a way to write so that it works for both examples?",
        "link": "https://stackoverflow.com/questions/49064828/how-to-write-jq-script-to-extract-elements-that-might-appear-as-singleton-or-lis",
        "title": "How to write jq script to extract elements that might appear as singleton or list?"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11468218,
                    "reputation": 5601,
                    "user_id": 8405835,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/sN3eq.png?s=256",
                    "display_name": "Abhijit Pritam Dutta",
                    "link": "https://stackoverflow.com/users/8405835/abhijit-pritam-dutta"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1519990052,
                "post_id": 49067568,
                "comment_id": 85141234,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1520004556,
                "creation_date": 1520004556,
                "answer_id": 49072251,
                "question_id": 49067568,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq -Rs &#39;[ split(&quot;\\n&quot;)[] | select(length &gt; 0) \r\n              | split(&quot;,&quot;) | {FrameworkName: .[0], VersionName: .[1]} ]&#39; data.txt\r\nThe output:\r\n\r\n    [\r\n      {\r\n        &quot;FrameworkName&quot;: &quot;Framework1&quot;,\r\n        &quot;VersionName&quot;: &quot;Version1&quot;\r\n      },\r\n      {\r\n        &quot;FrameworkName&quot;: &quot;Framework2&quot;,\r\n        &quot;VersionName&quot;: &quot;Version2&quot;\r\n      },\r\n      {\r\n        &quot;FrameworkName&quot;: &quot;Framework3&quot;,\r\n        &quot;VersionName&quot;: &quot;Version3&quot;\r\n      }\r\n    ]\r\n\r\nhttps://stedolan.github.io/jq/manual/v1.5/\r\n\r\n",
                "title": "Convert .txt to json using Shell scripting"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1520005533,
        "creation_date": 1519987646,
        "last_edit_date": 1520005533,
        "question_id": 49067568,
        "body_markdown": "I have a text file `data.txt`: \r\n\r\n    Framework1,Version1\r\n    Framework2,Version2\r\n    Framework3,Version3\r\n\r\nI need to convert it to `data.json` which would look like:\r\n\r\n    [\r\n    {&quot;FrameworkName&quot;:&quot;Framework1&quot;, &quot;VersionName&quot;:&quot;Version1&quot;},\r\n    {&quot;FrameworkName&quot;:&quot;Framework3&quot;, &quot;VersionName&quot;:&quot;Version2&quot;},\r\n    {&quot;FrameworkName&quot;:&quot;Framework3&quot;, &quot;VersionName&quot;:&quot;Version3&quot;}\r\n    ]\r\n\r\nI have tried using `awk` but it hasn&#39;t helped me much. Any help would be appreciated. ",
        "link": "https://stackoverflow.com/questions/49067568/convert-txt-to-json-using-shell-scripting",
        "title": "Convert .txt to json using Shell scripting"
    },
    {
        "tags": [
            "json",
            "sorting",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1519993875,
                "last_edit_date": 1519993875,
                "creation_date": 1519992676,
                "answer_id": 49068902,
                "question_id": 49068190,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq &#39;.[0].SG |= (map(.Permissions |= sort_by(.Port)) | sort_by(.GroupName))&#39; myfile.json\r\n\r\n- `(map(.Permissions |= sort_by(.Port)) | sort_by(.GroupName))` - compound expression to separate 2 sort operations:\r\n    - `map(.Permissions |= sort_by(.Port))` - get a new array where each internal `.Permissions` array is sorted by key `&quot;Port&quot;` value\r\n    - `sort_by(.GroupName)` - sort `SG` array items by `&quot;GroupName&quot;` key\r\n\r\n\r\n----------\r\n\r\n\r\nThe output:\r\n\r\n    [\r\n      {\r\n        &quot;SG&quot;: [\r\n          {\r\n            &quot;Id&quot;: &quot;17&quot;,\r\n            &quot;GroupName&quot;: &quot;fistGN&quot;,\r\n            &quot;Permissions&quot;: [\r\n              {\r\n                &quot;Port&quot;: 80,\r\n                &quot;Protocol&quot;: &quot;tcp&quot;\r\n              },\r\n              {\r\n                &quot;Port&quot;: 5080,\r\n                &quot;Protocol&quot;: &quot;tcp&quot;\r\n              },\r\n              {\r\n                &quot;Port&quot;: 8080,\r\n                &quot;Protocol&quot;: &quot;tcp&quot;\r\n              }\r\n            ]\r\n          },\r\n          {\r\n            &quot;Id&quot;: &quot;1&quot;,\r\n            &quot;GroupName&quot;: &quot;secondGN&quot;,\r\n            &quot;Permissions&quot;: [\r\n              {\r\n                &quot;Port&quot;: 80,\r\n                &quot;Protocol&quot;: &quot;tcp&quot;\r\n              },\r\n              {\r\n                &quot;Port&quot;: 5080,\r\n                &quot;Protocol&quot;: &quot;tcp&quot;\r\n              },\r\n              {\r\n                &quot;Port&quot;: 8080,\r\n                &quot;Protocol&quot;: &quot;tcp&quot;\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\n",
                "title": "Is it possible to use jq to sort_by then sort_by again by sub item"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1520068536,
        "creation_date": 1519990047,
        "last_edit_date": 1520068536,
        "question_id": 49068190,
        "body_markdown": "I have the following json:\r\n\r\n    [\r\n      {\r\n        &quot;SG&quot;: [\r\n          {\r\n            &quot;Id&quot;: &quot;17&quot;,\r\n            &quot;GroupName&quot;: &quot;fistGN&quot;,\r\n            &quot;Permissions&quot;: [\r\n              {\r\n                &quot;Port&quot;: 80,\r\n                &quot;Protocol&quot;: &quot;tcp&quot;\r\n              },\r\n              {\r\n                &quot;Port&quot;: 8080,\r\n                &quot;Protocol&quot;: &quot;tcp&quot;\r\n              },\r\n              {\r\n                &quot;Port&quot;: 5080,\r\n                &quot;Protocol&quot;: &quot;tcp&quot;\r\n              }\r\n            ]\r\n          },\r\n          {\r\n            &quot;Id&quot;: &quot;1&quot;,\r\n            &quot;GroupName&quot;: &quot;secondGN&quot;,\r\n            &quot;Permissions&quot;: [\r\n              {\r\n                &quot;Port&quot;: 80,\r\n                &quot;Protocol&quot;: &quot;tcp&quot;\r\n              },\r\n              {\r\n                &quot;Port&quot;: 8080,\r\n                &quot;Protocol&quot;: &quot;tcp&quot;\r\n              },\r\n              {\r\n                &quot;Port&quot;: 5080,\r\n                &quot;Protocol&quot;: &quot;tcp&quot;\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nIs it possible to sort_by GroupName and then for each group by Permissions Port using a single command?\r\n\r\nThis is what I&#39;m trying to do but that is not working as expected:\r\n\r\n    jq -s -S &#39;.[].SG |= sort_by(.GroupName, .Permissions[].Port)&#39; myfile.json",
        "link": "https://stackoverflow.com/questions/49068190/is-it-possible-to-use-jq-to-sort-by-then-sort-by-again-by-sub-item",
        "title": "Is it possible to use jq to sort_by then sort_by again by sub item"
    },
    {
        "tags": [
            "linux",
            "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": 1,
                "creation_date": 1520008510,
                "post_id": 49073376,
                "comment_id": 85152533,
                "content_license": "CC BY-SA 3.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": 1520008553,
                "post_id": 49073376,
                "comment_id": 85152562,
                "content_license": "CC BY-SA 3.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": 1520008622,
                "post_id": 49073376,
                "comment_id": 85152592,
                "content_license": "CC BY-SA 3.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": 1520009059,
                "post_id": 49073376,
                "comment_id": 85152867,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1520008722,
                "creation_date": 1520008722,
                "answer_id": 49073491,
                "question_id": 49073376,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**This is not a valid JSON document.** Backslashes in JSON must be escaped to be included in literal strings. Report a bug against whichever tool generated this invalid content.\r\n\r\n---\r\n\r\nTo include a backslash in JSON would instead look like:\r\n\r\n    {\r\n      &quot;kubectl.kubernetes.io\\\\last-applied-configuration&quot;: &quot;test&quot;\r\n    }\r\n\r\nIf you had such a valid document, you could then use:\r\n\r\n    jq &#39;.[&quot;kubectl.kubernetes.io\\\\last-applied-configuration&quot;]&#39; &lt;/tmp/yo",
                "title": "jq - escaping backslash in keyname"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1520008722,
        "creation_date": 1520008316,
        "question_id": 49073376,
        "body_markdown": "I have a a key with a \\ in it and I can&#39;t seem to access it in using jq. Any help is appreciated.\r\n\r\n    $ cat /tmp/yo\r\n    {\r\n      &quot;kubectl.kubernetes.io\\last-applied-configuration&quot;: &quot;test&quot;\r\n    }\r\n\r\n    $ cat /tmp/yo | jq .[&quot;kubectl.kubernetes.io\\last-applied-configuration&quot;]\r\n    parse error: Invalid escape at line 2, column 52",
        "link": "https://stackoverflow.com/questions/49073376/jq-escaping-backslash-in-keyname",
        "title": "jq - escaping backslash in keyname"
    },
    {
        "tags": [
            "json",
            "bash",
            "parsing",
            "jq",
            "jsonlines"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 17469,
                    "reputation": 1574,
                    "user_id": 39123,
                    "user_type": "registered",
                    "accept_rate": 44,
                    "profile_image": "https://www.gravatar.com/avatar/aaaaf18c8b8b06db93ab848eda85a530?s=256&d=identicon&r=PG",
                    "display_name": "Geoffrey Anderson",
                    "link": "https://stackoverflow.com/users/39123/geoffrey-anderson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1520012284,
                "post_id": 49074415,
                "comment_id": 85154774,
                "content_license": "CC BY-SA 3.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": 1520013669,
                "post_id": 49074415,
                "comment_id": 85155528,
                "content_license": "CC BY-SA 3.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": 1520013729,
                "post_id": 49074415,
                "comment_id": 85155557,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 17469,
                    "reputation": 1574,
                    "user_id": 39123,
                    "user_type": "registered",
                    "accept_rate": 44,
                    "profile_image": "https://www.gravatar.com/avatar/aaaaf18c8b8b06db93ab848eda85a530?s=256&d=identicon&r=PG",
                    "display_name": "Geoffrey Anderson",
                    "link": "https://stackoverflow.com/users/39123/geoffrey-anderson"
                },
                "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": 1520014337,
                "post_id": 49074415,
                "comment_id": 85155867,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 17469,
                    "reputation": 1574,
                    "user_id": 39123,
                    "user_type": "registered",
                    "accept_rate": 44,
                    "profile_image": "https://www.gravatar.com/avatar/aaaaf18c8b8b06db93ab848eda85a530?s=256&d=identicon&r=PG",
                    "display_name": "Geoffrey Anderson",
                    "link": "https://stackoverflow.com/users/39123/geoffrey-anderson"
                },
                "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": 1520014551,
                "post_id": 49074415,
                "comment_id": 85155974,
                "content_license": "CC BY-SA 3.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": 1520015154,
                "post_id": 49074415,
                "comment_id": 85156253,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1520012845,
                "creation_date": 1520012845,
                "answer_id": 49074626,
                "question_id": 49074415,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq -r &#39;select(.subreddit == &quot;nfl&quot;) as $o | $o.body, $o.author&#39; head_rc.txt\r\n\r\n- `... as $o` - assign filtered object to variable `o`\r\n\r\nThe output:\r\n\r\n    lol missed the extra wtf\r\n    kygiacomo\r\n    The ghost of MN kickers will haunt this game.\r\n    immortalis\r\n    The Big. The Dick. The Nick. \r\n    Mimi108\r\n\r\n",
                "title": "Unexpected results when Select objects using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1520013983,
                "last_edit_date": 1520013983,
                "creation_date": 1520013377,
                "answer_id": 49074760,
                "question_id": 49074415,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; Also need to add streaming once I get this syntax correct. \r\n\r\nSome good news - you won&#39;t need to use the so-called &quot;streaming parser&quot;, because your input has already been chopped up.  The &quot;streaming parser&quot; is only needed when the input has one or more individually ginormous JSON entities, whereas you have a (long) stream of small JSON objects.\r\n\r\n## p.s.\r\nAs Charles Duffy suggested, the simplest solution to your selection problem is to use parentheses\r\n\r\n\r\n    jq -r &#39;select(.subreddit==&quot;nfl&quot;) | (.body, .author)&#39; input.json\r\n\r\nIf CSV or TSV makes sense, then change the parentheses to brackets, and tack on @csv or @tsv, e.g.\r\n\r\n    select(.subreddit==&quot;nfl&quot;) | [.body, .author] | @tsv\r\n\r\n",
                "title": "Unexpected results when Select objects using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1520017590,
        "creation_date": 1520012104,
        "last_edit_date": 1520017590,
        "question_id": 49074415,
        "body_markdown": "When I add the body to output list, some wrong names get output. I expected it to output only names for nfl subreddit in both examples.  Feature or bug?  How can I only output the tuples for subreddit nfl?\r\n\r\nThe file:\r\n\r\n    {&quot;author&quot;:&quot;403and780&quot;,&quot;author_flair_css_class&quot;:&quot;NHL-EDM4-sheet1-col01-row17&quot;,&quot;author_flair_text&quot;:&quot;EDM - NHL&quot;,&quot;body&quot;:&quot;Don&#39;t get why we do this but can&#39;t have a Grey Cup GDT.&quot;,&quot;can_gild&quot;:true,&quot;controversiality&quot;:0,&quot;created_utc&quot;:1517788800,&quot;distinguished&quot;:null,&quot;edited&quot;:false,&quot;gilded&quot;:0,&quot;id&quot;:&quot;dtqrsn6&quot;,&quot;is_submitter&quot;:false,&quot;link_id&quot;:&quot;t3_7v9yqa&quot;,&quot;parent_id&quot;:&quot;t3_7v9yqa&quot;,&quot;permalink&quot;:&quot;/r/hockey/comments/7v9yqa/game_thread_super_bowl_lii_philadelphia_eagles_vs/dtqrsn6/&quot;,&quot;retrieved_on&quot;:1518931297,&quot;score&quot;:2,&quot;stickied&quot;:false,&quot;subreddit&quot;:&quot;hockey&quot;,&quot;subreddit_id&quot;:&quot;t5_2qiel&quot;,&quot;subreddit_type&quot;:&quot;public&quot;}    \r\n    {&quot;author&quot;:&quot;kygiacomo&quot;,&quot;author_flair_css_class&quot;:null,&quot;author_flair_text&quot;:null,&quot;body&quot;:&quot;lol missed the extra wtf&quot;,&quot;can_gild&quot;:true,&quot;controversiality&quot;:0,&quot;created_utc&quot;:1517788800,&quot;distinguished&quot;:null,&quot;edited&quot;:false,&quot;gilded&quot;:0,&quot;id&quot;:&quot;dtqrsn7&quot;,&quot;is_submitter&quot;:false,&quot;link_id&quot;:&quot;t3_7vad8n&quot;,&quot;parent_id&quot;:&quot;t3_7vad8n&quot;,&quot;permalink&quot;:&quot;/r/nfl/comments/7vad8n/super_bowl_lii_game_thread_philadelphia_eagles/dtqrsn7/&quot;,&quot;retrieved_on&quot;:1518931297,&quot;score&quot;:2,&quot;stickied&quot;:false,&quot;subreddit&quot;:&quot;nfl&quot;,&quot;subreddit_id&quot;:&quot;t5_2qmg3&quot;,&quot;subreddit_type&quot;:&quot;public&quot;}    \r\n    {&quot;author&quot;:&quot;shitpostlord4321&quot;,&quot;author_flair_css_class&quot;:null,&quot;author_flair_text&quot;:null,&quot;body&quot;:&quot;I really hope we get Bleeding Edge before we get the all new all different armor. &quot;,&quot;can_gild&quot;:true,&quot;controversiality&quot;:0,&quot;created_utc&quot;:1517788800,&quot;distinguished&quot;:null,&quot;edited&quot;:false,&quot;gilded&quot;:0,&quot;id&quot;:&quot;dtqrsn8&quot;,&quot;is_submitter&quot;:false,&quot;link_id&quot;:&quot;t3_7v7whz&quot;,&quot;parent_id&quot;:&quot;t3_7v7whz&quot;,&quot;permalink&quot;:&quot;/r/marvelstudios/comments/7v7whz/a_great_new_look_at_iron_mans_avengers_infinity/dtqrsn8/&quot;,&quot;retrieved_on&quot;:1518931297,&quot;score&quot;:1,&quot;stickied&quot;:false,&quot;subreddit&quot;:&quot;marvelstudios&quot;,&quot;subreddit_id&quot;:&quot;t5_2uii8&quot;,&quot;subreddit_type&quot;:&quot;public&quot;}\r\n    {&quot;author&quot;:&quot;namohysip&quot;,&quot;author_flair_css_class&quot;:null,&quot;author_flair_text&quot;:null,&quot;body&quot;:&quot;Maybe. I mostly am just doing this to get a story out, and it\\u2019s a huge one, so I\\u2019m not sure that I\\u2019ll be making another fic for many more months. I guess Pokemon Mystery Dungeon just isn\\u2019t as popular with the older demographics of AO3.&quot;,&quot;can_gild&quot;:true,&quot;controversiality&quot;:0,&quot;created_utc&quot;:1517788800,&quot;distinguished&quot;:null,&quot;edited&quot;:false,&quot;gilded&quot;:0,&quot;id&quot;:&quot;dtqrsn9&quot;,&quot;is_submitter&quot;:true,&quot;link_id&quot;:&quot;t3_7v9psr&quot;,&quot;parent_id&quot;:&quot;t1_dtqrm3t&quot;,&quot;permalink&quot;:&quot;/r/FanFiction/comments/7v9psr/how_do_you_deal_with_bad_reviews/dtqrsn9/&quot;,&quot;retrieved_on&quot;:1518931297,&quot;score&quot;:1,&quot;stickied&quot;:false,&quot;subreddit&quot;:&quot;FanFiction&quot;,&quot;subreddit_id&quot;:&quot;t5_2r5kb&quot;,&quot;subreddit_type&quot;:&quot;public&quot;}\r\n    {&quot;author&quot;:&quot;SDsc0rch&quot;,&quot;author_flair_css_class&quot;:null,&quot;author_flair_text&quot;:null,&quot;body&quot;:&quot;if it rates an upvote, I&#39;ll click it - I&#39;m not gonna click on low quality      \\nnot gonna apologize for it either &quot;,&quot;can_gild&quot;:true,&quot;controversiality&quot;:0,&quot;created_utc&quot;:1517788800,&quot;distinguished&quot;:null,&quot;edited&quot;:false,&quot;gilded&quot;:0,&quot;id&quot;:&quot;dtqrsna&quot;,&quot;is_submitter&quot;:false,&quot;link_id&quot;:&quot;t3_7vaam4&quot;,&quot;parent_id&quot;:&quot;t3_7vaam4&quot;,&quot;permalink&quot;:&quot;/r/The_Donald/comments/7vaam4/daily_reminderif_you_see_any_gray_arrows_on_the/dtqrsna/&quot;,&quot;retrieved_on&quot;:1518931297,&quot;score&quot;:4,&quot;stickied&quot;:false,&quot;subreddit&quot;:&quot;The_Donald&quot;,&quot;subreddit_id&quot;:&quot;t5_38unr&quot;,&quot;subreddit_type&quot;:&quot;public&quot;}\r\n    {&quot;author&quot;:&quot;scarletcrawford&quot;,&quot;author_flair_css_class&quot;:null,&quot;author_flair_text&quot;:null,&quot;body&quot;:&quot;Honestly, I wanted Takeshi to stay with Poe, but to each their own ship, I guess.&quot;,&quot;can_gild&quot;:true,&quot;controversiality&quot;:0,&quot;created_utc&quot;:1517788800,&quot;distinguished&quot;:null,&quot;edited&quot;:false,&quot;gilded&quot;:0,&quot;id&quot;:&quot;dtqrsnb&quot;,&quot;is_submitter&quot;:false,&quot;link_id&quot;:&quot;t3_7upyc0&quot;,&quot;parent_id&quot;:&quot;t1_dtppyry&quot;,&quot;permalink&quot;:&quot;/r/alteredcarbon/comments/7upyc0/season_1_series_discussion/dtqrsnb/&quot;,&quot;retrieved_on&quot;:1518931297,&quot;score&quot;:2,&quot;stickied&quot;:false,&quot;subreddit&quot;:&quot;alteredcarbon&quot;,&quot;subreddit_id&quot;:&quot;t5_3bzvp&quot;,&quot;subreddit_type&quot;:&quot;public&quot;}\r\n    {&quot;author&quot;:&quot;immortalis&quot;,&quot;author_flair_css_class&quot;:&quot;vikings&quot;,&quot;author_flair_text&quot;:&quot;Vikings&quot;,&quot;body&quot;:&quot;The ghost of MN kickers will haunt this game.&quot;,&quot;can_gild&quot;:true,&quot;controversiality&quot;:0,&quot;created_utc&quot;:1517788800,&quot;distinguished&quot;:null,&quot;edited&quot;:false,&quot;gilded&quot;:0,&quot;id&quot;:&quot;dtqrsnc&quot;,&quot;is_submitter&quot;:false,&quot;link_id&quot;:&quot;t3_7vad8n&quot;,&quot;parent_id&quot;:&quot;t3_7vad8n&quot;,&quot;permalink&quot;:&quot;/r/nfl/comments/7vad8n/super_bowl_lii_game_thread_philadelphia_eagles/dtqrsnc/&quot;,&quot;retrieved_on&quot;:1518931297,&quot;score&quot;:2,&quot;stickied&quot;:false,&quot;subreddit&quot;:&quot;nfl&quot;,&quot;subreddit_id&quot;:&quot;t5_2qmg3&quot;,&quot;subreddit_type&quot;:&quot;public&quot;}\r\n    {&quot;author&quot;:&quot;KryptoFreak405&quot;,&quot;author_flair_css_class&quot;:&quot;48&quot;,&quot;author_flair_text&quot;:&quot;&quot;,&quot;body&quot;:&quot;His original backstory had him training to be an Imperial officer until a commanding officer ordered him to transport a shipment of slaves. He refused, freed the slaves, one of which was Chewie, and defected to become a smuggler&quot;,&quot;can_gild&quot;:true,&quot;controversiality&quot;:0,&quot;created_utc&quot;:1517788800,&quot;distinguished&quot;:null,&quot;edited&quot;:false,&quot;gilded&quot;:0,&quot;id&quot;:&quot;dtqrsnd&quot;,&quot;is_submitter&quot;:false,&quot;link_id&quot;:&quot;t3_7vanzc&quot;,&quot;parent_id&quot;:&quot;t1_dtqr5q5&quot;,&quot;permalink&quot;:&quot;/r/StarWars/comments/7vanzc/solo_a_star_wars_story_big_game_tv_spot/dtqrsnd/&quot;,&quot;retrieved_on&quot;:1518931297,&quot;score&quot;:1102,&quot;stickied&quot;:false,&quot;subreddit&quot;:&quot;StarWars&quot;,&quot;subreddit_id&quot;:&quot;t5_2qi4s&quot;,&quot;subreddit_type&quot;:&quot;public&quot;}\r\n    {&quot;author&quot;:&quot;thwinks&quot;,&quot;author_flair_css_class&quot;:null,&quot;author_flair_text&quot;:null,&quot;body&quot;:&quot;Oh. TIL&quot;,&quot;can_gild&quot;:true,&quot;controversiality&quot;:0,&quot;created_utc&quot;:1517788800,&quot;distinguished&quot;:null,&quot;edited&quot;:false,&quot;gilded&quot;:0,&quot;id&quot;:&quot;dtqrsne&quot;,&quot;is_submitter&quot;:false,&quot;link_id&quot;:&quot;t3_7v8o0z&quot;,&quot;parent_id&quot;:&quot;t1_dtqg97a&quot;,&quot;permalink&quot;:&quot;/r/gifs/comments/7v8o0z/silly_walk_champion/dtqrsne/&quot;,&quot;retrieved_on&quot;:1518931297,&quot;score&quot;:2,&quot;stickied&quot;:false,&quot;subreddit&quot;:&quot;gifs&quot;,&quot;subreddit_id&quot;:&quot;t5_2qt55&quot;,&quot;subreddit_type&quot;:&quot;public&quot;}\r\n    {&quot;author&quot;:&quot;Mimi108&quot;,&quot;author_flair_css_class&quot;:&quot;lions&quot;,&quot;author_flair_text&quot;:&quot;Lions&quot;,&quot;body&quot;:&quot;The Big. The Dick. The Nick. &quot;,&quot;can_gild&quot;:true,&quot;controversiality&quot;:0,&quot;created_utc&quot;:1517788800,&quot;distinguished&quot;:null,&quot;edited&quot;:false,&quot;gilded&quot;:0,&quot;id&quot;:&quot;dtqrsnf&quot;,&quot;is_submitter&quot;:false,&quot;link_id&quot;:&quot;t3_7vad8n&quot;,&quot;parent_id&quot;:&quot;t3_7vad8n&quot;,&quot;permalink&quot;:&quot;/r/nfl/comments/7vad8n/super_bowl_lii_game_thread_philadelphia_eagles/dtqrsnf/&quot;,&quot;retrieved_on&quot;:1518931297,&quot;score&quot;:2,&quot;stickied&quot;:false,&quot;subreddit&quot;:&quot;nfl&quot;,&quot;subreddit_id&quot;:&quot;t5_2qmg3&quot;,&quot;subreddit_type&quot;:&quot;public&quot;}\r\n\r\nCode example 1, which works OK:\r\n\r\n    $ cat head_rc.txt | jq -r &#39;select(.subreddit==&quot;nfl&quot;) .author&#39;\r\n    kygiacomo\r\n    immortalis\r\n    Mimi108\r\n\r\nCode example 2, which is wrong or unexpected to me:\r\n\r\n    $ cat head_rc.txt | jq -r &#39;select(.subreddit==&quot;nfl&quot;) .body, .author&#39;\r\n    403and780\r\n    lol missed the extra wtf\r\n    kygiacomo\r\n    shitpostlord4321\r\n    namohysip\r\n    SDsc0rch\r\n    scarletcrawford\r\n    The ghost of MN kickers will haunt this game.\r\n    immortalis\r\n    KryptoFreak405\r\n    thwinks\r\n    The Big. The Dick. The Nick. \r\n    Mimi108\r\n\r\nYou can see that author 403and780 commented to a hockey subreddit, not nfl, unfortunately.\r\n",
        "link": "https://stackoverflow.com/questions/49074415/unexpected-results-when-select-objects-using-jq",
        "title": "Unexpected results when Select objects using jq"
    },
    {
        "tags": [
            "regex",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4739783,
                    "reputation": 629694,
                    "user_id": 3832970,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/IFOp5.jpg?s=256",
                    "display_name": "Wiktor Stribiżew",
                    "link": "https://stackoverflow.com/users/3832970/wiktor-stribi%c5%bcew"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1520103598,
                "post_id": 49087991,
                "comment_id": 85181532,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 17469,
                    "reputation": 1574,
                    "user_id": 39123,
                    "user_type": "registered",
                    "accept_rate": 44,
                    "profile_image": "https://www.gravatar.com/avatar/aaaaf18c8b8b06db93ab848eda85a530?s=256&d=identicon&r=PG",
                    "display_name": "Geoffrey Anderson",
                    "link": "https://stackoverflow.com/users/39123/geoffrey-anderson"
                },
                "reply_to_user": {
                    "account_id": 4739783,
                    "reputation": 629694,
                    "user_id": 3832970,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/IFOp5.jpg?s=256",
                    "display_name": "Wiktor Stribiżew",
                    "link": "https://stackoverflow.com/users/3832970/wiktor-stribi%c5%bcew"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1520103682,
                "post_id": 49087991,
                "comment_id": 85181565,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 17469,
                    "reputation": 1574,
                    "user_id": 39123,
                    "user_type": "registered",
                    "accept_rate": 44,
                    "profile_image": "https://www.gravatar.com/avatar/aaaaf18c8b8b06db93ab848eda85a530?s=256&d=identicon&r=PG",
                    "display_name": "Geoffrey Anderson",
                    "link": "https://stackoverflow.com/users/39123/geoffrey-anderson"
                },
                "reply_to_user": {
                    "account_id": 4739783,
                    "reputation": 629694,
                    "user_id": 3832970,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/IFOp5.jpg?s=256",
                    "display_name": "Wiktor Stribiżew",
                    "link": "https://stackoverflow.com/users/3832970/wiktor-stribi%c5%bcew"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1520103714,
                "post_id": 49087991,
                "comment_id": 85181583,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user557597"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1520105794,
                "post_id": 49087991,
                "comment_id": 85182284,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1520104254,
                "creation_date": 1520104254,
                "answer_id": 49088141,
                "question_id": 49087991,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The right way with `jq`:\r\n\r\n    echo &quot;low quality      not gonna apologize&quot; | jq -Rr &#39;gsub(&quot;\\\\s+&quot;;&quot; &quot;;&quot;g&quot;)&#39;\r\n\r\n- `-R` - *raw input*; each line of text is passed to the filter as a string\r\n\r\nThe output:\r\n\r\n    low quality not gonna apologize",
                "title": "jq remove spaces after first"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1520105927,
                "creation_date": 1520105927,
                "answer_id": 49088418,
                "question_id": 49087991,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Two of many alternatives:\r\n\r\n    $ echo &#39;&quot;low quality      not gonna apologize&quot;&#39; | jq -r &#39;gsub(&quot;\\\\s+&quot;; &quot; &quot;)&#39;\r\n    low quality not gonna apologize\r\n\r\n    $ jq -n --arg in &quot;low quality      not gonna apologize&quot; &#39;$in | gsub(&quot;\\\\s+&quot;; &quot; &quot;)&#39;\r\n    &quot;low quality not gonna apologize&quot;\r\n\r\nNotice that:\r\n\r\n* Not every shell string is a JSON string.\r\n* The `--arg` command-line option has the effect of coercing the shell string to a JSON string.\r\n* if you use &#39;gsub&#39;, there is no need to specify &quot;g&quot; as well. \r\n\r\n",
                "title": "jq remove spaces after first"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1520105927,
        "creation_date": 1520103423,
        "question_id": 49087991,
        "body_markdown": "Seemed simple, but not so far. Tried lots of things. Best I&#39;ve got:\r\n\r\n    echo &quot;low quality      not gonna apologize&quot; | jq -r &#39;gsub(&quot;[\\\\s+]&quot;; &quot; &quot;; &quot;g&quot;)&#39;\r\n\r\n    parse error: Invalid numeric literal at line 1, column 4\r\n\r\nGoal is to have 1 space replace any occurrence of multiple whitespace of any kind. Note that I removed tabs and newlines already from this stream.  This is bash shell. I don&#39;t get this error in the context of the larger application I&#39;m building either, where the code is simply and quietly not changing the multiple spaces into a single space for IDK why.",
        "link": "https://stackoverflow.com/questions/49087991/jq-remove-spaces-after-first",
        "title": "jq remove spaces after first"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1678536303,
                "last_edit_date": 1678536303,
                "creation_date": 1520238066,
                "answer_id": 49106090,
                "question_id": 49105880,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try:\r\n\r\n```\r\nmap(select(.finalStatus != null))\r\n```\r\n\r\nhttps://jqplay.org/s/PorPrMb7k97",
                "title": "jq - how to output document if a value is not null?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1678536303,
        "creation_date": 1520237066,
        "question_id": 49105880,
        "body_markdown": "I am trying to find way how to extract only document from following array if finalStatus != null. \r\n\r\nI have tried `select(.[].finalStatus != null)`but without success. still I am getting both lines. \r\n\r\n    [\r\n      {\r\n        &quot;_type&quot;: &quot;http&quot;,\r\n        &quot;uri&quot;: &quot;/rest/eFulfillment/V1/stock/5117855/OHK30&quot;,\r\n        &quot;status&quot;: 200,\r\n        &quot;statustext&quot;: &quot;OK&quot;,\r\n        &quot;method&quot;: &quot;GET&quot;,\r\n        &quot;vhost&quot;: null,\r\n        &quot;wafStatus&quot;: 0,\r\n        &quot;bytesSent&quot;: 0,\r\n        &quot;bytesReceived&quot;: 0,\r\n        &quot;remoteName&quot;: &quot;connecte-esb-bat.dhl.com&quot;,\r\n        &quot;remoteAddr&quot;: &quot;165.72.94.127&quot;,\r\n        &quot;localAddr&quot;: &quot;165.72.1.236&quot;,\r\n        &quot;remotePort&quot;: &quot;443&quot;,\r\n        &quot;localPort&quot;: &quot;52842&quot;,\r\n        &quot;sslsubject&quot;: &quot;/C=DE/ST=Nordrhein-Westfalen/L=Bonn/O=Deutsche Post AG/OU=ITSC/CN=connecte-esb-bat.dhl.com&quot;,\r\n        &quot;leg&quot;: 1,\r\n        &quot;timestamp&quot;: 1520235200649,\r\n        &quot;duration&quot;: 1099,\r\n        &quot;correlationId&quot;: &quot;c0f29c5a3e484ba5419878db&quot;,\r\n        &quot;serviceName&quot;: &quot;PeP e-Fulfillment API&quot;,\r\n        &quot;subject&quot;: &quot;d006366e-3b9e-415f-baff-cc1eec24898a&quot;,\r\n        &quot;operation&quot;: &quot;Get Available Stock&quot;,\r\n        &quot;type&quot;: &quot;http&quot;,\r\n        &quot;finalStatus&quot;: null\r\n      },\r\n      {\r\n        &quot;_type&quot;: &quot;http&quot;,\r\n        &quot;uri&quot;: &quot;/efulfillment/v1/stock/5117855/OHK30&quot;,\r\n        &quot;status&quot;: 200,\r\n        &quot;statustext&quot;: &quot;OK&quot;,\r\n        &quot;method&quot;: &quot;GET&quot;,\r\n        &quot;vhost&quot;: null,\r\n        &quot;wafStatus&quot;: 0,\r\n        &quot;bytesSent&quot;: 0,\r\n        &quot;bytesReceived&quot;: 0,\r\n        &quot;remoteName&quot;: &quot;165.72.87.12&quot;,\r\n        &quot;remoteAddr&quot;: &quot;165.72.87.12&quot;,\r\n        &quot;localAddr&quot;: &quot;165.72.1.236&quot;,\r\n        &quot;remotePort&quot;: &quot;51946&quot;,\r\n        &quot;localPort&quot;: &quot;6443&quot;,\r\n        &quot;sslsubject&quot;: null,\r\n        &quot;leg&quot;: 0,\r\n        &quot;timestamp&quot;: 1520235200642,\r\n        &quot;duration&quot;: 1107,\r\n        &quot;correlationId&quot;: &quot;c0f29c5a3e484ba5419878db&quot;,\r\n        &quot;serviceName&quot;: &quot;PeP e-Fulfillment API&quot;,\r\n        &quot;subject&quot;: &quot;d006366e-3b9e-415f-baff-cc1eec24898a&quot;,\r\n        &quot;operation&quot;: &quot;Get Available Stock&quot;,\r\n        &quot;type&quot;: &quot;http&quot;,\r\n        &quot;finalStatus&quot;: &quot;Pass&quot;\r\n      }\r\n    ]\r\n\r\nI have searched here over other articles but even if I found something it never worked for me. ",
        "link": "https://stackoverflow.com/questions/49105880/jq-how-to-output-document-if-a-value-is-not-null",
        "title": "jq - how to output document if a value is not null?"
    },
    {
        "tags": [
            "regex",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "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": 1520277210,
                "post_id": 49117626,
                "comment_id": 85240915,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1520284692,
                "creation_date": 1520284692,
                "answer_id": 49119643,
                "question_id": 49117626,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In the following, I&#39;ll assume you want to add &quot;ADDITIONAL&quot; to the array at EVERY key that matches a given regex (here &quot;ccc&quot;):\r\n\r\n    walk(if type == &quot;object&quot;\r\n         then with_entries(if (.key|test(&quot;ccc&quot;))\r\n                           then .value += [&quot;ADDITIONAL&quot;] else . end)\r\n         else . end)\r\n\r\nIf your jq does not have `walk/1`, then you can simply copy-and-paste its def from the [jq FAQ][1] or [builtin.jq][1]\r\n\r\n### Alternative formulation\r\n\r\nIf you have the following general-purpose helper function handy (e.g. in your ~/.jq):\r\n\r\n    def when(filter; action): if (filter?) // null then action else . end;\r\n\r\nthen the above solution shrinks down to:\r\n\r\n    walk(when(type == &quot;object&quot;;\r\n         with_entries(when(.key|test(&quot;ccc&quot;); .value += [&quot;ADDITIONAL&quot;]))))\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ\r\n",
                "title": "jq 1.5 find nested elements by regex when parent unknown"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1520299572,
        "creation_date": 1520276384,
        "last_edit_date": 1520299572,
        "question_id": 49117626,
        "body_markdown": "Given the JSON structure below i would like to find the first occurrence of object `ccc` so I can add a new object to the children `ddd`. However I do not know the key name of the parent or how many levels deep it may be.\r\n\r\nto find\r\n\r\n    &quot;children&quot;: {\r\n        &quot;ccc&quot;: [{\r\n            &quot;id&quot;: &quot;ddd&quot;,\r\n            &quot;des&quot;: &quot;object d&quot;,\r\n            &quot;parent&quot;: &quot;ccc&quot;\r\n        }]\r\n    }\r\n\r\nfull JSON stored in $myJson\r\n\r\n    {\r\n\t&quot;zzz&quot;: [{\r\n\t\t&quot;id&quot;: &quot;aaa&quot;,\r\n\t\t&quot;des&quot;: &quot;object A&quot;,\r\n\t\t&quot;parent&quot;: &quot;zzz&quot;,\r\n\t\t&quot;children&quot;: {\r\n\t\t\t&quot;aaa&quot;: [{\r\n\t\t\t\t&quot;id&quot;: &quot;bbb&quot;,\r\n\t\t\t\t&quot;des&quot;: &quot;object B&quot;,\r\n\t\t\t\t&quot;parent&quot;: &quot;aaa&quot;,\r\n\t\t\t\t&quot;children&quot;: {\r\n\t\t\t\t\t&quot;bbb&quot;: [{\r\n\t\t\t\t\t\t&quot;id&quot;: &quot;ccc&quot;,\r\n\t\t\t\t\t\t&quot;des&quot;: &quot;object C&quot;,\r\n\t\t\t\t\t\t&quot;parent&quot;: &quot;bbb&quot;,\r\n\t\t\t\t\t\t&quot;children&quot;: {\r\n\t\t\t\t\t\t\t&quot;ccc&quot;: [{\r\n\t\t\t\t\t\t\t\t&quot;id&quot;: &quot;ddd&quot;,\r\n\t\t\t\t\t\t\t\t&quot;des&quot;: &quot;object d&quot;,\r\n\t\t\t\t\t\t\t\t&quot;parent&quot;: &quot;ccc&quot;\r\n\t\t\t\t\t\t\t}]\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}, {\r\n\t\t\t\t\t\t&quot;id&quot;: &quot;eee&quot;,\r\n\t\t\t\t\t\t&quot;des&quot;: &quot;object e&quot;,\r\n\t\t\t\t\t\t&quot;parent&quot;: &quot;bbb&quot;\r\n\t\t\t\t\t}]\r\n\t\t\t\t}\r\n\t\t\t},{\r\n\t\t\t\t&quot;id&quot;: &quot;fff&quot;,\r\n\t\t\t\t&quot;des&quot;: &quot;object f&quot;,\r\n\t\t\t\t&quot;parent&quot;: &quot;aaa&quot;\r\n\t\t\t}]\r\n\t\t}\r\n\t}]}\t\r\n\r\nfollow some other answers I have tried combinations of\r\n \r\n\r\n    output=($(jq -r &#39;.. | with_entries(select(.key|match(&quot;ccc&quot;;&quot;i&quot;)))&#39; &lt;&lt;&lt; ${myjson}))\r\nor\r\n\r\n    output=($(jq -r &#39;.. | to_entries | map(select(.key | match(&quot;ccc&quot;;&quot;i&quot;))) | map(.value)&#39; &lt;&lt;&lt; ${myjson}))\r\n\r\nall give errors of a similar nature `jq: error (at &lt;stdin&gt;:1): number (0) cannot be matched, as it is not a string`\r\n\r\n",
        "link": "https://stackoverflow.com/questions/49117626/jq-1-5-find-nested-elements-by-regex-when-parent-unknown",
        "title": "jq 1.5 find nested elements by regex when parent unknown"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "sh",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1520321425,
                "creation_date": 1520321425,
                "answer_id": 49125508,
                "question_id": 49125451,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Always use double-quotes around command-substitution to avoid `*` to be treated literally.  The `*` is a special character in shell that is a wildcard entry that expands to all the files available in the current working directory. You need to quote it to deprive of its special meaning (Refer [GNU bash man page](https://linux.die.net/man/1/bash) under Parameters section).\r\n\r\nAlso `jq` can process the file directly, you can avoid useless `cat` usage.\r\n\r\n    result=&quot;$(jq -r &#39;.employees[2].division&#39; &lt; test.json)&quot;\r\n    echo &quot;$result&quot;\r\n\r\nshould produce the result as expected.",
                "title": "How to parse asterisk in json file as string via jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1587704941,
        "creation_date": 1520321163,
        "last_edit_date": 1587704941,
        "question_id": 49125451,
        "body_markdown": "Here is a json file named test.json for testing\r\n\r\n    {\r\n    \t&quot;name&quot;: &quot;Google&quot;,\r\n    \t&quot;location&quot;: {\r\n    \t\t&quot;street&quot;: &quot;1600 Amphitheatre Parkway&quot;,\r\n    \t\t&quot;city&quot;: &quot;Mountain View&quot;,\r\n    \t\t&quot;state&quot;: &quot;California&quot;,\r\n    \t\t&quot;country&quot;: &quot;US&quot;\r\n    \t},\r\n    \t&quot;employees&quot;: [\r\n    \t\t{\r\n    \t\t\t&quot;name&quot;: &quot;Michael&quot;,\r\n    \t\t\t&quot;division&quot;: &quot;Engineering&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;name&quot;: &quot;Laura&quot;,\r\n    \t\t\t&quot;division&quot;: &quot;HR&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;name&quot;: &quot;Elise&quot;,\r\n    \t\t\t&quot;division&quot;: &quot;Marketing * test&quot;\r\n    \t\t}\r\n    \t]\r\n    }\r\n\r\nif I use the `jq` code to parser it like below:\r\n\r\n    cat test.json | jq -r &#39;.employees[2].division&#39;\r\n\r\nit will work well and give a correct result:\r\n\r\n    Marketing * test\r\n\r\nbut I use `$()`, the bad thing will happen!\r\n\r\n    echo $(cat test.json | jq -r &#39;.employees[2].division&#39;)\r\n\r\nthe result will list all file names under current folder! like:\r\n\r\n    my1.json my2.json test.json test ...\r\n\r\nI guess it `$()` run asterisk `*` as a shell script, but a string.\r\n\r\nso how to make asterisk (`*`) in json file just as a string when I am using `jq` ?. I am using Google cloud platform and Ubuntu 17.10\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/49125451/how-to-parse-asterisk-in-json-file-as-string-via-jq",
        "title": "How to parse asterisk in json file as string via jq"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1520330724,
                "last_edit_date": 1520330724,
                "creation_date": 1520329870,
                "answer_id": 49127869,
                "question_id": 49127676,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It is quite simple when using [`jq`](https://stedolan.github.io/jq/manual/) using the `map()` call.\r\n\r\n    jq &#39;map(del(.age))&#39; &lt; json\r\n\r\nUsing `map()` for a given filter `del(.age)` will run it for each element of the input array, and return the output in a new array.",
                "title": "Delete key present inside objects array via jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1520337328,
        "creation_date": 1520329321,
        "last_edit_date": 1520337328,
        "question_id": 49127676,
        "body_markdown": "If I want to delete `age` from the JSON in first output. Is there a way to do that in one step, in other words, not invoking jq 2 times?\r\n\r\n    ➜ $?=0 @arastogi-ld2.linkedin.biz inGraphs/common-templates [ 1:39AM] ➤ echo &#39;[{&quot;id&quot;: 1, &quot;name&quot;: &quot;Arthur&quot;, &quot;age&quot;: &quot;21&quot;},{&quot;id&quot;: 2, &quot;name&quot;: &quot;Richard&quot;, &quot;age&quot;: &quot;32&quot;}]&#39; | jq .\r\n    [\r\n      {\r\n        &quot;id&quot;: 1,\r\n        &quot;name&quot;: &quot;Arthur&quot;,\r\n        &quot;age&quot;: &quot;21&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;name&quot;: &quot;Richard&quot;,\r\n        &quot;age&quot;: &quot;32&quot;\r\n      }\r\n    ]\r\n    \r\n    &gt;&gt;&gt;  0s elasped...\r\n    ➜ $?=0 @arastogi-ld2.linkedin.biz inGraphs/common-templates [ 1:39AM] ➤ echo &#39;[{&quot;id&quot;: 1, &quot;name&quot;: &quot;Arthur&quot;, &quot;age&quot;: &quot;21&quot;},{&quot;id&quot;: 2, &quot;name&quot;: &quot;Richard&quot;, &quot;age&quot;: &quot;32&quot;}]&#39; | jq &#39;.[] | del(.age)&#39; | jq -s\r\n    [\r\n      {\r\n        &quot;id&quot;: 1,\r\n        &quot;name&quot;: &quot;Arthur&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;name&quot;: &quot;Richard&quot;\r\n      }\r\n    ]\r\n    \r\n    &gt;&gt;&gt;  1s elasped...\r\n    ➜ $?=0 @arastogi-ld2.linkedin.biz inGraphs/common-templates [ 1:39AM] ➤",
        "link": "https://stackoverflow.com/questions/49127676/delete-key-present-inside-objects-array-via-jq",
        "title": "Delete key present inside objects array via jq"
    },
    {
        "tags": [
            "bash",
            "timestamp",
            "unix-timestamp",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1520535349,
                "last_edit_date": 1520535349,
                "creation_date": 1520340750,
                "answer_id": 49131338,
                "question_id": 49131125,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Simply use parentheses:\r\n\r\n     (.tickTimestamp | strftime(&quot;%B %d %Y %I:%M%p %Z&quot;))\r\n\r\nIf you want the time relative to TZ, use `strflocaltime`, which however requires a more recent version of jq than 1.5.",
                "title": "Apply strftime on last column in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1520535349,
        "creation_date": 1520340107,
        "last_edit_date": 1520340598,
        "question_id": 49131125,
        "body_markdown": "I am processing a file and filtering out certain fields from it. Then, I am converting the whole result to a CSV file. However, the last column that I am filtering out is the epoch timestamp (upto millisecond).\r\n\r\nSearching around, I found that I can use the `strftime` function in jq for conversion, however; when applying the `| strftime` inside the whole array, it applies the function to all the values.\r\n\r\n    TZ=&#39;Asia/Kolkata&#39;  grep $id ~/hhfh.log  |  grep -oE &#39;\\{.+&#39; | jq  -r &#39;[.highPrice, .lowPrice, .openPrice, .closePrice, .volumeTradedToday, .totalBuyQuantity, .totalSellQuantity, .tickTimestamp | strftime(&quot;%B %d %Y %I:%M%p %Z&quot;)]&#39; | jq -r &#39;map(tostring) | join(&quot;, &quot;)&#39;\r\n\r\nCan I modify this so that `strftime(&quot;%B %d %Y %I:%M%p %Z&quot;)` only applies to the `.tickTimestmap` value? If not, Would I have to depend on `awk`?\r\n\r\n---\r\n\r\nLog lines from `hhfh.log`:\r\n\r\n    2018-03-06 03:30:04,938 DEBUG KiteTickerSourceLogic [ReadingThread] TickData: {&quot;mode&quot;:&quot;full&quot;,&quot;tradable&quot;:false,&quot;instrumentToken&quot;:2997505,&quot;lastTradedPrice&quot;:740.0,&quot;highPrice&quot;:0.0,&quot;lowPrice&quot;:0.0,&quot;openPrice&quot;:731.5,&quot;closePrice&quot;:739.9,&quot;change&quot;:0.01351533991080183,&quot;lastTradedQuantity&quot;:23.0,&quot;averageTradePrice&quot;:0.0,&quot;volumeTradedToday&quot;:12.0,&quot;totalBuyQuantity&quot;:285.0,&quot;totalSellQuantity&quot;:1469.0,&quot;lastTradedTime&quot;:1520245282000,&quot;oi&quot;:0.0,&quot;tickTimestamp&quot;:1520307004000,&quot;openInterestDayHigh&quot;:0.0,&quot;openInterestDayLow&quot;:0.0,&quot;marketDepth&quot;:{&quot;buy&quot;:[{&quot;quantity&quot;:1,&quot;price&quot;:735.55,&quot;orders&quot;:1},{&quot;quantity&quot;:86,&quot;price&quot;:731.5,&quot;orders&quot;:1},{&quot;quantity&quot;:168,&quot;price&quot;:731.0,&quot;orders&quot;:1},{&quot;quantity&quot;:25,&quot;price&quot;:730.1,&quot;orders&quot;:1},{&quot;quantity&quot;:0,&quot;price&quot;:0.0,&quot;orders&quot;:0}],&quot;sell&quot;:[{&quot;quantity&quot;:550,&quot;price&quot;:743.6,&quot;orders&quot;:1},{&quot;quantity&quot;:550,&quot;price&quot;:746.6,&quot;orders&quot;:1},{&quot;quantity&quot;:10,&quot;price&quot;:750.0,&quot;orders&quot;:1},{&quot;quantity&quot;:25,&quot;price&quot;:777.0,&quot;orders&quot;:1},{&quot;quantity&quot;:12,&quot;price&quot;:-0.01,&quot;orders&quot;:1}]}}\r\n\r\nWhat I am currently generating:\r\n\r\n    January 01 1970 12:05:08AM UTC, January 01 1970 12:05:02AM UTC, January 01 1970 12:05:04AM UTC, January 01 1970 12:05:06AM UTC, January 19 1970 08:56:53AM UTC, January 01 1970 04:39:20AM UTC, January 01 1970 12:00:00AM UTC, August 31 50144 10:33:20AM UTC\r\n\r\nWhat it should be like:\r\n\r\n    751.95, 734.1, 745.45, 742.8, 1659987, 6358, 0, &lt;time in IST zone&gt;",
        "link": "https://stackoverflow.com/questions/49131125/apply-strftime-on-last-column-in-jq",
        "title": "Apply strftime on last column in jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1520349827,
                "creation_date": 1520349827,
                "answer_id": 49134318,
                "question_id": 49132181,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The simplest way to use `walk` here is to include the update in the &quot;then&quot; part of the `if ... then ... else ...end`.  To emphasize and clarify this, and to shorten the solution, I&#39;ll use the generic helper function, `when`:\r\n\r\n    def when(filter; action): if (filter?) // null then action else . end;\r\n\r\nThe solution to the problem can now be written in a very straightforward way:\r\n\r\n    walk(when(type == &quot;object&quot;;\r\n              with_entries(when(.key|test(&quot;ccc&quot;);\r\n                           when(any(.value[]; .id == &quot;ddd&quot;);\r\n    \t\t                    .value += [&quot;ADDITIONAL&quot;])))))\r\n\r\nOf course you might want a fancier test than .id == &quot;ddd&quot;, and you might want to perform the update only once per &quot;ccc&quot; object, but the same structure would be used.\r\n\r\nIn reality, you might also want to wrap the above expression in a `def` so it can more readily be parameterized and maintained.",
                "title": "jq 1.5 match a record where 2 or more keys match names and values"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1520373391,
                "creation_date": 1520373391,
                "answer_id": 49140657,
                "question_id": 49132181,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a response to the &quot;UPDATED&quot; question:\r\n\r\n    walk(when(type == &quot;object&quot;;\r\n              with_entries(when(.key|test(&quot;ccc&quot;);\r\n                                .value |= map( when(.id==&quot;ddd&quot;;\r\n    \t\t\t                          . + {&quot;newkey&quot;: &quot;newValue&quot;}))))))\r\n\r\n### p.s.\r\nIn future, please follow the mcve guidelines: http://stackoverflow.com/help/mcve ",
                "title": "jq 1.5 match a record where 2 or more keys match names and values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1520373391,
        "creation_date": 1520343449,
        "last_edit_date": 1520356702,
        "question_id": 49132181,
        "body_markdown": "Not quite sure how to ask the question clearly but, given a recursive structure as below. How would I use `walk` to match 2 or more key strings to values. I will not know where in the structure the result will be. It could be the top level or 10 levels deep.\r\n\r\n    &quot;children&quot;: {\r\n        &quot;ccc&quot;: [{\r\n            &quot;id&quot;: &quot;ddd&quot;,\r\n            &quot;des&quot;: &quot;object d&quot;,\r\n            &quot;parent&quot;: &quot;ccc&quot;,\r\n            &quot;other&quot;: &quot;zzz&quot;\r\n        },{\r\n            &quot;id&quot;: &quot;zzz&quot;,\r\n            &quot;des&quot;: &quot;object z&quot;,\r\n            &quot;parent&quot;: &quot;ccc&quot;,\r\n            &quot;other&quot; : &quot;ddd&quot;\r\n      }]\r\n    }\r\n\r\nI would like to find a record where `key=id=ddd` &amp;&amp; `key=parent=ccc`I would then like to add a new key/value to that record. Using `.key|match(&quot;&quot;)` will give me a match to the value of the key but not the key name itself. So searching for `ddd` may match both `id` and `other`.\r\n\r\nI have tried several combos and if doing in bash it would look something like \r\n\r\n\r\nmatch_criteria\r\n      \r\n\r\n         ((.key|match(&quot;id&quot;) and (.key|test(&quot;ddd&quot;)) \r\n            and \r\n         ((.key|match(&quot;parent&quot;) and (.key|test(&quot;ccc&quot;)) \r\n\r\nnew_key_value\r\n\r\n    += {&quot;newkey&quot;:&quot;newValue&quot;}\r\n\r\ninsert match statement into\r\n\r\n    walk(if type == &quot;object&quot;\r\n          then\r\n            with_entries(if ..match_criteria.. )\r\n          then ..new_key_value.. else . end)\r\n \r\nso the result should look like\r\n\r\n    &quot;children&quot;: {\r\n        &quot;ccc&quot;: [{\r\n            &quot;id&quot;: &quot;ddd&quot;,\r\n            &quot;des&quot;: &quot;object d&quot;,\r\n            &quot;parent&quot;: &quot;ccc&quot;,\r\n            &quot;other&quot;: &quot;zzz&quot;,\r\n            &quot;newkey&quot;: &quot;newValue&quot;\r\n        },{\r\n            &quot;id&quot;: &quot;zzz&quot;,\r\n            &quot;des&quot;: &quot;object z&quot;,\r\n            &quot;parent&quot;: &quot;ccc&quot;,\r\n            &quot;other&quot;:&quot;ddd&quot;\r\n      }]\r\n    }\r\n\r\n**UPDATE**\r\nbased on feedback in the answer from @peak i have updated the code as follows\r\n\r\n    jsonOut=$(jq &#39;walk(when(type == &quot;object&quot;;\r\n                  with_entries(\r\n                      when(any(.value[]; .id == &quot;ddd&quot;);\r\n                               .value[] += {&quot;newkey&quot;: &quot;newValue&quot;}\r\n                                ))))&#39; &lt;&lt;&lt; ${jsonIn})\r\nunfortunately this still leaves two open issues\r\n\r\na) this code adds `{&quot;newkey&quot;: &quot;newValue&quot;}` to all children where the search criteria is true, ie: to both `id:ddd` &amp;&amp; `id:zzz`, rather than to just the `id:ddd` record\r\n\r\n    &quot;children&quot;: {\r\n            &quot;ccc&quot;: [{\r\n                &quot;id&quot;: &quot;ddd&quot;,\r\n                &quot;des&quot;: &quot;object d&quot;,\r\n                &quot;parent&quot;: &quot;ccc&quot;,\r\n                &quot;other&quot;: &quot;zzz&quot;,\r\n                &quot;newkey&quot;: &quot;newValue&quot;\r\n            },{\r\n                &quot;id&quot;: &quot;zzz&quot;,\r\n                &quot;des&quot;: &quot;object z&quot;,\r\n                &quot;parent&quot;: &quot;ccc&quot;,\r\n                &quot;other&quot;:&quot;ddd&quot;,\r\n               &quot;newkey&quot;: &quot;newValue&quot;\r\n          }]\r\n        }\r\n\r\nb) adding multiple section criteria to the `any` clause. I have tried using the `AND` or `|` joining methods but this throws errors.\r\n\r\n    when(any(.value[]; .id == &quot;ddd&quot; | .other == &quot;zzz&quot;); //no match, no value added\r\n    or\r\n    when((any(.value[]; .id == &quot;ddd&quot;) AND (any(.value[]; .other == &quot;zzz&quot;));\r\n         //error : unexpected &#39;)&#39;, expecting $end\r\n    or\r\n    when(any(.value[]; .id == &quot;ddd&quot;, .other == &quot;zzz&quot;); //no match, no value added\r\n\r\nCan you advise the syntax for both issues.\r\n\r\n**UPDATE2** Understanding the `when` filter a littler better, I have now nested these and it seems to work in narrowing the result set. However problem `a)` updating both records when a match is true still exists.\r\n\r\n    jsonOut=$(jq &#39;walk(when(type == &quot;object&quot;;\r\n              with_entries(\r\n                           when(any(.value[]; .id == &quot;ddd&quot;);\r\n                            when(any(.value[]; .other == &quot;zzz&quot;);\r\n                                .value[] += {&quot;newkey&quot;: &quot;newValue&quot;}\r\n                                )))))&#39; &lt;&lt;&lt; ${jsonIn})\r\njsonIn\r\n\r\n    {&quot;children&quot;: {\r\n        &quot;ccc&quot;: [{\r\n            &quot;id&quot;: &quot;ddd&quot;,\r\n            &quot;des&quot;: &quot;object d&quot;,\r\n            &quot;parent&quot;: &quot;ccc&quot;,\r\n            &quot;other&quot;: &quot;zzz&quot;\r\n        },{\r\n            &quot;id&quot;: &quot;zzz&quot;,\r\n            &quot;des&quot;: &quot;object z&quot;,\r\n            &quot;parent&quot;: &quot;ccc&quot;,\r\n            &quot;other&quot;:&quot;ddd&quot;\r\n      }],\r\n      &quot;www&quot;: [{\r\n            &quot;id&quot;: &quot;ddd&quot;,\r\n            &quot;des&quot;: &quot;object d&quot;,\r\n            &quot;parent&quot;: &quot;www&quot;,\r\n            &quot;other&quot;: &quot;ppp&quot;\r\n       },{\r\n            &quot;id&quot;: &quot;kkk&quot;,\r\n            &quot;des&quot;: &quot;object z&quot;,\r\n            &quot;parent&quot;: &quot;www&quot;,\r\n            &quot;other&quot;:&quot;ddd&quot;\r\n      }]\r\n    }}\r\njsonOut\r\n\r\n    {\r\n    \t&quot;children&quot;: {\r\n    \t\t&quot;ccc&quot;: [{\r\n    \t\t\t&quot;id&quot;: &quot;ddd&quot;,\r\n    \t\t\t&quot;des&quot;: &quot;object d&quot;,\r\n    \t\t\t&quot;parent&quot;: &quot;ccc&quot;,\r\n    \t\t\t&quot;other&quot;: &quot;zzz&quot;,\r\n    \t\t\t&quot;newkey&quot;: &quot;newValue&quot;\r\n    \t\t}, {\r\n    \t\t\t&quot;id&quot;: &quot;zzz&quot;,\r\n    \t\t\t&quot;des&quot;: &quot;object z&quot;,\r\n    \t\t\t&quot;parent&quot;: &quot;ccc&quot;,\r\n    \t\t\t&quot;other&quot;: &quot;ddd&quot;,\r\n    \t\t\t&quot;newkey&quot;: &quot;newValue&quot; &lt;=need to NOT add this entry\r\n    \t\t}],\r\n    \t\t&quot;www&quot;: [{\r\n    \t\t\t&quot;id&quot;: &quot;ddd&quot;,\r\n    \t\t\t&quot;des&quot;: &quot;object d&quot;,\r\n    \t\t\t&quot;parent&quot;: &quot;www&quot;,\r\n    \t\t\t&quot;other&quot;: &quot;ppp&quot;\r\n    \t\t}, {\r\n    \t\t\t&quot;id&quot;: &quot;kkk&quot;,\r\n    \t\t\t&quot;des&quot;: &quot;object z&quot;,\r\n    \t\t\t&quot;parent&quot;: &quot;www&quot;,\r\n    \t\t\t&quot;other&quot;: &quot;ddd&quot;\r\n    \t\t}]\r\n    \t}\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/49132181/jq-1-5-match-a-record-where-2-or-more-keys-match-names-and-values",
        "title": "jq 1.5 match a record where 2 or more keys match names and values"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1520369089,
                "creation_date": 1520369089,
                "answer_id": 49139629,
                "question_id": 49139191,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "For this type of problem, you can use `..`.  With your data as input, the following filter:\r\n\r\n    ..\r\n    | objects\r\n    | to_entries[]\r\n    | select(.key|test(&quot;ccc&quot;))\r\n    | .value[]\r\n    | select(.parent==&quot;ccc&quot;)\r\n    | .id\r\n\r\nproduces:\r\n\r\n    &quot;ddd&quot;",
                "title": "jq save value of nested key into var"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1520369089,
        "creation_date": 1520367034,
        "question_id": 49139191,
        "body_markdown": "With thanks to @peak with the [linked question][1] I have started to understand jq, but I am struggling with the basics of how to capture the output to vars in bash. reviewing the jq manual has not cleared things up\r\n\r\ngiven the json below I would like to use walk to capture the value of a nested key. The structure is unknown prior to execution, so a standard query is not possible and the needed key can be a arbitrary nested level deep from 0 to 20.\r\n   \r\nsample json\r\n\r\n    {\r\n        &quot;zzz&quot;: [{\r\n            &quot;id&quot;: &quot;aaa&quot;,\r\n            &quot;des&quot;: &quot;object A&quot;,\r\n            &quot;parent&quot;: &quot;zzz&quot;,\r\n            &quot;children&quot;: {\r\n                &quot;aaa&quot;: [{\r\n                    &quot;id&quot;: &quot;bbb&quot;,\r\n                    &quot;des&quot;: &quot;object B&quot;,\r\n                    &quot;parent&quot;: &quot;aaa&quot;,\r\n                    &quot;children&quot;: {\r\n                        &quot;bbb&quot;: [{\r\n                            &quot;id&quot;: &quot;ccc&quot;,\r\n                            &quot;des&quot;: &quot;object C&quot;,\r\n                            &quot;parent&quot;: &quot;bbb&quot;,\r\n                            &quot;children&quot;: {\r\n                                &quot;ccc&quot;: [{\r\n                                    &quot;id&quot;: &quot;ddd&quot;, &lt;===this is the value I need\r\n                                    &quot;des&quot;: &quot;object d&quot;,\r\n                                    &quot;parent&quot;: &quot;ccc&quot;\r\n                                }]\r\n                            }\r\n                        }, {\r\n                            &quot;id&quot;: &quot;eee&quot;,\r\n                            &quot;des&quot;: &quot;object e&quot;,\r\n                            &quot;parent&quot;: &quot;bbb&quot;\r\n                        }]\r\n                    }\r\n                },{\r\n                    &quot;id&quot;: &quot;fff&quot;,\r\n                    &quot;des&quot;: &quot;object f&quot;,\r\n                    &quot;parent&quot;: &quot;aaa&quot;\r\n                }]\r\n            }\r\n        }]} \r\n\r\nnow using the `walk` function I can locate the key I want\r\n\r\n    myId=$(jq &#39;walk(when(type == &quot;object&quot;;\r\n                                with_entries(\r\n                                when(.key|test(&quot;ccc&quot;);\r\n                                when(any(.value[]; .parent == &quot;ccc&quot;);\r\n                                    ...insert action-code here....\r\n                                    )))))&#39; &lt;&lt;&lt; ${json})\r\nIf I use the `walk` code above and have an action code like `.value[] += {&quot;myKey&quot;: &quot;myVal&quot;}` it will add it to the selected object.\r\n\r\nNow I want to capture the value of `id` not add to the object. So I though it would be a simple string or perhaps a select statement but they do not work.\r\n\r\naction-code\r\n\r\n    select(.parent == &quot;ccc&quot;)|.hrn|.value\r\n    or\r\n    .hrn.value\r\n    or\r\n    .value[].hrn?\r\n\r\nplus a lot of other combinations. What is the correct syntax to capture the `id` value?\r\n\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/49132181/jq-1-5-match-a-record-where-2-or-more-keys-match-names-and-values\r\n",
        "link": "https://stackoverflow.com/questions/49139191/jq-save-value-of-nested-key-into-var",
        "title": "jq save value of nested key into var"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1520381481,
                "creation_date": 1520381481,
                "answer_id": 49142092,
                "question_id": 49141718,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With your data, the filter:\r\n\r\n    .data[][] | select(.attr3) | .attr2\r\n\r\nproduces:\r\n\r\n    &quot;val2&quot;",
                "title": "Get a field based on an attribute with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1520381481,
        "creation_date": 1520378954,
        "last_edit_date": 1520379499,
        "question_id": 49141718,
        "body_markdown": "Let&#39;s say that I have the following structure:\r\n\r\n    {\r\n\t&quot;data&quot;: [\r\n\t\t{\r\n\t\t\t&quot;wrapper_1&quot;: {\r\n\t\t\t\t&quot;attr1&quot;: &quot;val1&quot;,\r\n\t\t\t\t&quot;attr2&quot;: &quot;val2&quot;,\r\n\t\t\t\t&quot;attr3&quot;: true\r\n\t\t\t}\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;wrapper_2&quot;: {\r\n\t\t\t\t&quot;attr1&quot;: &quot;val1&quot;,\r\n\t\t\t\t&quot;attr2&quot;: &quot;val2&quot;,\r\n\t\t\t\t&quot;attr3&quot;: false\r\n\t\t\t}\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;wrapper_3&quot;: {\r\n\t\t\t\t&quot;attr1&quot;: &quot;val1&quot;,\r\n\t\t\t\t&quot;attr2&quot;: &quot;val2&quot;,\r\n\t\t\t\t&quot;attr3&quot;: false\r\n\t\t\t}\r\n\t\t},\r\n\t\t...\r\n\t]\r\n}\r\n\r\nAs you can see, I have an array that, for some reason, has a set of objects that have a different &quot;title&quot; (wrapper), but its inside structure is shared by all the elements present into that array.\r\nI&#39;ll have on `attr3` only one truthy element, while the rest of the elements of `data` will have a `false` value on that element.\r\n\r\nGiven that condition (`attr3 == true`), I need to filter that element and get the value of `attr2`. I am a beginner with jq and I tried this with no luck:\r\n\r\n`jq &#39;.path.to.data[] | select(.attr3 == true)&#39;`\r\n\r\nI&#39;m reading about the combination of `map` and `select` but I can&#39;t figure it out. Also, I know that the snippet above doesn&#39;t work because it assumes that elements of `data` are homogeneous and this is not the case.\r\n\r\nAny advice about this would be greatly appreciated.\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/49141718/get-a-field-based-on-an-attribute-with-jq",
        "title": "Get a field based on an attribute with jq"
    },
    {
        "tags": [
            "bash",
            "parsing",
            "logging",
            "jq",
            "tail"
        ],
        "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": 1520384360,
                "post_id": 49142436,
                "comment_id": 85290550,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 371672,
                    "reputation": 6510,
                    "user_id": 720323,
                    "user_type": "registered",
                    "accept_rate": 97,
                    "profile_image": "https://i.sstatic.net/wxseh.jpg?s=256",
                    "display_name": "HelpNeeder",
                    "link": "https://stackoverflow.com/users/720323/helpneeder"
                },
                "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": 1520384420,
                "post_id": 49142436,
                "comment_id": 85290560,
                "content_license": "CC BY-SA 3.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": 1520384531,
                "post_id": 49142436,
                "comment_id": 85290584,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 371672,
                    "reputation": 6510,
                    "user_id": 720323,
                    "user_type": "registered",
                    "accept_rate": 97,
                    "profile_image": "https://i.sstatic.net/wxseh.jpg?s=256",
                    "display_name": "HelpNeeder",
                    "link": "https://stackoverflow.com/users/720323/helpneeder"
                },
                "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": 1520384580,
                "post_id": 49142436,
                "comment_id": 85290597,
                "content_license": "CC BY-SA 3.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": 1520384623,
                "post_id": 49142436,
                "comment_id": 85290611,
                "content_license": "CC BY-SA 3.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": 1520384875,
                "post_id": 49142436,
                "comment_id": 85290664,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 371672,
                    "reputation": 6510,
                    "user_id": 720323,
                    "user_type": "registered",
                    "accept_rate": 97,
                    "profile_image": "https://i.sstatic.net/wxseh.jpg?s=256",
                    "display_name": "HelpNeeder",
                    "link": "https://stackoverflow.com/users/720323/helpneeder"
                },
                "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": 1520384970,
                "post_id": 49142436,
                "comment_id": 85290690,
                "content_license": "CC BY-SA 3.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": 1520384999,
                "post_id": 49142436,
                "comment_id": 85290693,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1520386621,
                "last_edit_date": 1520386621,
                "creation_date": 1520384222,
                "answer_id": 49142467,
                "question_id": 49142436,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use a [BashFAQ #1](http://mywiki.wooledge.org/BashFAQ/001) `while read` loop to iterate over the lines, and a [BashFAQ #100](http://mywiki.wooledge.org/BashFAQ/100) [parameter expansion](http://wiki.bash-hackers.org/syntax/pe) to perform the desired modifications:\r\n\r\n    tail -f -- errors.log \\\r\n      | jq --raw-output --unbuffered \\\r\n           &#39;[.server_name, .server_port, .request_file] | @tsv&#39; \\\r\n      | while IFS=$&#39;\\t&#39; read -r server_name server_port request_file; do\r\n          printf &#39;%s\\t%s\\t%s\\n&#39; &quot;$server_name&quot; &quot;$server_port&quot; &quot;/${request_file#/var/www/*/}&quot;\r\n        done\r\n\r\nNote the use of `--unbuffered`, to force `jq` to flush its output lines immediately rather than buffering them. This has a performance penalty (so it&#39;s not default), but it ensures that you get output immediately when reading from a potentially-slow input source.\r\n\r\n---\r\n\r\nThat said, it&#39;s also easy to remove a prefix in `jq`, so there&#39;s no particular reason to do the above:\r\n\r\n    tail -f -- errors.log | jq -r &#39;\r\n      def withoutPrefix: sub(&quot;^([/][^/]+){3}&quot;; &quot;&quot;);\r\n      [.server_name, .server_port, (.request_file | withoutPrefix)] | @tsv&#39;",
                "title": "Parse JQ output through external bash function?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1520393876,
        "creation_date": 1520384029,
        "last_edit_date": 1520393876,
        "question_id": 49142436,
        "body_markdown": "I want to parse out data out of a log file which consist of JSON sting and I wonder if there&#39;s a way for me to use a bash function to perform any custom parsing instead of overloading `jq` command.\r\n\r\nCommand:\r\n\r\n    tail errors.log --follow | jq --raw-output &#39;. | [.server_name, .server_port, .request_file] | @tsv&#39; \r\n\r\nOutputs:\r\n\r\n    8.8.8.8     80     /var/www/domain.com/www/public\r\n\r\nI want to parse 3rd column to cut the string to exclude `/var/www/domain.com` part where `/var/www/domain.com` is the document root, and `/var/www/domain.com/subdomain/public` is the public `html` section of the site. Therefore I would like to leave my output as `/subdomain/public` (or from the example `/www/public`).\r\n\r\nI wonder if I can somehow inject a bash function to parse `.request_file` column? Or how would I do that using `jq`?\r\n\r\nI&#39;m having issues piping out the output of any part of this command that would allow me to do any sort of string manipulation.",
        "link": "https://stackoverflow.com/questions/49142436/parse-jq-output-through-external-bash-function",
        "title": "Parse JQ output through external bash function?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "edit",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13085395,
                    "reputation": 65,
                    "user_id": 9454530,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-XdUIqdMkCWA/AAAAAAAAAAI/AAAAAAAAAAA/4252rscbv5M/s256-rj/photo.jpg",
                    "display_name": "Dale",
                    "link": "https://stackoverflow.com/users/9454530/dale"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1520394954,
                "post_id": 49143828,
                "comment_id": 85292957,
                "content_license": "CC BY-SA 3.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": 1520401045,
                "post_id": 49143828,
                "comment_id": 85294671,
                "content_license": "CC BY-SA 3.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": 1,
                "creation_date": 1520408820,
                "post_id": 49143828,
                "comment_id": 85297799,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 13085395,
                    "reputation": 65,
                    "user_id": 9454530,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-XdUIqdMkCWA/AAAAAAAAAAI/AAAAAAAAAAA/4252rscbv5M/s256-rj/photo.jpg",
                    "display_name": "Dale",
                    "link": "https://stackoverflow.com/users/9454530/dale"
                },
                "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": 1520419605,
                "post_id": 49143828,
                "comment_id": 85304189,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1520423860,
                "last_edit_date": 1520423860,
                "creation_date": 1520421444,
                "answer_id": 49150600,
                "question_id": 49143828,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`del/1` is capable of deleting nodes based on path expressions.\r\n\r\nThe example doesn&#39;t seem to be minimal, so let&#39;s consider:\r\n\r\n      {&quot;a&quot;:{&quot;c&quot;:[\r\n             {&quot;d&quot;:{&quot;c&quot;:[{&quot;e&quot;:&quot;xyzzy&quot;},{&quot;e&quot;:2}]}},\r\n             {&quot;d&quot;:{&quot;c&quot;:[{&quot;e&quot;:&quot;xyzzy&quot;},{&quot;e&quot;:2}]}} ]}}\r\n\r\nNow suppose we want to delete the objects for which `.e == &quot;xyzz&quot;`:\r\n\r\n    del( .a.c[].d.c[] | select(.e == &quot;xyzzy&quot;) )\r\n\r\nThis would result in:\r\n    {&quot;a&quot;:{&quot;c&quot;:[{&quot;d&quot;:{&quot;c&quot;:[{&quot;e&quot;:2}]}},{&quot;d&quot;:{&quot;c&quot;:[{&quot;e&quot;:2}]}}]}}\r\n\r\nUnfortunately, jq 1.5 does not support complex path specifications in `del/1`; using a sufficiently recent version of jq, however, we can write:\r\n\r\n    del( .a.c[].d.c[] | select(.e | type == &quot;string&quot; and contains(&quot;xyzzy&quot;) ) )\r\n\r\nThus, with the above-mentioned caveat about jq 1.5, you could write:\r\n\r\n    del(.rules.children[].children[] | select(.name| contains(&quot;7004389c-c47a-4611-9bd7-9f5dfe051d17&quot;)))\r\n\r\n### Workaround for jq 1.5\r\n\r\n    .rules.children[].children |= \r\n      map(select((.name? // &quot;&quot;)\r\n                 | contains(&quot;7004389c-c47a-4611-9bd7-9f5dfe051d17&quot;)\r\n                 | not))\r\n",
                "title": "jq removing inner child node without breaking the json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1520429735,
        "creation_date": 1520394871,
        "last_edit_date": 1520429735,
        "question_id": 49143828,
        "body_markdown": "Im trying to get jq to remove an inner node from a json file, the json file looks as so:\r\n\r\n        {\r\n      &quot;etag&quot;: &quot;14b3796c268c87553291702c808e86dfe1e53d1b&quot;,\r\n      &quot;rules&quot;: {\r\n        &quot;name&quot;: &quot;default&quot;,\r\n        &quot;children&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;xxxx&quot;,\r\n            &quot;children&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;dffaa42b-3f0f-425f-a9a1-a63cd35b2517&quot;,\r\n                &quot;children&quot;: [],\r\n                &quot;behaviors&quot;: [\r\n                  {\r\n                    &quot;name&quot;: &quot;xxx&quot;,\r\n                    &quot;options&quot;: {\r\n                      &quot;key&quot;: &quot;xxx-xxx-xxx-xxx&quot;,\r\n                      &quot;compress&quot;: true,\r\n                      &quot;ports&quot;: &quot;&quot;\r\n                    }\r\n                  }\r\n                ],\r\n                &quot;criteria&quot;: [\r\n                  {\r\n                    &quot;name&quot;: &quot;xxxx&quot;,\r\n                    &quot;options&quot;: {\r\n                      &quot;Name&quot;: &quot;UUID&quot;,\r\n                      &quot;values&quot;: [\r\n                        &quot;dffaa42b-3f0f-425f-a9a1-a63cd35b2517&quot;\r\n                      ]\r\n                    }\r\n                  }\r\n                ],\r\n                &quot;criteriaMustSatisfy&quot;: &quot;all&quot;\r\n              },\r\n              {\r\n                &quot;name&quot;: &quot;7004389c-c47a-4611-9bd7-9f5dfe051d17&quot;,\r\n                &quot;children&quot;: [],\r\n                &quot;behaviors&quot;: [\r\n                  {\r\n                    &quot;name&quot;: &quot;xxx&quot;,\r\n                    &quot;options&quot;: {\r\n                      &quot;key&quot;: &quot;xxx-xxx-xxx-xxx&quot;,\r\n                      &quot;compress&quot;: true,\r\n                      &quot;ports&quot;: &quot;&quot;\r\n                    }\r\n                  }\r\n                ],\r\n                &quot;criteria&quot;: [\r\n                  {\r\n                    &quot;name&quot;: &quot;xxxx&quot;,\r\n                    &quot;options&quot;: {\r\n                      &quot;Name&quot;: &quot;UUID&quot;,\r\n                      &quot;values&quot;: [\r\n                        &quot;7004389c-c47a-4611-9bd7-9f5dfe051d17&quot;\r\n                      ]\r\n                    }\r\n                  }\r\n                ],\r\n                &quot;criteriaMustSatisfy&quot;: &quot;all&quot;\r\n              }\r\n            ],\r\n            &quot;behaviors&quot;: [],\r\n            &quot;criteria&quot;: [],\r\n            &quot;criteriaMustSatisfy&quot;: &quot;all&quot;\r\n          }\r\n        ],\r\n        &quot;behaviors&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;xxx&quot;,\r\n            &quot;options&quot;: {}\r\n          }\r\n        ],\r\n        &quot;options&quot;: {\r\n          &quot;is_secure&quot;: true\r\n        },\r\n        &quot;variables&quot;: []\r\n        },\r\n      &quot;warnings&quot;: [\r\n      ],\r\n      &quot;Format&quot;: &quot;xxx&quot;\r\n    }\r\n\r\nI may have muddled up the json structure, however my jq query at the moment is as follows:\r\n\r\n    (.rules.children[].children[] | select(.name | contains(&quot;7004389c-c47a-4611-9bd7-9f5dfe051d17&quot;)| not ))\r\n\r\nThis works, excepts it it return the json excluding the child item from `.rules.children[].children[]`.\r\n\r\nHow do I have jq return the entire json file excluding the json identified in the filter?\r\n",
        "link": "https://stackoverflow.com/questions/49143828/jq-removing-inner-child-node-without-breaking-the-json",
        "title": "jq removing inner child node without breaking the json"
    },
    {
        "tags": [
            "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": 0,
                "creation_date": 1520409339,
                "post_id": 49145205,
                "comment_id": 85298073,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1520409256,
                "last_edit_date": 1520409256,
                "creation_date": 1520406812,
                "answer_id": 49146126,
                "question_id": 49145205,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It is much easier to convert first and subtract the three hours.\r\n\r\nExample below converts to seconds and prints true if condition is met.\r\n\r\n`date_in_seconds=$(date -d $custom_field +&quot;%s&quot;);\r\n[ ${date_in_seconds} -gt 259200 ] &amp;&amp; echo true;`\r\n\r\nFor non GNU versions of the `date` command you can use the following;\r\n\r\n`date_in_seconds=$(date -j -f &#39;%Y-%m-%d %H:%M:%S&#39; &quot;2016-02-22 20:22:14&quot; &#39;+%s&#39;)`\r\n\r\nKeep in mind that the `EPOCH` will rollover 1 Jan 2036.",
                "title": "Compare datetime inside variable with current datetime"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1520419146,
                "last_edit_date": 1520419146,
                "creation_date": 1520409260,
                "answer_id": 49146748,
                "question_id": 49145205,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Given input like\r\n\r\n    { &quot;issues&quot;:\r\n     [{&quot;id&quot;: 1, &quot;fields&quot;: {&quot;created&quot;: &quot;2018-03-06T21:24:41.000+0000&quot;}},\r\n      {&quot;id&quot;: 2, &quot;fields&quot;: {&quot;created&quot;: &quot;2018-03-06T22:48:47.000+0000&quot;}},\r\n      {&quot;id&quot;: 3, &quot;fields&quot;: {&quot;created&quot;: &quot;2018-03-09T22:48:47.000+0000&quot;}}]}\r\n\r\nyou can use the built-in date manipulation functions to print the old records with something like\r\n\r\n    jq -r &#39;(now-3600*3) as $when | .issues[] |\r\n      select(.fields.created | strptime(&quot;%Y-%m-%dT%H:%M:%S.000+0000&quot;) | mktime &lt; $when) |\r\n    [.id, .fields.created, &quot;old&quot;]&#39; 1.json\r\n\r\nwhere the last line probably needs tweaking to produce exactly the output you want.",
                "title": "Compare datetime inside variable with current datetime"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1520423859,
        "creation_date": 1520402819,
        "last_edit_date": 1520423859,
        "question_id": 49145205,
        "body_markdown": "I have the following line:\r\n\r\n     for custom_field in $(jq -r &#39;.issues[] | .fields.created&#39; 1.json\r\n    ); do\r\n          echo $custom_field\r\n    \r\n    done\r\n\r\nOutput:\r\n\r\n    2018-03-06T21:24:41.000+0000\r\n    2018-03-06T22:48:47.000+0000\r\n\r\nHow to compare current datetime with each output and if it&#39;s older than 3 hours to print &quot;old&quot;?\r\n",
        "link": "https://stackoverflow.com/questions/49145205/compare-datetime-inside-variable-with-current-datetime",
        "title": "Compare datetime inside variable with current datetime"
    },
    {
        "tags": [
            "json",
            "list",
            "directory",
            "jq",
            "ls"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1520507343,
                "last_edit_date": 1520507343,
                "creation_date": 1520485656,
                "answer_id": 49165802,
                "question_id": 49161220,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following only handles vanilla files and is neither portable nor robust but should be sufficient to get you on your way.\r\n\r\nThe JSON structure that is emitted is very similar to the output of the `tree` program (shown below); in particular, it uses directory components as strings, since that produces an economical\r\nhierarchy allowing queries such as `.a.b` to view details about the directory ‘./a/b’. To provide jq the necessary data, we use `find . -ls`.\r\n\r\n### jqtree\r\n\r\n    #!/bin/bash\r\n    \r\n    find . -ls | jq -nR &#39;\r\n      # Return an object with useful information\r\n      def gather:\r\n        [splits(&quot; +&quot;)] as $in\r\n        | { pathname: $in[-1], entrytype: $in[2][0:1], size: ($in[6] | tonumber) };\r\n    \r\n      reduce (inputs | gather) as $entry ({};\r\n          ($entry.pathname | split(&quot;/&quot;) ) as $names\r\n          | if ($entry|.entrytype == &quot;-&quot;) then\r\n               ($names[0:-1] + [&quot;items&quot;]) as $p\r\n               | setpath($p; getpath($p) + [{name: $names[-1], size: $entry.size}])\r\n            else . end) &#39;\r\n\r\n### Demo\r\n\r\n    $ tree\r\n    .\r\n    |-- a\r\n    |   `-- b\r\n    |       `-- foo\r\n    |-- big\r\n    |-- foo\r\n    `-- so\r\n    \r\n    $ ~/bin/jqtree\r\n    {\r\n      &quot;.&quot;: {\r\n        &quot;items&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;big&quot;,\r\n            &quot;size&quot;: 1025\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;so&quot;,\r\n            &quot;size&quot;: 667\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;foo&quot;,\r\n            &quot;size&quot;: 0\r\n          }\r\n        ],\r\n        &quot;a&quot;: {\r\n          &quot;b&quot;: {\r\n            &quot;items&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;foo&quot;,\r\n                &quot;size&quot;: 0\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n",
                "title": "List directory to json format using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1520546259,
                "creation_date": 1520546259,
                "answer_id": 49183160,
                "question_id": 49161220,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This Linux works on mips. Not have `find . -ls` (PARAM not available), tree not have.\r\n\r\nMaybe someone can compile `tree` package.\r\n\r\n\r\n    BusyBox v1.22.1 (2017-06-29 11:15:20 CST) multi-call binary.\r\n    \r\n    Usage: find [-HL] [PATH]... [OPTIONS] [ACTIONS]\r\n    \r\n    Search for files and perform actions on them.\r\n    First failed action stops processing of current file.\r\n    Defaults: PATH is current directory, action is &#39;-print&#39;\r\n    \r\n    \t-L,-follow\tFollow symlinks\r\n    \t-H\t\t...on command line only\r\n    \r\n    Actions:\r\n    \tACT1 [-a] ACT2\tIf ACT1 fails, stop, else do ACT2\r\n    \tACT1 -o ACT2\tIf ACT1 succeeds, stop, else do ACT2\r\n    \t\t\tNote: -a has higher priority than -o\r\n    \t-name PATTERN\tMatch file name (w/o directory name) to PATTERN\r\n    \t-iname PATTERN\tCase insensitive -name\r\n    If none of the following actions is specified, -print is assumed\r\n    \t-print\t\tPrint file name",
                "title": "List directory to json format using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1520546259,
        "creation_date": 1520456882,
        "last_edit_date": 1520507553,
        "question_id": 49161220,
        "body_markdown": "I&#39;ve tried to get linux list of my all files and directories in specified path to json format using ls and jq.\r\n\r\nDesired output:\r\n[![enter image description here][1]][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/P1Ipm.png\r\n\r\n\r\nthis is all what I have...\r\nls | jq -R &#39;[.]&#39; | jq -s -c &#39;add&#39;\r\n\r\nIs it possible to build output like above in the picture?",
        "link": "https://stackoverflow.com/questions/49161220/list-directory-to-json-format-using-jq",
        "title": "List directory to json format using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1520477178,
                "creation_date": 1520477178,
                "answer_id": 49164558,
                "question_id": 49162956,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The key to a simple formulation of your query is `any/2`:\r\n\r\n    .imageDetails[] | select(any(.imageTags[]; . == &quot;mytest1&quot;))",
                "title": "jq | return subset of data based on matched array element"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1520477178,
        "creation_date": 1520465188,
        "question_id": 49162956,
        "body_markdown": "I am trying to parse the below json file using jq. I&#39;d like to return a subset of that data. \r\n\r\n      {\r\n          &quot;imageDetails&quot;: [\r\n            {\r\n              &quot;imageSizeInBytes&quot;: 2066961,\r\n              &quot;imageDigest&quot;: &quot;sha256:ff089cca12407adce49e70771a32c2fd48d53d8d3fb735cee430037e6b27c535123&quot;,\r\n              &quot;imageTags&quot;: [\r\n                &quot;test&quot;,\r\n                &quot;latest&quot;\r\n              ],\r\n              &quot;registryId&quot;: &quot;98654010662132&quot;,\r\n              &quot;repositoryName&quot;: &quot;testrepository&quot;,\r\n              &quot;imagePushedAt&quot;: 1520462286\r\n            },\r\n            {\r\n              &quot;imageSizeInBytes&quot;: 2066961,\r\n              &quot;imageDigest&quot;: &quot;sha256:c30974de3423250382f5b33be01103c11de73459ceaedd789dff9b461532eb2dd55&quot;,\r\n              &quot;imageTags&quot;: [\r\n                &quot;test3&quot;\r\n              ],\r\n              &quot;registryId&quot;: &quot;98654010662132&quot;,\r\n              &quot;repositoryName&quot;: &quot;testrepository&quot;,\r\n              &quot;imagePushedAt&quot;: 1520462305\r\n            },\r\n            {\r\n              &quot;imageSizeInBytes&quot;: 2066961,\r\n              &quot;imageDigest&quot;: &quot;sha256:05048eb6cc559e953e6c98afa0e71fd836c37a34563531487af2b5d1c9430570ff9&quot;,\r\n              &quot;imageTags&quot;: [\r\n                &quot;mytest1&quot;,\r\n                &quot;mytest2&quot;,\r\n                &quot;mytest3&quot;\r\n              ],\r\n              &quot;registryId&quot;: &quot;98654010662132&quot;,\r\n              &quot;repositoryName&quot;: &quot;testrepository&quot;,\r\n              &quot;imagePushedAt&quot;: 1520459886\r\n            },\r\n            {\r\n              &quot;imageSizeInBytes&quot;: 2066961,\r\n              &quot;imageDigest&quot;: &quot;sha256:bf23ada8a14d1c70c476b4f39b9b849fd5191d8fc419312b3d1b8f59aa182b050e6&quot;,\r\n              &quot;imageTags&quot;: [\r\n                &quot;test3-latest&quot;\r\n              ],\r\n              &quot;registryId&quot;: &quot;98654010662132&quot;,\r\n              &quot;repositoryName&quot;: &quot;testrepository&quot;,\r\n              &quot;imagePushedAt&quot;: 1520462305\r\n            },\r\n            {\r\n              &quot;imageSizeInBytes&quot;: 2066961,\r\n              &quot;imageDigest&quot;: &quot;sha256:a040f335556e783930905d0b7bd9f55f1400a2778e39983c3d1e3cc41643c090ee0&quot;,\r\n              &quot;imageTags&quot;: [\r\n                &quot;test2&quot;\r\n              ],\r\n              &quot;registryId&quot;: &quot;98654010662132&quot;,\r\n              &quot;repositoryName&quot;: &quot;testrepository&quot;,\r\n              &quot;imagePushedAt&quot;: 1520462304\r\n            }\r\n          ]\r\n        }\r\n\r\n\r\nSpecifically, I&#39;d like to search for &#39;imageTags&#39; where an item in the array is &quot;mytest1&quot;. Returning output should be the dictionary block. Like this:\r\n\r\n        {\r\n          &quot;imageSizeInBytes&quot;: 2066961,\r\n          &quot;imageDigest&quot;: &quot;sha256:05048eb6cc559e953e6c98afa0e71fd836c37a34563531487af2b5d1c9430570ff9&quot;,\r\n          &quot;imageTags&quot;: [\r\n            &quot;mytest1&quot;,\r\n            &quot;mytest2&quot;,\r\n            &quot;mytest3&quot;\r\n          ],\r\n          &quot;registryId&quot;: &quot;98654010662132&quot;,\r\n          &quot;repositoryName&quot;: &quot;testrepository&quot;,\r\n          &quot;imagePushedAt&quot;: 1520459886\r\n        }\r\n\r\nAny assistance would be greatly appreciated.",
        "link": "https://stackoverflow.com/questions/49162956/jq-return-subset-of-data-based-on-matched-array-element",
        "title": "jq | return subset of data based on matched array element"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1520526531,
                "creation_date": 1520526531,
                "answer_id": 49177958,
                "question_id": 49176069,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Complement your **`jq`** pipeline with the following filter:\r\n\r\n    jq -r &#39;yourfilter | to_entries \r\n           | map(select(.key | test(&quot;^args[0-9]+&quot;)).value) | @tsv&#39; testTab.json\r\nThe output:\r\n\r\n    tail\t-f\t/dev/null\r\n\r\nThough, if you would have posted your initial `testTab.json` contents - I would help to optimize your current filter.\r\n",
                "title": "jq match a regex"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1520526531,
        "creation_date": 1520520929,
        "last_edit_date": 1520523291,
        "question_id": 49176069,
        "body_markdown": "Let&#39;s say I have a [tag:json] file, I run `cat testTab.json | jq &#39;.action.service.spec.task| select(.container) | .container&#39;` and it gives me\r\n\r\n    {\r\n      &quot;image&quot;: &quot;ubuntu:latest&quot;,\r\n      &quot;args1&quot;: &quot;tail&quot;,\r\n      &quot;args2&quot;: &quot;-f&quot;,\r\n      &quot;args3&quot;: &quot;/dev/null&quot;,\r\n      &quot;mounts&quot;: {\r\n        &quot;source&quot;: &quot;/home/testVolume&quot;,\r\n        &quot;target&quot;: &quot;/opt&quot;\r\n      },\r\n      &quot;dns_config&quot;: null\r\n    }\r\n\r\nHow should I edit this command the get all args (args1, args2 and args3) values (&quot;tail&quot; &quot;-f&quot; &quot;/dev/null&quot;)",
        "link": "https://stackoverflow.com/questions/49176069/jq-match-a-regex",
        "title": "jq match a regex"
    },
    {
        "tags": [
            "json",
            "sed",
            "edit",
            "jq",
            "iso8601"
        ],
        "answers": [
            {
                "up_vote_count": 25,
                "is_accepted": true,
                "score": 25,
                "last_activity_date": 1520542527,
                "creation_date": 1520542527,
                "answer_id": 49182262,
                "question_id": 49181898,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With **jq**&#39;s `sub()` and `fromdate()` functions:\r\n\r\n    jq &#39;.LastModified |= (sub(&quot;\\\\.000Z&quot;;&quot;Z&quot;) | fromdate)&#39; input.json\r\nThe output:\r\n\r\n    {\r\n      &quot;LastModified&quot;: 1520443473,\r\n      &quot;Key&quot;: &quot;pending/archive/f7ab1684-e94d-483e-ace1-560367c1196c_1000_s.json&quot;\r\n    }\r\n\r\n",
                "title": "jq replace part of value in json"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1520542932,
                "creation_date": 1520542932,
                "answer_id": 49182379,
                "question_id": 49181898,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If your platform supports it, you could use the date functions to parse out then reformat the date string.\r\n\r\n    .LastModified |= (sub(&quot;\\\\.000Z$&quot;; &quot;Z&quot;) | fromdateiso8601 | strftime(&quot;%Y/%m/%d %H:%M:%S&quot;))\r\n\r\nOtherwise, you could use the usual string manipulation techniques.\r\n\r\n    .LastModified |= &quot;\\(.[:10] | sub(&quot;-&quot;; &quot;/&quot;; &quot;g&quot;)) \\(.[11:19])&quot;\r\n\r\nBoth results in the results:\r\n\r\n    {\r\n      &quot;LastModified&quot;: &quot;2018/03/07 17:24:33&quot;,\r\n      &quot;Key&quot;: &quot;pending/archive/f7ab1684-e94d-483e-ace1-560367c1196c_1000_s.json&quot;\r\n    }",
                "title": "jq replace part of value in json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 16,
        "last_activity_date": 1650525504,
        "creation_date": 1520540907,
        "last_edit_date": 1650525504,
        "question_id": 49181898,
        "body_markdown": "I need to replace part of a value from a json output. I could easily do this using `sed -i` however it would also replace other parts of the file I don&#39;t want it to, unless I&#39;m missing something. The output is\r\n\r\n```\r\n{\r\n  &quot;LastModified&quot;: &quot;2018-03-07T17:24:33.000Z&quot;,\r\n  &quot;Key&quot;: &quot;pending/archive/f7ab1684-e94d-483e-ace1-560367c1196c_1000_s.json&quot;\r\n}\r\n```\r\n\r\nand I need to replace the dash &quot;-&quot; on the LastModified value to a slash, then remove some stuff too like the &quot;T&quot; and the &quot;.000Z&quot; So I can eventually convert that timestamp to epoch.\r\n\r\nI tried using \r\n`cat list |  jq -r &#39;.[] | select (.LastModified == &quot;-&quot;) .LastModified = &quot;/&quot;&#39;`\r\nand `|=` operator but I can&#39;t find anywhere else on the web that this has been accomplished. ",
        "link": "https://stackoverflow.com/questions/49181898/jq-replace-part-of-value-in-json",
        "title": "jq replace part of value in json"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "edit",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1712115127,
                "last_edit_date": 1712115127,
                "creation_date": 1520555246,
                "answer_id": 49184757,
                "question_id": 49184557,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Given a bash array, how to convert it to a JSON array \r\n\r\nAssuming your jq supports the `--args` command-line option,\r\nyou can use it in conjunction with the built-in `$ARGS` pseudo-variable, as illustrated by this example:\r\n```\r\n$ declare -a output=($&#39;abc\\ndef&#39; &quot;x y z&quot;)\r\n$ jq -c -n &#39;$ARGS.positional&#39; --args &quot;${output[@]}&quot;\r\n[&quot;abc\\ndef&quot;,&quot;x y z&quot;]\r\n```\r\nHere, all the values of the bash array are converted to JSON strings.  Notice that the embedded new-line in the first value of the bash array is correctly handled.\r\n\r\n&gt; Additionally ...\r\n\r\n(1) If all the values in newArray are valid as JSON values without spaces, then you could get away with piping the values as a stream, e.g.\r\n\r\n    newArray=(100 200 300)\r\n    echo &quot;${newArray[@]}&quot; |\r\n      jq -s &#39;{client_nohup: ., server_nohup: []}&#39;\r\n\r\n(2)\r\nNow let&#39;s suppose you merely wish to update the &quot;nohup&quot; object in a file, say nohup.json:\r\n\r\n    { &quot;client_nohup&quot;: [], &quot;server_nohup&quot;: [ &quot;keep me&quot; ] }\r\n\r\nSince you are using bash, you can then write:\r\n\r\n    echo &quot;${newArray[@]}&quot; |\r\n      jq -s --argjson nohup &quot;$(cat nohup.json)&quot; &#39;\r\n        . as $newArray | $nohup | .client_nohup = $newArray\r\n      &#39;\r\n\r\n### Output\r\n(1)\r\n\r\n    {\r\n      &quot;client_nohup&quot;: [\r\n        100,\r\n        200,\r\n        300\r\n       ],\r\n      &quot;server_nohup&quot;: []\r\n    }\r\n\r\n(2)\r\n\r\n    {\r\n      &quot;client_nohup&quot;: [\r\n        100,\r\n        200,\r\n        300\r\n      ],\r\n      &quot;server_nohup&quot;: [\r\n        &quot;keep me&quot;\r\n      ]\r\n    }\r\n\r\n### Other cases\r\n\r\nWhere there&#39;s a will, there&#39;s a jq way :-)\r\n\r\nSee for example the accepted answer at https://stackoverflow.com/questions/26808855/how-to-format-a-bash-array-as-a-json-array (though this is not a completely generic solution).\r\n\r\n\r\n\r\n## Further thoughts\r\nYou might wish to convert numeric strings to JSON numbers, e.g. using the jq idiom: `(tonumber? // .)`.\r\n\r\nYou might also wish to exploit the fact that bash strings cannot contain NUL characters.\r\n\r\n\r\n",
                "title": "Convert bash array to json array and insert to file using jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1520606411,
                "last_edit_date": 1520606411,
                "creation_date": 1520605397,
                "answer_id": 49195839,
                "question_id": 49184557,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In general, the only truly safe way to do this is with multiple invocations of `jq`, adding each element to the output of the previous command. \r\n\r\n   \r\n    arr=&#39;[]&#39;  # Empty JSON array\r\n    for x in &quot;${newArray[@]}&quot;; do\r\n      arr=$(jq -n --arg x &quot;$x&quot; --argjson arr &quot;$arr&quot; &#39;$arr + [$x]&#39;)\r\n    done\r\n\r\nThis ensures that each element `x` of your `bash` array is properly encoded prior to adding it to the JSON array.\r\n\r\nThis is complicated, though, by the fact that `bash` doesn&#39;t not distinguish between numbers and strings. This encodes your array as `[&quot;100&quot;, &quot;200&quot;, &quot;300&quot;]`, not `[100, 200, 300]`. In the end, you need to have some awareness of what your array contains, and preprocess it accordingly.\r\n",
                "title": "Convert bash array to json array and insert to file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 12,
        "last_activity_date": 1712115127,
        "creation_date": 1520553786,
        "last_edit_date": 1558679022,
        "question_id": 49184557,
        "body_markdown": "Given a bash array, how to convert it to a JSON array in order to output to a file with jq?\r\n\r\nAdditionnally: is there a way to keep the server_nohup array unchanged instead of re-writing the whole json file each time?\r\n\r\n\tnewArray=(100 200 300)\r\n\tjq -n --arg newArray $newArray &#39;{\r\n\t\tclient_nohup: [ \r\n\t\t\t$newArray\r\n\t\t],\r\n\t\tserver_nohup: [\r\n\r\n\t\t]\r\n\t}&#39; &gt; $projectDir/.watch.json\r\n\r\nCurrent output:\r\n\r\n\t{\r\n\t&quot;client_nohup&quot;: [\r\n\t\t&quot;100&quot;\r\n\t],\r\n\t&quot;server_nohup&quot;: []\r\n\t}\r\n\r\nDesired output:\r\n\r\n\t{\r\n\t&quot;client_nohup&quot;: [\r\n\t\t100,\r\n\t\t200,\r\n\t\t300\r\n\t],\r\n\t&quot;server_nohup&quot;: []\r\n\t}\r\n\r\n",
        "link": "https://stackoverflow.com/questions/49184557/convert-bash-array-to-json-array-and-insert-to-file-using-jq",
        "title": "Convert bash array to json array and insert to file using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "csv",
            "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": 1520592407,
                "post_id": 49191968,
                "comment_id": 85388885,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1520603499,
                "last_edit_date": 1520603499,
                "creation_date": 1520603109,
                "answer_id": 49195174,
                "question_id": 49191968,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The trick is to extract .UserName as a variable before iterating over the inner array:\r\n\r\n    .UserDetailList[] \r\n    | .UserName as $u\r\n    | .AttachedManagedPolicies[]\r\n    | [$u, .PolicyName]\r\n    | @csv\r\n\r\nOf course this assumes valid JSON input.",
                "title": "Convert/Export JSON to CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1520676458,
        "creation_date": 1520592275,
        "last_edit_date": 1520676458,
        "question_id": 49191968,
        "body_markdown": "JSON file:\r\n\r\n    &quot;UserDetailList&quot;: [\r\n            {\r\n                &quot;UserName&quot;: &quot;citrix-xendesktop-ec2-provisioning&quot;, \r\n                &quot;GroupList&quot;: [], \r\n                &quot;CreateDate&quot;: &quot;2017-11-07T14:20:14Z&quot;, \r\n                &quot;UserId&quot;: &quot;1234556&quot;, \r\n                &quot;Path&quot;: &quot;/&quot;, \r\n                &quot;AttachedManagedPolicies&quot;: [\r\n                    {\r\n                        &quot;PolicyName&quot;: &quot;AmazonEC2FullAccess&quot;, \r\n                        &quot;PolicyArn&quot;: &quot;arn:aws:iam::aws:policy/AmazonEC2FullAccess&quot;\r\n                    }, \r\n                    {\r\n                        &quot;PolicyName&quot;: &quot;AmazonS3FullAccess&quot;, \r\n                        &quot;PolicyArn&quot;: &quot;arn:aws:iam::aws:policy/AmazonS3FullAccess&quot;\r\n                    }\r\n                ], \r\n                &quot;Arn&quot;: &quot;arn:aws:iam::1234567890:user/citrix-xendesktop-ec2-provisioning&quot;\r\n            }, \r\n            {\r\n                &quot;UserName&quot;: &quot;rundeck-read-only-iam-permissions&quot;, \r\n                &quot;GroupList&quot;: [], \r\n                &quot;CreateDate&quot;: &quot;2018-03-09T11:13:38Z&quot;, \r\n                &quot;UserId&quot;: &quot;AIDAJQOQGKISLCWDXG6EQ&quot;, \r\n                &quot;Path&quot;: &quot;/&quot;, \r\n                &quot;AttachedManagedPolicies&quot;: [\r\n                    {\r\n                        &quot;PolicyName&quot;: &quot;IAMReadOnlyAccess&quot;, \r\n                        &quot;PolicyArn&quot;: &quot;arn:aws:iam::aws:policy/IAMReadOnlyAccess&quot;\r\n                    }\r\n                ], \r\n                &quot;Arn&quot;: &quot;arn:aws:iam::279052847476:user/rundeck-read-only-iam-permissions&quot;\r\n            }\r\n        ]\r\n\r\n\r\nwith \r\n\r\n    jq -r &#39;.UserDetailList[] | [.UserName] | @csv&#39; output.json &gt; fileout2.csv\r\n\r\nI can get\r\n\r\n    citrix-xendesktop-ec2-provisioning&quot;\r\n    &quot;rundeck-read-only-iam-permissions&quot;\r\n\r\nHow to get IAM policies for these 2 users, i need to extract AmazonEC2FullAccess and AmazonS3FullAccess under AttachedManagedPolicies ?\r\n\r\nso output can be\r\n\r\n    citrix-xendesktop-ec2-provisioning&quot;,AmazonEC2FullAccess\r\n    citrix-xendesktop-ec2-provisioning&quot;,AmazonS3FullAccess\r\n    rundeck-read-only-iam-permissions,IAMReadOnlyAccess\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/49191968/convert-export-json-to-csv",
        "title": "Convert/Export JSON to CSV"
    }
]