[
  {
    "context": [
      "Now, I want to make \"my test\" two separate words. My desired output is \r\n\r\n    {\r\n      \"my - test\": {\r\n        \"path\": \"success\"\r\n      }\r\n    }",
      "the jq filter you need is:\r\n\r\n    .[\"my test\"].path = \"success\"",
      "(If ever in doubt about using the `.foo` syntax, you can always fall back on the fundamental form: `.[\"key name\"]`.)"
    ],
    "utterance": "Set the value at the top-level key 'my test', then nested key 'path', to 'success' on an empty object",
    "expressions": [
      ".[\"my test\"].path = \"success\""
    ],
    "data": [
      {
        "input": {},
        "output": {
          "my test": {
            "path": "success"
          }
        }
      }
    ],
    "identifier": 48536924
  },
  {
    "context": [
      "I want all the values from this json, a, b, and c",
      "`jq` solution for valid JSON structure:",
      "... | jq '[.a, .b, (.c | fromjson | .[])]'",
      "The output:",
      "[",
      "  \"foo\",",
      "  \"bar\",",
      "  \"world\"",
      "]"
    ],
    "utterance": "Extract the values of fields a and b, and also extract all values from the object stored as a string in field c, returning a flat array.",
    "expressions": [
      "[.a, .b, (.c | fromjson | .[])]"
    ],
    "data": [
      {
        "input": {
          "a": "foo",
          "b": "bar",
          "c": "{\"hello\": \"world\"}"
        },
        "output": [
          "foo",
          "bar",
          "world"
        ]
      }
    ],
    "identifier": 48526634
  },
  {
    "context": [
      "I'm trying to isolate how, via jq, I can convert that back YYYY-MM-DD but am really not finding it.",
      "dateFound\t\"Sun, 12 Nov 2017 00:00:00 GMT\"",
      "For example:\n\n     sub(\" [A-Z]+$\";\"\")\n     | strptime(\"%a, %d %b %Y %T\")\n     | mktime\n     | strftime(\"%Y-%m-%d\")"
    ],
    "utterance": "Extract the dateFound field formatted as 'Day, DD Mon YYYY 00:00:00 GMT' and output only the 'YYYY-MM-DD' date.",
    "expressions": [
      ".dateFound | sub(\" [A-Z]+$\";\"\") | strptime(\"%a, %d %b %Y %T\") | mktime | strftime(\"%Y-%m-%d\")"
    ],
    "data": [
      {
        "input": {
          "dateFound": "Sun, 12 Nov 2017 00:00:00 GMT"
        },
        "output": "2017-11-12"
      }
    ],
    "identifier": 48566431
  },
  {
    "context": [
      "I want to return ids that the last created date is > 2 days from current date",
      "def older(days):\n  (now - (strptime(\"%d.%m.%Y %T\") | mktime)) #  seconds \n  >  (days*24*3600);",
      "\"30.1.2018 17:11:56\"\n| older(2)\nemits `true`."
    ],
    "utterance": "Return the ids where the created date is more than 2 days older than the current time.",
    "expressions": [
      "def older(days): (now - (strptime(\"%d.%m.%Y %T\") | mktime)) > (days*24*3600); .[] | select(.created | older(2)) | .id"
    ],
    "data": [
      {
        "input": [
          {
            "id": "b8895839-52d3-40e1-8c86-20463f38fec4",
            "created": "23.08.2016 17:11:56"
          },
          {
            "id": "294374c0-0fb9-4ab6-853c-e0a11fde4906",
            "created": "26.08.2016 11:22:38"
          }
        ]
      }
    ],
    "identifier": 48583928
  },
  {
    "context": [
      "test.json",
      "{\n \"url\": \"https://<part1>.test/hai/<part1>\"\n}",
      "if .url == \"<part1>\"\n then . + {\"url\" : (\"https://\" + $input + \".test/hai/\" + $input)  }\n else . end",
      ".url | contains(\"<part1>\")",
      ".url | test(\"//<part1>.*<part1>$\")",
      "Another possibility would be to use `gsub`."
    ],
    "utterance": "Replace all occurrences of <part1> in the url string value with a supplied variable value when the string contains <part1>.",
    "expressions": [
      "jq --arg input \"$arg\" 'if .url | contains(\"<part1>\") then . + {\"url\": (.url | gsub(\"<part1>\", $input))} else . end' test.json",
      "jq --arg input \"$arg\" 'if .url | test(\"<part1>\") then . + {\"url\": (.url | gsub(\"<part1>\", $input))} else . end' test.json"
    ],
    "data": [
      {
        "input": {
          "url": "https://<part1>.test/hai/<part1>"
        },
        "output": {
          "url": "https://foo.test/hai/foo"
        }
      }
    ],
    "identifier": 48557351
  },
  {
    "context": [
      "I try to rename the values in an array. However, only parts of them, keeping the other parts.",
      "JSON input:\n\n    {\n      \"values\": [\n        \"foo:bar1\",\n        \"foo:bar2\",\n        \"foo:bar3\"\n      ]\n    }",
      "desired output:\n\n    {\n      \"values\": [\n        \"bar1\",\n        \"bar2\",\n        \"bar3\"\n      ]\n    }",
      "Assuming your jq has regex support (e.g. jq 1.5):\n\n    .values |= map(sub(\"foo:\";\"\")))"
    ],
    "utterance": "Remove the 'foo:' prefix from each element in the 'values' array, preserving the rest of each string.",
    "expressions": [
      ".values |= map(sub(\"foo:\";\"\"))",
      ".values |= map(sub(\"^foo:\";\"\"))"
    ],
    "data": [
      {
        "input": {
          "values": [
            "foo:bar1",
            "foo:bar2",
            "foo:bar3"
          ]
        },
        "output": {
          "values": [
            "bar1",
            "bar2",
            "bar3"
          ]
        }
      }
    ],
    "identifier": 48600234
  },
  {
    "context": [
      "I 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.",
      "The return value should be the whole json object with the array missing the 1.0.0.2.",
      "Use `|=` to modify the piece in-place but return the larger document.",
      "if jq '.Statement[0].Condition.IpAddress[\"aws:SourceIp\"] |= .[0:-1]' \\",
      "jq '.Statement[0].Condition.IpAddress[\"aws:SourceIp\"] |= .[:-1]' test.json | sponge test.json"
    ],
    "utterance": "Remove the last element from the aws:SourceIp array inside Statement[0].Condition.IpAddress and return the whole object with this change.",
    "expressions": [
      ".Statement[0].Condition.IpAddress[\"aws:SourceIp\"] |= .[0:-1]",
      ".Statement[0].Condition.IpAddress[\"aws:SourceIp\"] |= .[:-1]"
    ],
    "data": [
      {
        "input": {
          "Version": "2012-**-**",
          "Statement": [
            {
              "Effect": "**",
              "Principal": "**",
              "Action": "**",
              "Resource": "***",
              "Condition": {
                "IpAddress": {
                  "aws:SourceIp": [
                    "127.0.0.1",
                    "1.0.0.2"
                  ]
                }
              }
            }
          ]
        },
        "output": {
          "Version": "2012-**-**",
          "Statement": [
            {
              "Effect": "**",
              "Principal": "**",
              "Action": "**",
              "Resource": "***",
              "Condition": {
                "IpAddress": {
                  "aws:SourceIp": [
                    "127.0.0.1"
                  ]
                }
              }
            }
          ]
        }
      }
    ],
    "identifier": 48588056
  },
  {
    "context": [
      "However, 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:",
      "\"Thriller\",\"Michael Jackson\",\"Wanna Be Startin' Somethin'\",363400",
      "Is it possible to do this using the @csv filter?",
      "jq -r '\n  .name as $album_name           ### <- THIS RIGHT HERE\n  | .tracks.items[]\n  | [$album_name, .artists[].name, .name, .duration_ms]\n  | @csv\n' myfile.json"
    ],
    "utterance": "Extract album name, each song's artist, song's title, and song's duration for every item in tracks and output each as a CSV row including the album name.",
    "expressions": [
      ".name as $album_name | .tracks.items[] | [$album_name, .artists[].name, .name, .duration_ms] | @csv"
    ],
    "data": [
      {
        "input": {
          "name": "Thriller",
          "tracks": {
            "items": [
              {
                "artists": [
                  {
                    "name": "Michael Jackson"
                  }
                ],
                "duration_ms": 363400,
                "name": "Wanna Be Startin' Somethin'"
              },
              {
                "artists": [
                  {
                    "name": "Michael Jackson"
                  }
                ],
                "duration_ms": 260666,
                "name": "Baby Be Mine"
              }
            ]
          }
        },
        "output": [
          "\"Thriller\",\"Michael Jackson\",\"Wanna Be Startin' Somethin'\",363400",
          "\"Thriller\",\"Michael Jackson\",\"Baby Be Mine\",260666"
        ]
      }
    ],
    "identifier": 48611465
  },
  {
    "context": [
      "How to combine two jq conditions using 'and'.",
      "jq --arg input1 \"$arg1\" --arg input2 \"$arg2\" \\\n   'if .url | contains(\"<part1>\")\n     then . + {\"url\" : (\"https://\" + $input1 + \".test/hai/\" + $input1)  }\n       else . end'    and \n    'if .ParameterValue == \"<value>\"\n                         then . + {\"ParameterValue\" : ($input2) }\n                  else . end'   test.json  > test123.json",
      "`and` is a boolean (logical) operator.  What you want here is to create a pipeline using '|':",
      "jq --arg input1 \"$arg1\" --arg input2 \"$arg2\" '\n   if .url | contains(\"<part1>\")\n   then . + {url : (\"https://\" + $input1 + \".test/hai/\" + $input1)  }\n   else . end\n   | if .ParameterValue == \"<value>\"\n     then . + {ParameterValue : $input2 }\n     else . end' test.json  > test123.json",
      "Or maybe better:\n\ndef when(filter; action): if (filter?) // null then action else . end;\nwhen(.url | contains(\"<part1>\");\n      .url = (\"https://\" + $input1 + \".test/hai/\" + $input1))\n| when(.ParameterValue == \"<value>\";\n      .ParameterValue = $input2)"
    ],
    "utterance": "Update the 'url' field if it contains '<part1>' and update the 'ParameterValue' field if it equals '<value>', using supplied input values.",
    "expressions": [
      "jq --arg input1 \"$arg1\" --arg input2 \"$arg2\" '\n  if .url | contains(\"<part1>\")\n  then . + {url : (\"https://\" + $input1 + \".test/hai/\" + $input1) }\n  else . end\n  | if .ParameterValue == \"<value>\"\n    then . + {ParameterValue : $input2 }\n    else . end' test.json > test123.json",
      "def when(filter; action): if (filter?) // null then action else . end;\nwhen(.url | contains(\"<part1>\");\n      .url = (\"https://\" + $input1 + \".test/hai/\" + $input1))\n| when(.ParameterValue == \"<value>\";\n      .ParameterValue = $input2)"
    ],
    "data": [
      {
        "input": {
          "url": "https://<part1>.test/hai/<part1>",
          "ParameterValue": "<value>"
        }
      }
    ],
    "identifier": 48586980
  },
  {
    "context": [
      "My specific issue is I have a JSON object (below) and I want to be able to add/remove the \u201cmaxHeight\u201d key/value from the JSON object.",
      "Using jq-1.6, this deletes the key .maxHeight from the input (it doesn't even complain if it didn't exist before):",
      "jq 'del(.maxHeight)' new.json",
      "The following illustrates the global approach:\n\n    walk(if type == \"object\" and has(\"maxHeight\") then del(.maxHeight) else . end)"
    ],
    "utterance": "Remove the top-level key 'maxHeight' from an object.",
    "expressions": [
      "del(.maxHeight)",
      "walk(if type == \"object\" and has(\"maxHeight\") then del(.maxHeight) else . end)"
    ],
    "data": [
      {
        "input": {
          "style": {
            "className": "feature",
            "showLabels": false,
            "color": "function(feature, variableName, glyphObject, track){if(feature.get(\"type\") === \"CDS\"){return \"#9CFBF5\";} else if(feature.get(\"type\") === \"exon\"){return \"#43A47F\";} else if(feature.get(\"type\") === \"intron\"){return \"#E8E8E8\";} else if(feature.get(\"type\") === \"five_prime_UTR\"){return \"#F192FE\";} else if(feature.get(\"type\") === \"three_prime_UTR\"){return \"#FEC892\";} else {return \"#FF0000\";}}",
            "arrowheadClass": null,
            "featureCss": "padding:3px;"
          },
          "menuTemplate": [
            {
              "label": "View details"
            },
            {
              "label": "Highlight a gene"
            },
            {
              "iconClass": "dijitIconBookmark",
              "content": "function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( feature[2] ) }",
              "action": "contentDialog",
              "title": "(feature{name})",
              "label": "Create Note"
            }
          ],
          "hooks": {
            "modify": " function(track,feature,div){   var checkArr=[\"Reference\",\"Missing\",\"Heterozygous\",\"NonReference\"];for(var i=0;i<feature.length;i++){for(var j=0;j<checkArr.length;j++){  if( i>3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\"NonReference\"){div.style.backgroundColor=\"red\";}else if(feature[i]==\"Reference\"){div.style.backgroundColor=\"green\";}else if(feature[i]==\"Heterozygous\"){div.style.backgroundColor=\"orange\";}else if(feature[i]==\"Missing\"){div.style.backgroundColor=\"grey\";} }}}}} "
          },
          "key": "cucumber_ChineseLong_v2.gff3",
          "storeClass": "JBrowse/Store/SeqFeature/NCList",
          "trackType": null,
          "maxHeight": "200px",
          "urlTemplate": "tracks/cucumber_ChineseLong_v2.gff3/{refseq}/trackData.json",
          "compress": 0,
          "label": "cucumber_ChineseLong_v2.gff3",
          "type": "JBrowse/View/Track/CanvasFeatures"
        },
        "output": {
          "style": {
            "className": "feature",
            "showLabels": false,
            "color": "function(feature, variableName, glyphObject, track){if(feature.get(\"type\") === \"CDS\"){return \"#9CFBF5\";} else if(feature.get(\"type\") === \"exon\"){return \"#43A47F\";} else if(feature.get(\"type\") === \"intron\"){return \"#E8E8E8\";} else if(feature.get(\"type\") === \"five_prime_UTR\"){return \"#F192FE\";} else if(feature.get(\"type\") === \"three_prime_UTR\"){return \"#FEC892\";} else {return \"#FF0000\";}}",
            "arrowheadClass": null,
            "featureCss": "padding:3px;"
          },
          "menuTemplate": [
            {
              "label": "View details"
            },
            {
              "label": "Highlight a gene"
            },
            {
              "iconClass": "dijitIconBookmark",
              "content": "function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( feature[2] ) }",
              "action": "contentDialog",
              "title": "(feature{name})",
              "label": "Create Note"
            }
          ],
          "hooks": {
            "modify": " function(track,feature,div){   var checkArr=[\"Reference\",\"Missing\",\"Heterozygous\",\"NonReference\"];for(var i=0;i<feature.length;i++){for(var j=0;j<checkArr.length;j++){  if( i>3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\"NonReference\"){div.style.backgroundColor=\"red\";}else if(feature[i]==\"Reference\"){div.style.backgroundColor=\"green\";}else if(feature[i]==\"Heterozygous\"){div.style.backgroundColor=\"orange\";}else if(feature[i]==\"Missing\"){div.style.backgroundColor=\"grey\";} }}}}} "
          },
          "key": "cucumber_ChineseLong_v2.gff3",
          "storeClass": "JBrowse/Store/SeqFeature/NCList",
          "trackType": null,
          "urlTemplate": "tracks/cucumber_ChineseLong_v2.gff3/{refseq}/trackData.json",
          "compress": 0,
          "label": "cucumber_ChineseLong_v2.gff3",
          "type": "JBrowse/View/Track/CanvasFeatures"
        }
      }
    ],
    "identifier": 48529016
  },
  {
    "context": [
      "Can someone let me know how to check whether sent or error exists.",
      "You were close.",
      "jq '. | select(.error or .sent)'",
      "Even shorter (no need for additional pipes):",
      "jq '.sent or .error'"
    ],
    "utterance": "Check if either the key 'sent' or the key 'error' exists at the top level of the object.",
    "expressions": [
      ". | select(.error or .sent)",
      ".sent or .error"
    ],
    "data": [
      {
        "input": {
          "name": "appId (xxxxx-xxx-1234)",
          "sent": 7939246,
          "received": 6673490,
          "details": [
            {
              "timestamp": "20180201000041",
              "sentbytes": 1805,
              "receivedbytes": 1485
            }
          ]
        }
      },
      {
        "input": {
          "error": "Not found"
        }
      }
    ],
    "identifier": 48647315
  },
  {
    "context": [
      "Here\u0019s an all-jq solution:  \r\n\r\n    .[] | .[0:12] | @tsv | gsub(\"\\t\";\",\") | \"(\\(.))\"\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(\u001c,\u001c)` instead of the @tsv|gsub portion of the pipeline. You might, for example, want to consider:\r\n\r\n    .[] | join(\u001c,\u001c) | \u001c(\\(.))\u001c.   # 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)"
    ],
    "utterance": "Format each subarray of length 12 as a parenthesized, comma-separated tuple.",
    "expressions": [
      ".[] | .[0:12] | @tsv | gsub(\"\\t\";\",\") | \"(\\(.))\"",
      ".[] | join(\",\") | \"(\\(.))\""
    ],
    "data": [
      {
        "input": [
          [
            1517773500000,
            0.102501,
            0.102757,
            0.102435,
            0.102566,
            257.267,
            1517773799999,
            26.3891222,
            1229,
            104.322,
            10.7057991,
            0
          ],
          [
            1517773800000,
            0.102566,
            0.10268,
            0.102316,
            0.102434,
            310.646,
            1517774099999,
            31.83806883,
            1452,
            129.705,
            13.29758266,
            0
          ],
          [
            1517774100000,
            0.102434,
            0.102575,
            0.102118,
            0.1023,
            359.063,
            1517774399999,
            36.73708621,
            1296,
            154.785,
            15.8404191,
            0
          ]
        ],
        "output": [
          "(1517773500000,0.10250100,0.10275700,0.10243500,0.10256600,257.26700000,1517773799999,26.38912220,1229,104.32200000,10.70579910,0)",
          "(1517773800000,0.10256600,0.10268000,0.10231600,0.10243400,310.64600000,1517774099999,31.83806883,1452,129.70500000,13.29758266,0)",
          "(1517774100000,0.10243400,0.10257500,0.10211800,0.10230000,359.06300000,1517774399999,36.73708621,1296,154.78500000,15.84041910,0)"
        ]
      }
    ],
    "identifier": 48612588
  },
  {
    "context": [
      "Here is the current JSON output:\r\n\r\n    [\r\n     {\"colour\":\"Red\", \"car\": [ {\"year\":2000, \"make\":\"Honda\", \"model\":\"Accord\"} ] },\r\n     {\"colour\":\"Blue\", \"car\": [ {\"year\":2015, \"make\":\"Toyota\", \"model\":\"Camry\"} ] },\r\n     {\"colour\":\"Red\", \"car\": [ {\"year\":1999, \"make\":\"Dodge\", \"model\":\"Ram\"} ] }\r\n    ]",
      "I would like to format this into a new JSON object that looks like this:\r\n \r\n    [\r\n     { \"Red\":[2000,1999] },\r\n     { \"Blue\": 2015 }\r\n    ]",
      "$ jq -c 'group_by(.colour) | map({(.[0].colour): map(.car[].year)})' input.json\r\n    [{\"Blue\":[2015]},{\"Red\":[2000,1999]}]",
      "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} ]"
    ],
    "utterance": "Group entries by colour and produce an array of objects where each key is a colour and its value is the list of years for that colour, using just the year values; use a number and not an array for colours with only one year.",
    "expressions": [
      "group_by(.colour) | map({(.[0].colour): map(.car[].year)})",
      "reduce .[] as $car ({};\n  .[ $car.colour ] += ($car.car | map(.year)) )\n| map_values(if length==1 then .[0] else . end)\n| [ to_entries[] | {(.key): .value} ]"
    ],
    "data": [
      {
        "input": [
          {
            "colour": "Red",
            "car": [
              {
                "year": 2000,
                "make": "Honda",
                "model": "Accord"
              }
            ]
          },
          {
            "colour": "Blue",
            "car": [
              {
                "year": 2015,
                "make": "Toyota",
                "model": "Camry"
              }
            ]
          },
          {
            "colour": "Red",
            "car": [
              {
                "year": 1999,
                "make": "Dodge",
                "model": "Ram"
              }
            ]
          }
        ],
        "output": [
          {
            "Red": [
              2000,
              1999
            ]
          },
          {
            "Blue": 2015
          }
        ]
      }
    ],
    "identifier": 48614477
  },
  {
    "context": [
      "A better example what I'm looking for is this:",
      "echo '[{\"first\": \"John\", \"last\": \"Big\"}, {\"first\": \"Justin\", \"last\": \"Frozen\"}]' | jq -c '.[] | {first, last, id: (.first + .last | md5) }'",
      "to output:",
      "{\"first\":\"John\",\"last\":\"Big\",\"id\":\"cda5c2dd89a0ab28a598a6b22e5b88ce\"}",
      "{\"first\":\"Justin\",\"last\":\"Frozen\",\"id\":\"af97f1bd8468e013c432208c32272668\"}",
      "I need to generate a unique key for each record.",
      "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:",
      "jq -c .[] \"$jsonfile\" | while read -r jsonline ; do\n  id=\"$(jq -s -j -r '.[] | .first + .last' <<<\"$jsonline\" | md5sum | cut -d ' ' -f1)\"\n  jq --arg id \"$id\" -s -c '.[] | .id = \"\\($id)\"' <<<\"$jsonline\"\ndone",
      "Here is an efficient solution to the restated problem. There are altogether just two calls to jq, no matter the length of the array:",
      "echo \"$json\" |\njq -c '.[] | [.[]] | add' |\nwhile read -r line ; do echo \"$line\" | md5 ; done |\njq -s -R --argjson json \"$json\" 'split(\"\\n\")\n  | map(select(length>0))\n  | . as $in\n  | reduce range(0;length) as $i ($json; .[$i].id = $in[$i])'",
      "It 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 \u2018.[]\u2019"
    ],
    "utterance": "Add an id field to each object in an array, where the id is the md5 hash of the concatenation of the first and last fields.",
    "expressions": [
      "jq -c '.[] | {first, last, id: (.first + .last | md5) }'",
      "jq -c .[] \"$jsonfile\" | while read -r jsonline ; do id=\"$(jq -s -j -r '.[] | .first + .last' <<<\"$jsonline\" | md5sum | cut -d ' ' -f1)\"; jq --arg id \"$id\" -s -c '.[] | .id = \"\\($id)\"' <<<\"$jsonline\"; done"
    ],
    "data": [
      {
        "input": [
          {
            "first": "John",
            "last": "Big"
          },
          {
            "first": "Justin",
            "last": "Frozen"
          }
        ],
        "output": [
          {
            "first": "John",
            "last": "Big",
            "id": "cda5c2dd89a0ab28a598a6b22e5b88ce"
          },
          {
            "first": "Justin",
            "last": "Frozen",
            "id": "af97f1bd8468e013c432208c32272668"
          }
        ]
      }
    ],
    "identifier": 48548580
  },
  {
    "context": [
      "Input json:",
      "[ { \"Authors\": \"Author1, Author2, Author3\", \"Affiliation\": \"Here, There, Everywhere\" }, { \"Authors\": \"Author4, Author5\", \"Affiliation\": \"Nirvana, Utopia\" } ]",
      "Desired output:",
      "{ \"authors\": [ { \"Name\": \"Author1\", \"Affiliation\": \"Here\" }, { \"Name\": \"Author2\", \"Affiliation\": \"There\" }, { \"Name\": \"Author3\", \"Affiliation\": \"Everywhere\" } ] }, { \"authors\": [ { \"Name\": \"Author4\", \"Affiliation\": \"Nirvana\" }, { \"Name\": \"Author5\", \"Affiliation\": \"Utopia\" } ] }",
      "I can read the first elements of both arrays with:",
      "jq '.[] as $o | $o.Authors | split(\", \") as $authors | $o.Affiliation | split(\", \") as $affiliation | { \"Authors\": [ { \"Name\": $authors[.0], \"Affiliation\": $affiliation[.0]} ] }'",
      "but I'm struggling to understand how to get jq to iterate over the entire (arbitrary length) string to produce the full desired output.",
      "jq '[.[] | [(.Authors | split(\", \")), (.Affiliation | split(\", \"))] | transpose | { authors: map({ Name:.[0], Affiliation:.[1] }) }]'"
    ],
    "utterance": "For each object containing comma-separated 'Authors' and 'Affiliation' strings, produce an array of objects where each author's name is paired with its corresponding affiliation.",
    "expressions": [
      "[.[] | [(.Authors | split(\", \")), (.Affiliation | split(\", \"))] | transpose | { authors: map({ Name:.[0], Affiliation:.[1] }) }]"
    ],
    "data": [
      {
        "input": [
          {
            "Authors": "Author1, Author2, Author3",
            "Affiliation": "Here, There, Everywhere"
          },
          {
            "Authors": "Author4, Author5",
            "Affiliation": "Nirvana, Utopia"
          }
        ],
        "output": [
          {
            "authors": [
              {
                "Name": "Author1",
                "Affiliation": "Here"
              },
              {
                "Name": "Author2",
                "Affiliation": "There"
              },
              {
                "Name": "Author3",
                "Affiliation": "Everywhere"
              }
            ]
          },
          {
            "authors": [
              {
                "Name": "Author4",
                "Affiliation": "Nirvana"
              },
              {
                "Name": "Author5",
                "Affiliation": "Utopia"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 48650452
  },
  {
    "context": [
      "I get a list of all the installed `npm` packages in the following format:",
      "`$package;$version;js;$resolved`",
      "How can I get the key name value that I am iterating over in `.dependencies` that contains that package name.",
      "How can I recurse through ALL dependency objects?",
      "jq -r '.. | .dependencies? | objects\n    | to_entries[] | [.key, .value.version, \"js\", .value.resolved] | join(\";\")' input.json",
      "produces the results:",
      "npm;5.5.1;js;",
      "yaml-table;1.1.3;js;https://registry.npmjs.org/yaml-table/-/yaml-table-1.1.3.tgz",
      "JSONStream;1.3.1;js;https://registry.npmjs.org/JSONStream/-/JSONStream-1.3.1.tgz",
      "jsonparse;1.3.1;js;https://registry.npmjs.org/jsonparse/-/jsonparse-1.3.1.tgz",
      "through;2.3.8;js;https://registry.npmjs.org/through/-/through-2.3.8.tgz",
      "js-yaml;3.4.6;js;https://registry.npmjs.org/js-yaml/-/js-yaml-3.4.6.tgz",
      "argparse;1.0.9;js;https://registry.npmjs.org/argparse/-/argparse-1.0.9.tgz"
    ],
    "utterance": "Produce a list of installed npm package names, versions, the string 'js', and their resolved URLs if present, from all levels of the dependency tree, formatted as name;version;js;resolved.",
    "expressions": [
      ".. | .dependencies? | objects | to_entries[] | [.key, .value.version, \"js\", .value.resolved] | join(\";\")"
    ],
    "data": [
      {
        "input": {
          "dependencies": {
            "npm": {
              "version": "5.5.1",
              "dependencies": {
                "JSONStream": {
                  "version": "1.3.1",
                  "from": "JSONStream@~1.3.1",
                  "resolved": "https://registry.npmjs.org/JSONStream/-/JSONStream-1.3.1.tgz",
                  "dependencies": {
                    "jsonparse": {
                      "version": "1.3.1",
                      "from": "jsonparse@^1.2.0",
                      "resolved": "https://registry.npmjs.org/jsonparse/-/jsonparse-1.3.1.tgz"
                    },
                    "through": {
                      "version": "2.3.8",
                      "from": "through@>=2.2.7 <3",
                      "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz"
                    }
                  }
                }
              }
            },
            "yaml-table": {
              "version": "1.1.3",
              "from": "yaml-table@latest",
              "resolved": "https://registry.npmjs.org/yaml-table/-/yaml-table-1.1.3.tgz",
              "dependencies": {
                "js-yaml": {
                  "version": "3.4.6",
                  "from": "js-yaml@3.4.6",
                  "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.4.6.tgz",
                  "dependencies": {
                    "argparse": {
                      "version": "1.0.9",
                      "from": "argparse@>=1.0.2 <2.0.0",
                      "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.9.tgz"
                    }
                  }
                }
              }
            }
          }
        },
        "output": [
          "npm;5.5.1;js;",
          "yaml-table;1.1.3;js;https://registry.npmjs.org/yaml-table/-/yaml-table-1.1.3.tgz",
          "JSONStream;1.3.1;js;https://registry.npmjs.org/JSONStream/-/JSONStream-1.3.1.tgz",
          "jsonparse;1.3.1;js;https://registry.npmjs.org/jsonparse/-/jsonparse-1.3.1.tgz",
          "through;2.3.8;js;https://registry.npmjs.org/through/-/through-2.3.8.tgz",
          "js-yaml;3.4.6;js;https://registry.npmjs.org/js-yaml/-/js-yaml-3.4.6.tgz",
          "argparse;1.0.9;js;https://registry.npmjs.org/argparse/-/argparse-1.0.9.tgz"
        ]
      }
    ],
    "identifier": 48629417
  },
  {
    "context": [
      "[ {\"one\": 1}, {\"two\": 2}]",
      "and wish to convert it to this format:",
      "{\"one\": 1}",
      "{\"two\": 2}",
      "cat test_array.json |jq '.[]'",
      "jq -c '.[]' test_array.json"
    ],
    "utterance": "Output each object in the top-level array on its own line in the same format as the objects in the array.",
    "expressions": [
      ".[]"
    ],
    "data": [
      {
        "input": [
          {
            "one": 1
          },
          {
            "two": 2
          }
        ],
        "output": [
          {
            "one": 1
          },
          {
            "two": 2
          }
        ]
      }
    ],
    "identifier": 48711199
  },
  {
    "context": [
      "How can i break jq string into lines, this is for long lines, when i put \\ query breaks.",
      "`jq` is fine with literal line breaks, so just add linefeeds anywhere without trying to escape them:",
      "jq -r --arg vpcId \"someId\" '\n   .[][] \n     | select(.VpcId == $vpcId)\n     | .[\"State\"]'  << 'EOF'"
    ],
    "utterance": "Select the State of an object whose VpcId matches a variable, writing the filter over multiple lines.",
    "expressions": [
      ".[][] | select(.VpcId == $vpcId) | .[\"State\"]"
    ],
    "data": [
      {
        "input": {
          "Vpcs": [
            {
              "VpcId": "someId",
              "InstanceTenancy": "default",
              "State": "available",
              "IsDefault": false
            }
          ]
        },
        "output": "available"
      }
    ],
    "identifier": 48712545
  },
  {
    "context": [
      "**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)\nMy end results would look like this:**",
      "jq '.endpoints |= map((.virtual_endpoint | sub(\"https?://[^/]+\"; \"\")) as $end_p \n                          | .vs_endpoints |= [.[] + $end_p] )' main.json"
    ],
    "utterance": "Append the path from the virtual_endpoint field to each value in vs_endpoints for each object in the endpoints array.",
    "expressions": [
      ".endpoints |= map((.virtual_endpoint | sub(\"https?://[^/]+\"; \"\")) as $end_p | .vs_endpoints |= [.[] + $end_p])"
    ],
    "data": [
      {
        "input": {
          "endpoints": [
            {
              "org": "Alison Sandbox",
              "physical_endpoint": "https://dev.service-now.com/ESD_Assets.do?SOAP",
              "physical_service": "ServiceNowService_v1_0",
              "virtual_endpoint": "https://sandbox-dv.soa.com:443/ServiceNow/ESD_ServiceNowSvc_v1_0_vs0",
              "virtual_service": "ServiceNowService_v1_0_vs0",
              "vs_endpoints": [
                "https://sandbox-ci.soa.com",
                "https://sandbox-dv101.soa.com",
                "https://sandbox-dv102.soa.com"
              ]
            }
          ]
        },
        "output": {
          "endpoints": [
            {
              "org": "Alison Sandbox",
              "physical_endpoint": "https://dev.service-now.com/ESD_Assets.do?SOAP",
              "physical_service": "ServiceNowService_v1_0",
              "virtual_endpoint": "https://sandbox-dv.soa.com:443/ServiceNow/ESD_ServiceNowSvc_v1_0_vs0",
              "virtual_service": "ServiceNowService_v1_0_vs0",
              "vs_endpoints": [
                "https://sandbox-ci.soa.com/ServiceNow/ESD_ServiceNowSvc_v1_0_vs0",
                "https://sandbox-dv101.soa.com/ServiceNow/ESD_ServiceNowSvc_v1_0_vs0",
                "https://sandbox-dv102.soa.com/ServiceNow/ESD_ServiceNowSvc_v1_0_vs0"
              ]
            }
          ]
        }
      }
    ],
    "identifier": 48648058
  },
  {
    "context": [
      "How would I use `jq` to create an empty object named after \"test1\" in a new file?",
      "Now you can do it like this:    ",
      "jq '{(.config.name):{}}' config.name",
      "Output:\n\n    {\n      \"test1\": {}\n    }"
    ],
    "utterance": "Create an empty object with a property whose key is the value of the 'config.name' property and whose value is an empty object.",
    "expressions": [
      "{(.config.name):{}}"
    ],
    "data": [
      {
        "input": {
          "config": {
            "name": "test1"
          }
        },
        "output": {
          "test1": {}
        }
      }
    ],
    "identifier": 48745410
  },
  {
    "context": [
      "The context is this: \n\n    aws logs get-log-events --log-group-name \"$logGroup\" --log-stream-name \"$logStreamName\" --limit \"$logSize\" |\n     jq '{message:.nextForwardToken}, .events[] | .message'",
      "I need to put in a variable this:\n\n    f/33854369274157730709515363051725446974398055862891970561\n\nand display (or put in an other variable) the messages:",
      "I've added `-r` flag to `jq` print output without quotes\n\n    jq -r '{message:.nextForwardToken}, .events[] | .message'",
      "nextForwardToken=$(jq -r '.nextForwardToken' /tmp/log_data)",
      "jq -r '.events[].message' /tmp/log_data",
      "x=$(aws ... |\n     jq -r '.nextForwardToken, (.events[] | .message)' |\n     tee >(tail -n +2 >&2) |\n     head -n 1) 2>&1"
    ],
    "utterance": "Extract the value of nextForwardToken and the list of message fields from all entries in events.",
    "expressions": [
      ".nextForwardToken",
      ".events[].message",
      ".nextForwardToken, (.events[] | .message)",
      "-r '.nextForwardToken'",
      "-r '.events[].message'",
      "-r '.nextForwardToken, (.events[] | .message)'"
    ],
    "data": [
      {
        "input": {
          "events": [
            {
              "timestamp": 1518081460955,
              "ingestionTime": 1518081462998,
              "message": "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}]"
            },
            {
              "timestamp": 1518081461095,
              "ingestionTime": 1518081462998,
              "message": "08.02.2018 09:17:41.095 [SimpleAsyncTaskExecutor-138] INFO  o.s.batch.core.job.SimpleStepHandler - Executing step: [index salesprices]"
            },
            {
              "timestamp": 1518082421586,
              "ingestionTime": 1518082423001,
              "message": "08.02.2018 09:33:41.586 [upriceUpdateTaskExecutor-3] DEBUG e.u.d.a.j.d.b.StoredMasterDataReader - Reading page 1621"
            }
          ],
          "nextBackwardToken": "b/33854347851370569899844322814554152895248902123886870536",
          "nextForwardToken": "f/33854369274157730709515363051725446974398055862891970561"
        },
        "output": [
          "f/33854369274157730709515363051725446974398055862891970561",
          "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}]",
          "08.02.2018 09:17:41.095 [SimpleAsyncTaskExecutor-138] INFO  o.s.batch.core.job.SimpleStepHandler - Executing step: [index salesprices]",
          "08.02.2018 09:33:41.586 [upriceUpdateTaskExecutor-3] DEBUG e.u.d.a.j.d.b.StoredMasterDataReader - Reading page 1621"
        ]
      }
    ],
    "identifier": 48682276
  },
  {
    "context": [
      "I would like to use the `profitability24` field.",
      "I am having a lot of problems figuring out how to grab the most profitable currency",
      "And you want to extract the max of 'profitability24, I would just filter out the dictionaries into a list, and then pipe that to `max_by`",
      "`cat test.json | jq '[.coins[]]|max_by(.profitability24)'`",
      "If you want to ensure you always select one of the maximal objects, you could write:",
      "[.coins[]] | max_by(.profitability24)"
    ],
    "utterance": "Extract the coin object with the maximum profitability24 value from the coins dictionary.",
    "expressions": [
      "[.coins[]] | max_by(.profitability24)"
    ],
    "data": [
      {
        "input": {
          "coins": {
            "coin1": {
              "id": 4,
              "profitability24": 3
            },
            "coin2": {
              "id": 5,
              "profitability24": 2
            },
            "coin3": {
              "id": 6,
              "profitability24": 1
            }
          }
        },
        "output": {
          "id": 4,
          "profitability24": 3
        }
      }
    ],
    "identifier": 48736632
  },
  {
    "context": [
      "I want to filter out all items which happened during the weekend.",
      "jq '.[]|select(.date|fromdateiso8601|strftime(\"%w\") as $d|$d==\"7\" or $d==\"0\")' file.json",
      "7 stands for Saturday, 0 for Sunday."
    ],
    "utterance": "Filter objects where the date field occurs on a Saturday or Sunday.",
    "expressions": [
      ".[] | select(.date | fromdateiso8601 | strftime(\"%w\") as $d | $d == \"7\" or $d == \"0\")"
    ],
    "data": [
      {
        "input": [
          {
            "name": "foo",
            "date": "2018-02-11T12:00:00Z"
          },
          {
            "name": "bar",
            "date": "2018-02-12T12:00:00Z"
          }
        ],
        "output": [
          {
            "name": "foo",
            "date": "2018-02-11T12:00:00Z"
          }
        ]
      }
    ],
    "identifier": 48753701
  },
  {
    "context": [
      "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).",
      "The object to be appended in both cases is literally the entire contents of the file, with the file's \"id\" field as the object's key.",
      "I'm taking a large list of input files (all with the same syntax) and essentially combining them like that.",
      "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:",
      "**program.jq**: `map({(.id):(.)}) | add`",
      "Invocation:",
      "jq -s -f program.jq input_01.json input_02.json",
      "desired output:",
      "    {",
      "      \"input1_id\": {",
      "        \"id\": \"input1_id\",",
      "        \"val\": \"testVal1\"",
      "      },",
      "      \"input2_id\": {",
      "        \"id\": \"input2_id\",",
      "        \"val\": \"testVal2\"",
      "      }",
      "    }"
    ],
    "utterance": "Combine multiple input files mapping each object's id field as a key to the entire object, resulting in a single object with ids as keys and corresponding object values.",
    "expressions": [
      "map({(.id):(.)}) | add",
      "jq -s 'map({(.id):(.)}) | add' input_01.json input_02.json"
    ],
    "data": [
      {
        "input": [
          {
            "id": "input1_id",
            "val": "testVal1"
          },
          {
            "id": "input2_id",
            "val": "testVal2"
          }
        ],
        "output": {
          "input1_id": {
            "id": "input1_id",
            "val": "testVal1"
          },
          "input2_id": {
            "id": "input2_id",
            "val": "testVal2"
          }
        }
      }
    ],
    "identifier": 48747820
  },
  {
    "context": [
      "I need to add also value of TargetNode:",
      "GROUPID:3       ID:1    NAME:profile1    TARGETNODE:system1",
      "USERID:7        ID:2    NAME:profile2    TARGETNODE:system2",
      "is there a way to include it in \n[{userId, groupId, id, name, TargetNode}] \nto get the value of TargetNode and not null?",
      "it is cousing that RomanPerekhrest's jq filter returns too much...\nhow to rid of them too?",
      "jq -r '.attributes |= map(select(.name == \"TargetNode\")) \n       | if (.attributes | length != 0) then .targetNode = .attributes[0].value else . end \n       | if (.userId == \"0\") then del(.userId) else . end \n       | if (.groupId == \"0\") then del(.groupId) else . end \n       | del(.attributes, .xconns) | to_entries \n       | map(\"\\(.key | ascii_upcase):\\(.value)\") | @tsv' file.json",
      "If an object with \"name\": \"TargetNode\" pair not exists - TARGETNODE won't be added into resulting structure",
      "The output:",
      "ID:1\tNAME:profile1\tGROUPID:3\tTARGETNODE:system1",
      "ID:2\tNAME:profile2\tUSERID:7\tTARGETNODE:system2"
    ],
    "utterance": "Extract objects with specific keys, removing userId when it is 0, removing groupId when it is 0, excluding other attributes, and adding TARGETNODE with the value from attributes where name is TargetNode.",
    "expressions": [
      ".attributes |= map(select(.name == \"TargetNode\")) | if (.attributes | length != 0) then .targetNode = .attributes[0].value else . end | if (.userId == \"0\") then del(.userId) else . end | if (.groupId == \"0\") then del(.groupId) else . end | del(.attributes, .xconns) | to_entries | map(\"\\(.key | ascii_upcase):\\(.value)\") | @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "id": "1",
            "name": "profile1",
            "userId": "0",
            "groupId": "3",
            "attrib101": "A",
            "attrib102": "B",
            "attributes": [
              {
                "id": "104",
                "name": "Enable",
                "value": "1"
              },
              {
                "id": "105",
                "name": "TargetNode",
                "value": "system1"
              },
              {
                "id": "106",
                "name": "Timeout",
                "value": "30"
              }
            ],
            "xconns": []
          },
          {
            "id": "2",
            "name": "profile2",
            "userId": "7",
            "groupId": "0",
            "attrib101": "C",
            "attrib102": "D",
            "attributes": [
              {
                "id": "104",
                "name": "Enable",
                "value": "1"
              },
              {
                "id": "105",
                "name": "TargetNode",
                "value": "system2"
              },
              {
                "id": "106",
                "name": "Timeout",
                "value": "30"
              }
            ],
            "xconns": []
          }
        ],
        "output": "ID:1\tNAME:profile1\tGROUPID:3\tATTRIB101:A\tATTRIB102:B\tTARGETNODE:system1\nID:2\tNAME:profile2\tUSERID:7\tATTRIB101:C\tATTRIB102:D\tTARGETNODE:system2"
      }
    ],
    "identifier": 48666137
  },
  {
    "context": [
      "I want to make it tsv with jq, but jq says:",
      "jq: error (at <stdin>:1): object ({\"products_...) cannot be tsv-formatted, only array",
      "the full command I'm passing is :",
      "jq  '@tsv' file.json",
      "It would be:",
      "jq -r 'to_entries|map(.value)|@tsv' file.json",
      "If you just want the values (without headers):",
      "[.[]] | @tsv",
      "If you want the headers as well:",
      "(keys_unsorted, [.[]]) | @tsv"
    ],
    "utterance": "Output all values from the top-level object as a single TSV line, optionally including headers.",
    "expressions": [
      "[.[]] | @tsv",
      "to_entries | map(.value) | @tsv",
      "(keys_unsorted, [.[]]) | @tsv"
    ],
    "data": [
      {
        "input": {
          "base_price_mw": 249.99,
          "best_offer_base_price": 280.06,
          "best_offer_nature": 11,
          "best_offer_promo_price": 247.35,
          "best_offer_shiping_price": 0,
          "best_shop_id": 2004,
          "best_shop_name": "Stuff",
          "cat_id": 69,
          "grey_dot": true,
          "is_exclusivity": null,
          "is_favorite": false,
          "is_new": false,
          "is_topsales": false,
          "manufacturer_id": 58,
          "name": "my product name",
          "nature_mw": 11,
          "note": "0.0000",
          "offers_count": 11,
          "offers_min_price": 233.21,
          "products_ids": 30671,
          "promo_price_mw": 249.99,
          "status": 1
        }
      }
    ],
    "identifier": 48764829
  },
  {
    "context": [
      "I am able to get the values for transactionType or transactionsubtype or even ItemID values etc as given below",
      "jq '.data.transactionType'    ",
      "jq '.data.Items[0].itemID' ",
      "for Transaction type and item id",
      "but when it comes to values of numeric types i.e., without the quotes in it, I don't get any value.",
      "I am using similar syntax for the numeric type also as shown below.",
      "jq '.data.Items[0].amount'",
      "jq '.data.Items[0].tax'",
      "Your jq invocations are fine, but the sample data is missing a final closing brace (\"}\")"
    ],
    "utterance": "Extract the numeric value of the 'amount' field from the first element of the 'Items' array inside 'data'.",
    "expressions": [
      ".data.Items[0].amount"
    ],
    "data": [
      {
        "input": {
          "data": {
            "transactionType": "Sales",
            "transactionSubType": "DomesticSale",
            "Items": [
              {
                "itemID": "2",
                "itemType": "Good",
                "amount": 5.0,
                "tax": 1.0
              }
            ]
          }
        },
        "output": 5.0
      }
    ],
    "identifier": 48767090
  },
  {
    "context": [
      "I 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:\n\n    {\n      \"files\": [\n        {\n          \"aql\": {\n            \"items.find\": {\n              \"repo\": \"release-repo\",\n              \"modified\": { \"$before\": \"30d\" },\n              \"type\": { \"$eq\": \"folder\" },\n              \"$or\": [\n                {\n                  \"$and\": [\n                    {\n                      \"name\": {\n                        \"$nmatch\": \"*a991fef6bb9e9759d513fd4b277fe3674b44e4f4*\"\n                      }\n                    }\n                  ]\n                },\n                {\n                  \"$and\": [\n                    {\n                      \"name\": {\n                        \"$nmatch\": \"*5a562d34bb1d4ab4264acc2c61327651218524ad*\"\n                      }\n                    }\n                  ]\n                },\n                {\n                  \"$and\": [\n                    {\n                      \"name\": {\n                        \"$nmatch\": \"*d4e296c35644743e58aed35d1afb87e34d6c8823*\"\n                      }\n                    }\n                  ]\n                }\n              ],\n              \"depth\": \"2\"\n            }\n          }\n        }\n      ]\n    }",
      "jq -n \\\n        --argjson template \"$template\" \\\n        --arg shas_str \"${shas[*]}\" \\\n'  reduce ($shas_str | split(\" \") | .[]) as $sha ($template;\n  .files[0].aql[\"items.find\"][\"$or\"] += [{\n    \"$and\": [{\"name\": {\"$nmatch\": (\"*\" + $sha + \"*\")}}]\n  }]\n) '",
      "map( {\"$and\": [ {name: { \"$nmatch\": \"*\\(.)*\" }}]} ) as $x\n| $spec[0] | (.files[0].aql.\"items.find\".\"$or\" = $x)"
    ],
    "utterance": "Populate the \"$or\" array in the spec file with objects for each provided commit SHA so that each contains an \"$and\" array with a \"name\" object whose \"$nmatch\" value is the SHA surrounded by asterisks.",
    "expressions": [
      "reduce ($shas_str | split(\" \") | .[]) as $sha ($template; .files[0].aql[\"items.find\"][\"$or\"] += [{ \"$and\": [{\"name\": {\"$nmatch\": (\"*\" + $sha + \"*\")}}] }])",
      "map({ \"$and\": [ {name: { \"$nmatch\": \"*\\(.)*\" }}] }) as $x | $spec[0] | (.files[0].aql.\"items.find\".\"$or\" = $x)"
    ],
    "data": [
      {
        "input": {
          "files": [
            {
              "aql": {
                "items.find": {
                  "repo": "release-repo",
                  "modified": {
                    "$before": "30d"
                  },
                  "type": {
                    "$eq": "folder"
                  },
                  "depth": "2"
                }
              }
            }
          ]
        },
        "output": {
          "files": [
            {
              "aql": {
                "items.find": {
                  "repo": "release-repo",
                  "modified": {
                    "$before": "30d"
                  },
                  "type": {
                    "$eq": "folder"
                  },
                  "$or": [
                    {
                      "$and": [
                        {
                          "name": {
                            "$nmatch": "*a991fef6bb9e9759d513fd4b277fe3674b44e4f4*"
                          }
                        }
                      ]
                    },
                    {
                      "$and": [
                        {
                          "name": {
                            "$nmatch": "*5a562d34bb1d4ab4264acc2c61327651218524ad*"
                          }
                        }
                      ]
                    },
                    {
                      "$and": [
                        {
                          "name": {
                            "$nmatch": "*d4e296c35644743e58aed35d1afb87e34d6c8823*"
                          }
                        }
                      ]
                    }
                  ],
                  "depth": "2"
                }
              }
            }
          ]
        }
      }
    ],
    "identifier": 48690913
  },
  {
    "context": [
      "from 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.",
      "The expected output is like this:",
      "jq --slurpfile patterns file_2.json \\\n    '($patterns[0] | map({(.pattern): .url}) | add) as $patterns \n     | .[0] | [ map((.physical_endpoint | match(\"^http://[^/]+/\").string) as $url \n                     | if ($patterns | has($url)) then .available_urls = $patterns[$url]\n                       else . end) ]' file_1.json"
    ],
    "utterance": "For each object, if physical_endpoint starts with a pattern found as pattern in the reference data, add a new property available_urls with the url array from that pattern.",
    "expressions": [
      "jq --slurpfile patterns file_2.json '($patterns[0] | map({(.pattern): .url}) | add) as $patterns | .[0] | [ map((.physical_endpoint | match(\"^http://[^/]+/\").string) as $url | if ($patterns | has($url)) then .available_urls = $patterns[$url] else . end) ]' file_1.json"
    ],
    "data": [
      {
        "input": [
          [
            {
              "org": "Architecture Frameworks",
              "physical_endpoint": "http://localhostdayofweek/DayOfWeek",
              "physical_service": "DayOfWeekServiceMT1001",
              "virtual_endpoint": "https://sandbox-laird-dv.crawl.com:443/testpromotion/DayOfWeekServiceMT1001_vs0",
              "virtual_service": "DayOfWeekServiceMT1001_vs0"
            },
            {
              "org": "Architecture Frameworks",
              "physical_endpoint": "http://localhostdayofweek/DayOfWeek/updated",
              "physical_service": "DayOfWeekServiceMT1002",
              "virtual_endpoint": "https://sandbox-laird-dv.crawl.com:443/UPDATE/DayOfWeekServiceMT1002_vs0_2",
              "virtual_service": "DayOfWeekServiceMT1002_vs0"
            }
          ]
        ],
        "output": [
          [
            {
              "org": "Architecture Frameworks",
              "physical_endpoint": "http://localhostdayofweek/DayOfWeek",
              "physical_service": "DayOfWeekServiceMT1001",
              "virtual_endpoint": "https://sandbox-laird-dv.crawl.com:443/testpromotion/DayOfWeekServiceMT1001_vs0",
              "virtual_service": "DayOfWeekServiceMT1001_vs0",
              "available_urls": [
                "http://cm-billingsvc2-west-pt01.crawl.com/",
                "http://policymanager-pt.crawl.com:30000/",
                "http://rmosr-resourcelifecyclemgmt-ps101.crawl.com/"
              ]
            },
            {
              "org": "Architecture Frameworks",
              "physical_endpoint": "http://localhostdayofweek/DayOfWeek/updated",
              "physical_service": "DayOfWeekServiceMT1002",
              "virtual_endpoint": "https://sandbox-laird-dv.crawl.com:443/UPDATE/DayOfWeekServiceMT1002_vs0_2",
              "virtual_service": "DayOfWeekServiceMT1002_vs0",
              "available_urls": [
                "http://cm-billingsvc2-west-pt01.crawl.com/",
                "http://policymanager-pt.crawl.com:30000/",
                "http://rmosr-resourcelifecyclemgmt-ps101.crawl.com/"
              ]
            }
          ]
        ]
      }
    ],
    "identifier": 48755543
  },
  {
    "context": [
      "I want to be able to add an optional key & value pair to my new object, based on whether the response contains a key with a certain value.",
      "All droplets have a public IP, but the private IP is optional.",
      "However, once I add in the private IP, any droplet that doesn't have one goes missing from the response:",
      "`jq '.droplets | map({id: .id, name: .name, status: .status, public_ip: .networks.v4[] | select(.type==\"public\") | .ip_address, private_ip: .networks.v4[] | select(.type==\"private\") | .ip_address})'`",
      "I think I need to use concatenation or conditionals some how, but I can't quite figure out the syntax.",
      "You don\u2019t 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.",
      ".droplets | map({id, name, status, public_ip: (first(.networks.v4[] | select(.type==\"public\"))  // {}) | .ip_address, private_ip: (first(.networks.v4[] | select(.type==\"private\")) // {}) | .ip_address } )",
      "def one(condition): first(.[] | select(condition)) // null;\n.droplets | map({id, name, status} + (.networks.v4 | { public_ip: one(.type==\"public\") | .ip_address} + (one(.type==\"private\") | if . then {private_ip: .ip_address} else null end ) ))"
    ],
    "utterance": "Transform a list of droplets to objects with id, name, status, public_ip, and include private_ip only if a private IP exists.",
    "expressions": [
      ".droplets | map({id, name, status, public_ip: (first(.networks.v4[] | select(.type==\"public\"))  // {}) | .ip_address, private_ip: (first(.networks.v4[] | select(.type==\"private\")) // {}) | .ip_address })",
      "def one(condition): first(.[] | select(condition)) // null; .droplets | map({id, name, status} + (.networks.v4 | { public_ip: one(.type==\"public\") | .ip_address} + (one(.type==\"private\") | if . then {private_ip: .ip_address} else null end ) ))"
    ],
    "data": [
      {
        "input": {
          "droplets": [
            {
              "id": 12345678,
              "name": "my-droplet",
              "status": "active",
              "networks": {
                "v4": [
                  {
                    "ip_address": "123.456.78.90",
                    "netmask": "255.255.240.0",
                    "gateway": "123.123.0.1",
                    "type": "public"
                  },
                  {
                    "ip_address": "10.123.45.67",
                    "netmask": "255.255.0.0",
                    "gateway": "10.123.0.1",
                    "type": "private"
                  }
                ],
                "v6": []
              }
            },
            {
              "id": 87654321,
              "name": "another-droplet",
              "status": "off",
              "networks": {
                "v4": [
                  {
                    "ip_address": "98.76.54.32",
                    "netmask": "255.255.240.0",
                    "gateway": "98.76.0.1",
                    "type": "public"
                  }
                ],
                "v6": []
              }
            }
          ]
        },
        "output": [
          {
            "id": 12345678,
            "name": "my-droplet",
            "status": "active",
            "public_ip": "123.456.78.90",
            "private_ip": "10.123.45.67"
          },
          {
            "id": 87654321,
            "name": "another-droplet",
            "status": "off",
            "public_ip": "98.76.54.32"
          }
        ]
      }
    ],
    "identifier": 48762994
  },
  {
    "context": [
      "I\u2019d like to pick even odd entries in metrics array and put them together into a single object as key value pairs like this:\n\n{ \n   \"solr.core.shard1\": \"QUERY./select\",\n   \"solr.core.shard2\": \"QUERY./update\",\n   ...\n}",
      "jq '[ .metrics as $m | range(0; $m | length; 2) \n      | {($m[.]): $m[(. + 1)]} ] | add' jsonfile",
      ".metrics\n| [pairwise(.[]) | {(.[0]): .[1]}]\n| add"
    ],
    "utterance": "Combine each pair of consecutive entries in the 'metrics' array, using the first as the key and the second as the value, to form a single object of key-value pairs.",
    "expressions": [
      "[ .metrics as $m | range(0; $m | length; 2) | {($m[.]): $m[(. + 1)]} ] | add",
      ".metrics | [pairwise(.[]) | {(.[0]): .[1]}] | add"
    ],
    "data": [
      {
        "input": {
          "responseHeader": {
            "status": 0,
            "QTime": 7962
          },
          "metrics": [
            "solr.core.shard1",
            "QUERY./select",
            "solr.core.shard2",
            "QUERY./update"
          ]
        },
        "output": {
          "solr.core.shard1": "QUERY./select",
          "solr.core.shard2": "QUERY./update"
        }
      }
    ],
    "identifier": 48792105
  },
  {
    "context": [
      "Hi want to get the id and the master cat id so I'm doing this",
      "cat test2.json | jq -c '.hits.hits[]|{products_ids: ._id, cat_id: ._source.category.master_category.id}'",
      "But unfortunately I get an error :",
      "jq: error (at <stdin>:48): Cannot index array with string \"id\"",
      "for the second hit, there's no .source.category.master_category.id",
      "One possibility is to use the `?` suffix operator, e.g.",
      ".hits.hits[]\n| { products_ids: ._id,\n    cat_id: ._source.category.master_category.id? }",
      "or if you want to be more inclusive:",
      ".hits.hits[]\n| { products_ids: ._id,\n    cat_id: (._source.category.master_category.id? // null ) }"
    ],
    "utterance": "Extract _id and master_category.id for each hit, handling cases where master_category.id may not exist.",
    "expressions": [
      ".hits.hits[] | { products_ids: ._id, cat_id: ._source.category.master_category.id? }",
      ".hits.hits[] | { products_ids: ._id, cat_id: (._source.category.master_category.id? // null) }"
    ],
    "data": [
      {
        "input": {
          "_shards": {
            "failed": 0
          },
          "hits": {
            "hits": [
              {
                "_id": "P16296",
                "_source": {
                  "category": {
                    "all_categories": [
                      {
                        "id": 76,
                        "name": "Souris"
                      }
                    ],
                    "master_category": {
                      "id": 76,
                      "name": "Souris"
                    }
                  }
                }
              },
              {
                "_id": "P749525",
                "_source": {
                  "category": {
                    "all_categories": [
                      {
                        "id": 1301,
                        "name": "Produits abim\u000e9s"
                      }
                    ],
                    "master_category": []
                  }
                }
              }
            ]
          }
        },
        "output": [
          {
            "products_ids": "P16296",
            "cat_id": 76
          },
          {
            "products_ids": "P749525",
            "cat_id": null
          }
        ]
      }
    ],
    "identifier": 48792711
  },
  {
    "context": [
      "The 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.",
      "Restrict consideration to .search_result_data.shop.id:",
      ".hits.hits[]._source\n| (.search_result_data.shop.id) as $shop\n| (.offers_data | map(select(.shop_id == $shop)) | min_by(.base_price)) as $min_offers_data\n| .search_result_data\n| {products_ids: .identifiers.id}\n  + ($min_offers_data\n     | {best_shop_id: .shop_id,\n        best_shop_name: .shop_name,\n        best_offer_base_price: .base_price})\n",
      "{\n  \"products_ids\": 32116,\n  \"best_shop_id\": 2247,\n  \"best_shop_name\": \"MainShop\",\n  \"best_offer_base_price\": 223\n}"
    ],
    "utterance": "Return a single record per product where, among offers with shop_id equal to the search_result_data.shop.id, base_price is minimal.",
    "expressions": [
      ".hits.hits[]._source\n| (.search_result_data.shop.id) as $shop\n| (.offers_data | map(select(.shop_id == $shop)) | min_by(.base_price)) as $min_offers_data\n| .search_result_data\n| {products_ids: .identifiers.id}\n  + ($min_offers_data\n     | {best_shop_id: .shop_id,\n        best_shop_name: .shop_name,\n        best_offer_base_price: .base_price})"
    ],
    "data": [
      {
        "input": {
          "hits": {
            "hits": [
              {
                "_source": {
                  "offers_data": [
                    {
                      "base_price": 198.89,
                      "shop_id": 2002,
                      "shop_name": "TheOtherShop"
                    },
                    {
                      "base_price": 223,
                      "shop_id": 2247,
                      "shop_name": "MainShop"
                    },
                    {
                      "base_price": 225,
                      "shop_id": 2247,
                      "shop_name": "MainShop"
                    }
                  ],
                  "search_result_data": {
                    "identifiers": {
                      "id": 32116
                    },
                    "shop": {
                      "id": 2247,
                      "name": "MainShop"
                    }
                  }
                }
              }
            ]
          }
        },
        "output": {
          "products_ids": 32116,
          "best_shop_id": 2247,
          "best_shop_name": "MainShop",
          "best_offer_base_price": 223
        }
      }
    ],
    "identifier": 48804655
  },
  {
    "context": [
      "Is there a way to make assignations without losing data? So that the result is like this:\n\n    {\n      \"things\": [\n        {\n            \"name\": \"lkj\",\n            \"something\": [\n                \"changed\"\n            ],\n            \"more_data\": \"important\",\n            \"other_stuff\": \"very important\"\n        },\n        {\n            \"name\": \"iou\",\n            \"something\": [\n                \"changed\"\n            ],\n            \"different_more_data\": \"very important too\",\n            \"more_different_data\": [\n                \"even more\"\n            ]\n        }\n      ]\n    }",
      "With `jq`'s **`map`** function:\n\n    jq '.things |= map(.something = [\"changed\"])' jsonfile",
      "You can simply modify your query so that it looks like:\n\n     .things[] |= (.something = [\"changed\"])"
    ],
    "utterance": "Set the value of 'something' to [\"changed\"] for each object inside 'things', preserving all other keys and values.",
    "expressions": [
      ".things |= map(.something = [\"changed\"])",
      ".things[] |= (.something = [\"changed\"])"
    ],
    "data": [
      {
        "input": {
          "things": [
            {
              "name": "lkj",
              "something": [
                "hike"
              ],
              "more_data": "important",
              "other_stuff": "very important"
            },
            {
              "name": "iou",
              "different_more_data": "very important too",
              "more_different_data": [
                "even more"
              ]
            }
          ]
        },
        "output": {
          "things": [
            {
              "name": "lkj",
              "something": [
                "changed"
              ],
              "more_data": "important",
              "other_stuff": "very important"
            },
            {
              "name": "iou",
              "different_more_data": "very important too",
              "more_different_data": [
                "even more"
              ],
              "something": [
                "changed"
              ]
            }
          ]
        }
      }
    ],
    "identifier": 48806071
  },
  {
    "context": [
      "I need help in filtering the issues created only since last week.",
      "Using jq:",
      "def older(days):\n  (now - (strptime(\"%Y-%m-%dT%T\") | mktime)) #  seconds \n  >  (days*24*3600);\n\n.[]\n| (.created_at | sub(\"Z.*\";\"\")) as $date \n| select($date | older(7) | not)\n| [.number, .user.login, .state, .created_at]\n| @tsv"
    ],
    "utterance": "Select GitHub issues where the created_at date is within the past 7 days.",
    "expressions": [
      "def older(days):\n  (now - (strptime(\"%Y-%m-%dT%T\") | mktime)) > (days*24*3600);\n\n.[]\n| (.created_at | sub(\"Z.*\";\"\")) as $date\n| select($date | older(7) | not)\n| [.number, .user.login, .state, .created_at]\n| @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "url": "https://api.github.com/repos/stedolan/jq/issues/1558",
            "repository_url": "https://api.github.com/repos/stedolan/jq",
            "labels_url": "https://api.github.com/repos/stedolan/jq/issues/1558/labels{/name}",
            "comments_url": "https://api.github.com/repos/stedolan/jq/issues/1558/comments",
            "events_url": "https://api.github.com/repos/stedolan/jq/issues/1558/events",
            "html_url": "https://github.com/stedolan/jq/pull/1558",
            "id": 282346710,
            "number": 1558,
            "title": "Fix a try-catch example",
            "user": {
              "login": "zogwarg",
              "id": 6682272,
              "avatar_url": "https://avatars3.githubusercontent.com/u/6682272?v=4",
              "gravatar_id": "",
              "url": "https://api.github.com/users/zogwarg",
              "html_url": "https://github.com/zogwarg",
              "followers_url": "https://api.github.com/users/zogwarg/followers",
              "following_url": "https://api.github.com/users/zogwarg/following{/other_user}",
              "gists_url": "https://api.github.com/users/zogwarg/gists{/gist_id}",
              "starred_url": "https://api.github.com/users/zogwarg/starred{/owner}{/repo}",
              "subscriptions_url": "https://api.github.com/users/zogwarg/subscriptions",
              "organizations_url": "https://api.github.com/users/zogwarg/orgs",
              "repos_url": "https://api.github.com/users/zogwarg/repos",
              "events_url": "https://api.github.com/users/zogwarg/events{/privacy}",
              "received_events_url": "https://api.github.com/users/zogwarg/received_events",
              "type": "User",
              "site_admin": false
            },
            "labels": [],
            "state": "open",
            "locked": false,
            "assignee": null,
            "assignees": [],
            "milestone": null,
            "comments": 0,
            "created_at": "2017-12-15T07:56:31Z",
            "updated_at": "2017-12-15T07:56:31Z",
            "closed_at": null,
            "author_association": "NONE",
            "pull_request": {
              "url": "https://api.github.com/repos/stedolan/jq/pulls/1558",
              "html_url": "https://github.com/stedolan/jq/pull/1558",
              "diff_url": "https://github.com/stedolan/jq/pull/1558.diff",
              "patch_url": "https://github.com/stedolan/jq/pull/1558.patch"
            },
            "body": "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."
          },
          {
            "url": "https://api.github.com/repos/stedolan/jq/issues/1557",
            "repository_url": "https://api.github.com/repos/stedolan/jq",
            "labels_url": "https://api.github.com/repos/stedolan/jq/issues/1557/labels{/name}",
            "comments_url": "https://api.github.com/repos/stedolan/jq/issues/1557/comments",
            "events_url": "https://api.github.com/repos/stedolan/jq/issues/1557/events",
            "html_url": "https://github.com/stedolan/jq/issues/1557",
            "id": 282289185,
            "number": 1557,
            "title": "Compiling for tvOS",
            "user": {
              "login": "larryaasen",
              "id": 325973,
              "avatar_url": "https://avatars1.githubusercontent.com/u/325973?v=4",
              "gravatar_id": "",
              "url": "https://api.github.com/users/larryaasen",
              "html_url": "https://github.com/larryaasen",
              "followers_url": "https://api.github.com/users/larryaasen/followers",
              "following_url": "https://api.github.com/users/larryaasen/following{/other_user}",
              "gists_url": "https://api.github.com/users/larryaasen/gists{/gist_id}",
              "starred_url": "https://api.github.com/users/larryaasen/starred{/owner}{/repo}",
              "subscriptions_url": "https://api.github.com/users/larryaasen/subscriptions",
              "organizations_url": "https://api.github.com/users/larryaasen/orgs",
              "repos_url": "https://api.github.com/users/larryaasen/repos",
              "events_url": "https://api.github.com/users/larryaasen/events{/privacy}",
              "received_events_url": "https://api.github.com/users/larryaasen/received_events",
              "type": "User",
              "site_admin": false
            },
            "labels": [],
            "state": "open",
            "locked": false,
            "assignee": null,
            "assignees": [],
            "milestone": null,
            "comments": 0,
            "created_at": "2017-12-15T01:05:47Z",
            "updated_at": "2017-12-15T01:05:47Z",
            "closed_at": null,
            "author_association": "CONTRIBUTOR",
            "body": "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"
          }
        ]
      }
    ],
    "identifier": 48659631
  },
  {
    "context": [
      "._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",
      "so I wrote this  ._source.offers_data[]|select(.shop_id ==  ._source.search_result_data.shop.id).shop_name",
      "jq '.hits.hits[]._source | .search_result_data.shop.id as $shop_id \n    | .offers_data[] | select(.shop_id == $shop_id).shop_name' jsonfile",
      "The output:\n\n    \"Stuff\""
    ],
    "utterance": "For each item, get the shop_name from offers_data where shop_id matches the shop.id in search_result_data",
    "expressions": [
      ".hits.hits[]._source | .search_result_data.shop.id as $shop_id | .offers_data[] | select(.shop_id == $shop_id).shop_name"
    ],
    "data": [
      {
        "input": {
          "_shards": {
            "failed": 0,
            "successful": 2,
            "total": 2
          },
          "hits": {
            "hits": [
              {
                "_id": "P3ssss",
                "_index": "truc",
                "_score": 0.0057305535,
                "_source": {
                  "category": {
                    "all_categories": [
                      {
                        "id": 69,
                        "name": "my stuff",
                        "url": "/fr/soms/"
                      }
                    ],
                    "master_category": {
                      "id": 69,
                      "name": "my stuff",
                      "url": "/soms/"
                    },
                    "master_path": "28-63-69",
                    "master_universe": {
                      "id": 28,
                      "name": "ffffff",
                      "url": "/soms/"
                    },
                    "paths": [
                      "28-63-69"
                    ]
                  },
                  "number_filters": {
                    "available_quantity": 3,
                    "status": 1
                  },
                  "offers_data": [
                    {
                      "availability_date": "2018-02-14",
                      "base_price": 280.06,
                      "nature": 11,
                      "offer_id": 2628,
                      "promo_price": 247.35,
                      "quantity": 3,
                      "shipping_price": 0,
                      "shop_grade": 3,
                      "shop_id": 2004,
                      "shop_name": "Stuff",
                      "shop_url": "/some/Stuff"
                    },
                    {
                      "availability_date": "2018-02-14",
                      "base_price": 270.61,
                      "nature": 11,
                      "offer_id": 4998,
                      "promo_price": 270.61,
                      "quantity": 12,
                      "shipping_price": 0,
                      "shop_grade": 3,
                      "shop_id": 2003,
                      "shop_name": "Truc",
                      "shop_url": "/some/truc"
                    }
                  ],
                  "search_result_data": {
                    "base_price": 280.06,
                    "brand": {
                      "id": 58,
                      "logo": "/so.jpg",
                      "name": "truc",
                      "url": "/TTTT"
                    },
                    "flags": {
                      "is_exclusivity": null,
                      "is_favorite": false,
                      "is_new": false,
                      "is_topsales": false
                    },
                    "grey_dot": true,
                    "identifiers": {
                      "erp": "ZORGLUB",
                      "id": 455565
                    },
                    "image": "/images/",
                    "name": "Isomething",
                    "nature": 11,
                    "offers_count": 11,
                    "offers_min_price": 233.21,
                    "own_offer": {
                      "base_price": 249.99,
                      "base_price_ht": 208.325,
                      "grey_dot": true,
                      "nature": 11,
                      "promo_price": 249.99,
                      "promo_price_ht": 208.325
                    },
                    "promo_price": 247.35,
                    "reviews_count": "0",
                    "reviews_count_website_5": "0",
                    "reviews_note": "0.0000",
                    "reviews_note_website_5": "0.0000",
                    "shop": {
                      "id": 2004,
                      "name": "Stuff",
                      "url": "/soms/Stuff"
                    },
                    "url": "/soms/product.html"
                  }
                },
                "_type": "page",
                "sort": [
                  0.0057305535,
                  0.04427508529513
                ]
              }
            ],
            "max_score": null,
            "total": 3657
          },
          "timed_out": false,
          "took": 68
        },
        "output": "Stuff"
      }
    ],
    "identifier": 48746081
  },
  {
    "context": [
      "I have JSON exported from Cassandra in this format.",
      "I would like to split it to separate documents:",
      "I wanted to use [jq][1] but didn&#39;t find way how.",
      "Using jq, one can split an array into its components using the filter:\r\n\r\n    .[]",
      "The 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."
    ],
    "utterance": "Output each element of the top-level array as a separate document.",
    "expressions": [
      ".[]"
    ],
    "data": [
      {
        "input": [
          {
            "correlationId": "2232845a8556cd3219e46ab8",
            "leg": 0,
            "tag": "received",
            "offset": 263128,
            "len": 30,
            "prev": {
              "page": {
                "file": 0,
                "page": 0
              },
              "record": 0
            },
            "data": "HEAD /healthcheck HTTP/1.1\r\n\r\n"
          },
          {
            "correlationId": "2232845a8556cd3219e46ab8",
            "leg": 0,
            "tag": "sent",
            "offset": 262971,
            "len": 157,
            "prev": {
              "page": {
                "file": 10330,
                "page": 6
              },
              "record": 1271
            },
            "data": "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"
          }
        ],
        "output": {
          "correlationId": "2232845a8556cd3219e46ab8",
          "leg": 0,
          "tag": "received",
          "offset": 263128,
          "len": 30,
          "prev": {
            "page": {
              "file": 0,
              "page": 0
            },
            "record": 0
          },
          "data": "HEAD /healthcheck HTTP/1.1\r\n\r\n"
        }
      }
    ],
    "identifier": 48790861
  },
  {
    "context": [
      "To convert the .data element from a JSON string into a JSON object, you could use the filter:",
      ".data |= fromjson",
      "If you just want to extract the .data element and convert it, you could use the filter:",
      ".data | fromjson",
      "If it is uncertain whether or not fromjson will succeed, you could use the idiom: fromjson? // ., e.g.:",
      ".data |= (fromjson? // .)"
    ],
    "utterance": "Replace the 'data' field's string value with its parsed object value, so it becomes a structured array/object instead of a string.",
    "expressions": [
      ".data |= fromjson",
      ".data | fromjson",
      ".data |= (fromjson? // .)"
    ],
    "data": [
      {
        "input": {
          "correlationId": "fb8f855a0eac8985d430896d",
          "leg": 65535,
          "tag": "circuitpath",
          "offset": 479306,
          "len": 508,
          "prev": {
            "page": {
              "file": 10342,
              "page": 8
            },
            "record": 216
          },
          "data": "[ { \"policy\": \"Health Check\", \"execTime\": 0, \"filters\": [ { \"espk\": \"DEFAULT_PRIMARY_VordelGateway_7.4.0:223\", \"name\": \"Set Message\", \"type\": \"ChangeMessageFilter\", \"class\": \"com.vordel.circuit.conversion.ChangeMessageFilter\", \"status\": \"Pass\", \"filterTime\": 1518702587006, \"execTime\": 0 } , { \"espk\": \"DEFAULT_PRIMARY_VordelGateway_7.4.0:222\", \"name\": \"Reflect\", \"type\": \"ReflectFilter\", \"class\": \"com.vordel.circuit.net.ReflectFilter\", \"status\": \"Pass\", \"filterTime\": 1518702587006, \"execTime\": 0 } ] } ]"
        },
        "output": {
          "correlationId": "fb8f855a0eac8985d430896d",
          "leg": 65535,
          "tag": "circuitpath",
          "offset": 479306,
          "len": 508,
          "prev": {
            "page": {
              "file": 10342,
              "page": 8
            },
            "record": 216
          },
          "data": [
            {
              "policy": "Health Check",
              "execTime": 0,
              "filters": [
                {
                  "espk": "DEFAULT_PRIMARY_VordelGateway_7.4.0:223",
                  "name": "Set Message",
                  "type": "ChangeMessageFilter",
                  "class": "com.vordel.circuit.conversion.ChangeMessageFilter",
                  "status": "Pass",
                  "filterTime": 1518702587006,
                  "execTime": 0
                },
                {
                  "espk": "DEFAULT_PRIMARY_VordelGateway_7.4.0:222",
                  "name": "Reflect",
                  "type": "ReflectFilter",
                  "class": "com.vordel.circuit.net.ReflectFilter",
                  "status": "Pass",
                  "filterTime": 1518702587006,
                  "execTime": 0
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 48811733
  },
  {
    "context": [
      "I would like to transform with jq this JSON\n\n    [\n      {\n        \"one\": 37,\n        \"two\": \"2017-09-15T19:31:55\"\n      }\n    ]\n\nto this one\n\n    [\n      {\n        \"one\": 37\n      },\n      {\n        \"two\": \"2017-09-15T19:31:55\"\n      }\n    ]\n\nHow to do it?",
      "map(to_entries[] | {(.key): .value})"
    ],
    "utterance": "Convert each object with multiple key-value pairs in an array into separate objects each containing a single key-value pair.",
    "expressions": [
      "map(to_entries[] | {(.key): .value})"
    ],
    "data": [
      {
        "input": [
          {
            "one": 37,
            "two": "2017-09-15T19:31:55"
          }
        ],
        "output": [
          {
            "one": 37
          },
          {
            "two": "2017-09-15T19:31:55"
          }
        ]
      }
    ],
    "identifier": 48843494
  },
  {
    "context": [
      "with JQ the output looks like this: \r\n\r\n    \"removedforprivacy@gmail.com\"  \r\n    \"john\"  \r\n    \"smith\"  \r\n    null  \r\n    null  \r\n    \"123 road st\"  \r\n    null  \r\n    \"Columbia\"  \r\n    \"29203\"  \r\n    \"SC\"  \r\n    null  \r\n",
      "instead I want it to look like this: \r\n    \r\n    \"removedforprivacy@gmail.com\" \"john\" \"smith\" null null \"123 road st\" null \"Columbia\" \"29203\" \"SC\" null",
      "or even better: \r\n\r\n    \"removedforprivacy@gmail.com\",\"john\",\"smith\",null,null,\"123,road,st\",null,\"Columbia\",\"29203\",\"SC\",null",
      "jq -c '(.email, .first_name, .last_name, .ip, .address, .address1, .address2, .city, .zip, .state, .phone)' file.json > file2.json",
      "If you want CSV then you could of course simply use the `@csv` filter, but `@csv` converts `null` to an empty field:",
      "To 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 == \"string\" then \"\\\"\\(.)\\\"\" else \"null\" end)\r\n    | @tsv | gsub(\"\\t\";\",\")"
    ],
    "utterance": "Output the selected fields as a single comma-separated line where string values are quoted and null values appear as the literal word null.",
    "expressions": [
      "[(.email, .first_name, .last_name, .ip, .address, .address1, .address2, .city, .zip, .state, .phone)] | map(if type == \"string\" then \"\\\"\\(.)\\\"\" else \"null\" end) | @tsv | gsub(\"\\t\";\",\")"
    ],
    "identifier": 48817992
  },
  {
    "context": [
      "and to retrieve Date value (from credentials). I have tried `curl xxx | jq -r '. | select (.Date)' which 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).",
      "The (or at least a) short answer is:\n\n    .system.svcs.upsvcs[0].credentials.Date",
      "Another approach would be just to retrieve all \u201ctruthy\u201d `.Date` values, no matter where they appear:\n\n    $ jq -c '.. | .Date? // empty' input.json\n    \"Feb152018\""
    ],
    "utterance": "Extract the value of the Date field from the credentials object inside the first item of the upsvcs array.",
    "expressions": [
      ".system.svcs.upsvcs[0].credentials.Date",
      "getpath([\"system\",\"svcs\",\"upsvcs\",0,\"credentials\",\"Date\"])",
      ".. | .Date? // empty"
    ],
    "data": [
      {
        "input": {
          "environment": {
            "reg": "abc"
          },
          "system": {
            "svcs": {
              "upsvcs": [
                {
                  "name": "monitor",
                  "tags": [],
                  "vmnts": [],
                  "label": "upsvcs",
                  "credentials": {
                    "Date": "Feb152018",
                    "time": "1330"
                  }
                },
                {
                  "name": "application",
                  "tags": [],
                  "vmnts": [],
                  "label": "upsvcs",
                  "credentials": {
                    "lastViewed": "2018-02-07"
                  }
                }
              ]
            }
          }
        },
        "output": "Feb152018"
      }
    ],
    "identifier": 48847742
  },
  {
    "context": [
      "I would like to filter this array and remove all the purchased items that were \"undone\".",
      "A PURCHASE_ITEM object can be undone by adding an ITEM_UNDONE object after it with a higher timestamp, a matching participantId and beforeId==itemId.",
      "First, let\u2019s define a filter that will tell if an item in the array has been \"undone\" by a subsequent (in the array and in time) item.",
      "def undone($n):\n  . as $in\n  | length as $length\n  | .[$n] as $nth\n  | if $nth.type != \"ITEM_PURCHASED\" then false\n    else any( range($n+1; $length) | $in[.]; \n              .type == \"ITEM_UNDO\"\n              and .participantId == $nth.participantId\n              and .beforeId== $nth.itemId\n              and .timestamp > $nth.timestamp)\n    end;",
      "[ range(0;length) as $i\n  | select( (.[$i].type == \"ITEM_PURCHASED\") and (undone($i) | not) )\n  | .[$i] ]"
    ],
    "utterance": "Select all purchased items that do not have a corresponding undo with a later timestamp, matching participantId and beforeId equal to itemId.",
    "expressions": [
      "def undone($n): . as $in | length as $length | .[$n] as $nth | if $nth.type != \"ITEM_PURCHASED\" then false else any( range($n+1; $length) | $in[.]; .type == \"ITEM_UNDO\" and .participantId == $nth.participantId and .beforeId== $nth.itemId and .timestamp > $nth.timestamp) end; [ range(0;length) as $i | select( (.[$i].type == \"ITEM_PURCHASED\") and (undone($i) | not) ) | .[$i] ]"
    ],
    "data": [
      {
        "input": [
          {
            "type": "ITEM_PURCHASED",
            "timestamp": 1710829,
            "participantId": 2,
            "itemId": 3089
          },
          {
            "type": "ITEM_PURCHASED",
            "timestamp": 1711620,
            "participantId": 7,
            "itemId": 2055
          },
          {
            "type": "ITEM_PURCHASED",
            "timestamp": 1711621,
            "participantId": 7,
            "itemId": 1058
          },
          {
            "type": "ITEM_PURCHASED",
            "timestamp": 1714435,
            "participantId": 9,
            "itemId": 1037
          },
          {
            "type": "ITEM_UNDO",
            "timestamp": 1716107,
            "participantId": 7,
            "afterId": 0,
            "beforeId": 2055
          },
          {
            "type": "ITEM_UNDO",
            "timestamp": 1716272,
            "participantId": 7,
            "afterId": 0,
            "beforeId": 1058
          },
          {
            "type": "ITEM_PURCHASED",
            "timestamp": 1718091,
            "participantId": 7,
            "itemId": 1026
          }
        ],
        "output": [
          {
            "type": "ITEM_PURCHASED",
            "timestamp": 1710829,
            "participantId": 2,
            "itemId": 3089
          },
          {
            "type": "ITEM_PURCHASED",
            "timestamp": 1714435,
            "participantId": 9,
            "itemId": 1037
          },
          {
            "type": "ITEM_PURCHASED",
            "timestamp": 1718091,
            "participantId": 7,
            "itemId": 1026
          }
        ]
      }
    ],
    "identifier": 48820138
  },
  {
    "context": [
      "Sample JSON:\r\n\r\n    {\r\n    \"db.password\" : \"Some password\",\r\n    \"db.username\" : \"Some username\"\r\n    }",
      "while read -r key val; do \r\n    declare -x \"$key\"=\"$val\"\r\n done < <(jq -r 'to_entries[] | [(.key | gsub(\"\\\\.\";\"_\")), .value] | @tsv' <<<\"$creds\")",
      "jq -r 'to_entries[] | [(.key | gsub(\"\\\\.\";\"_\")), .value] | @tsv'"
    ],
    "utterance": "Produce pairs of top-level object keys (replacing dots with underscores) and their values as tab-separated lines.",
    "expressions": [
      "to_entries[] | [(.key | gsub(\"\\\\.\";\"_\")), .value] | @tsv",
      "jq -r 'to_entries[] | [(.key | gsub(\"\\\\.\";\"_\")), .value] | @tsv'"
    ],
    "data": [
      {
        "input": {
          "db.password": "Some password",
          "db.username": "Some username"
        },
        "output": "db_password\tSome password\ndb_username\tSome username"
      }
    ],
    "identifier": 48850819
  },
  {
    "context": [
      "I am using filter **setpath** described in jq manual.",
      "But even if I copied the documented string",
      "./jq 'setpath([0,\"a\"]; 1)'  < test.json",
      "still getting error:",
      "jq: error (at <stdin>:1): Cannot index object with number",
      "You cannot use integer indices as keys in the JSON object. For JSON objects, the key must be a string, so you could write:",
      "jq 'setpath([\"0\",\"a\"]; 1)'  < test.json",
      "Output:",
      "{\n  \"correlationId\": \"6298865a73b477106c98d021\",\n  \"leg\": 0,\n  \"tag\": \"sent\",\n  \"offset\": 322858,\n  \"len\": 178,\n  \"prev\": {\n    \"page\": {\n      \"file\": 10352,\n      \"page\": 2\n    },\n    \"record\": 911\n  },\n  \"data\": \"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\",\n  \"0\": {\n    \"a\": 1\n  }\n}"
    ],
    "utterance": "Add a new object at the top level with key \"0\" and nested key \"a\" set to 1 using setpath.",
    "expressions": [
      "setpath([\"0\",\"a\"]; 1)"
    ],
    "data": [
      {
        "input": {
          "correlationId": "6298865a73b477106c98d021",
          "leg": 0,
          "tag": "sent",
          "offset": 322858,
          "len": 178,
          "prev": {
            "page": {
              "file": 10352,
              "page": 2
            },
            "record": 911
          },
          "data": "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"
        },
        "output": {
          "correlationId": "6298865a73b477106c98d021",
          "leg": 0,
          "tag": "sent",
          "offset": 322858,
          "len": 178,
          "prev": {
            "page": {
              "file": 10352,
              "page": 2
            },
            "record": 911
          },
          "data": "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",
          "0": {
            "a": 1
          }
        }
      }
    ],
    "identifier": 48827898
  },
  {
    "context": [
      "I have this document:\n\n    {\n      \"correlationId\": \"6298865a73b477106c98d021\",\n      \"leg\": 0,\n      \"tag\": \"sent\",\n      \"offset\": 322858,\n      \"len\": 178,\n      \"prev\": {\n        \"page\": {\n          \"file\": 10352,\n          \"page\": 2\n        },\n        \"record\": 911\n      },\n      \"data\": \"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\"\n    }\n",
      "I would like to move the value \n\n> \"HTTP/1.1 403 Forbidden\\r\\nDate: Fri, 16 Feb 2018 08:37:54\n> GMT\\r\\nServer: \\r\\nConnection: close\\r\\nX-CorrelationID:\n> Id-6298865a73b477106c98d021 0\\r\\nContent-Type: text/html\\r\\n\\r\\nAccess\n> Denied\"\n\ninto `\"data\": { \"message\": \"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\"}` structure.",
      "I tried to find a solution with jq but I didn't found any filter which would move it.",
      "It seems you want:\n\n    .data |= { message: .}"
    ],
    "utterance": "Move the value of the 'data' field at the root level into an object with a key 'message' under 'data'.",
    "expressions": [
      ".data |= { message: . }"
    ],
    "data": [
      {
        "input": {
          "correlationId": "6298865a73b477106c98d021",
          "leg": 0,
          "tag": "sent",
          "offset": 322858,
          "len": 178,
          "prev": {
            "page": {
              "file": 10352,
              "page": 2
            },
            "record": 911
          },
          "data": "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"
        },
        "output": {
          "correlationId": "6298865a73b477106c98d021",
          "leg": 0,
          "tag": "sent",
          "offset": 322858,
          "len": 178,
          "prev": {
            "page": {
              "file": 10352,
              "page": 2
            },
            "record": 911
          },
          "data": {
            "message": "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"
          }
        }
      }
    ],
    "identifier": 48826688
  },
  {
    "context": [
      "I was trying to extract relevant data from a given JSON file. The JSON has the following format.",
      "\"partyResponse\" : { \"ns2:Address1\" : \"10 test Way\", ... }",
      "I'm trying to get the value for Address1 but the following just prints out the whole JSON in an odd manner.",
      "jq .[].partyResponse[\"ns2:Address1\"] random_file_20180220.json",
      "I just want to list out the address as follows.",
      "\"10 test Way\"",
      "Found the solution.",
      "jq '[].partyResponse[\"ns2:Address1\"]' random_file_20180220.json",
      "The above gives the desired result.",
      "\"10 test Way\"",
      "\"10 test Way\"",
      "\"3030 test Freeway\""
    ],
    "utterance": "Extract all values for the key 'ns2:Address1' from each object's 'partyResponse'.",
    "expressions": [
      ".[].partyResponse[\"ns2:Address1\"]"
    ],
    "data": [
      {
        "input": [
          {
            "partyResponse": {
              "ns2:Address1": "10 test Way",
              "ns2:Address2": null
            }
          },
          {
            "partyResponse": {
              "ns2:Address1": "3030 test Freeway",
              "ns2:Address2": null
            }
          }
        ],
        "output": [
          "10 test Way",
          "3030 test Freeway"
        ]
      }
    ],
    "identifier": 48878685
  },
  {
    "context": [
      "but now i'd like to print the full json and not just the modified strings",
      "Adapting your query:\r\n \r\n    .profiles |= walk( if type == \"object\" and has(\"gameDir\")\r\n                       then .gameDir |=\r\n                         (if type == \"null\" then \"\" else . end\r\n                         | scan(\"{REPLACE}.*\") | sub(\"{REPLACE}\"; \"{REPLACESTRINGHERE}\"))\r\n                       else . \r\n                       end )",
      "For the record, here'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] == \"gameDir\")) as $path ($in;\r\n           ($in | getpath($path)\r\n    \t    | if type == \"null\" then \"\"\r\n                  else sub(\".*{REPLACE}\"; \"{REPLACESTRINGHERE}\")\r\n                  end) as $value\r\n           | setpath($path; $value) ))"
    ],
    "utterance": "Replace all 'gameDir' descendant values starting with '{REPLACE}' with '{REPLACESTRINGHERE}', and output the entire modified object.",
    "expressions": [
      ".profiles |= walk( if type == \"object\" and has(\"gameDir\")\n                       then .gameDir |=\n                         (if type == \"null\" then \"\" else . end\n                         | scan(\"{REPLACE}.*\") | sub(\"{REPLACE}\"; \"{REPLACESTRINGHERE}\"))\n                       else . \n                       end )",
      ".profiles |= \n   ( . as $in\n   | reduce (paths | select(.[-1] == \"gameDir\")) as $path ($in;\n       ($in | getpath($path)\n        | if type == \"null\" then \"\"\n              else sub(\".*{REPLACE}\"; \"{REPLACESTRINGHERE}\")\n              end) as $value\n       | setpath($path; $value) ))"
    ],
    "identifier": 48865921
  },
  {
    "context": [
      "Now, the `(.key)` is parsed as a string, yet I want `companyId` to be a number.",
      "`jq` has inbuilt functions, you can pipe your key to [`tonumber`](https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions):",
      "jq 'to_entries[]| {companyId: (.key)|tonumber, companyTitle: (.value.title), companyCode: (.value.booking_service_code)}' companies.json",
      "If you want to *guarantee* your result is an integer you will need to floor it.",
      "jq 'to_entries[]| {companyId: ((.key|tonumber)|floor), companyTitle: (.value.title), companyCode: (.value.booking_service_code)}' companies.json"
    ],
    "utterance": "Convert the object key, originally a string containing a number, to a numeric companyId field.",
    "expressions": [
      "to_entries[] | {companyId: (.key|tonumber), companyTitle: (.value.title), companyCode: (.value.booking_service_code)}",
      "to_entries[] | {companyId: ((.key|tonumber)|floor), companyTitle: (.value.title), companyCode: (.value.booking_service_code)}"
    ],
    "data": [
      {
        "input": {
          "1337": {
            "title": "Some company title",
            "booking_service_code": "oxo"
          }
        },
        "output": {
          "companyId": 1337,
          "companyTitle": "Some company title",
          "companyCode": "oxo"
        }
      }
    ],
    "identifier": 48887711
  },
  {
    "context": [
      "I want to filter by `objectName` for `contacts` add some data to empty IBM field and save to the file",
      "Applying the same logic to inplace edit the IBM field to `\"Y\"` on object containing `\"objectName\": \"contacts\"`",
      "Your jq filter is not the one you need because `select` selects.  That is, it filters out the objects that don't match the selection criterion.",
      "This jq filter should do what you want:",
      "if (.objectName == \"contacts\") then .IBM = \"Y\" else . end"
    ],
    "utterance": "Update the value of the IBM field to \"Y\" for all objects where objectName is equal to \"contacts\".",
    "expressions": [
      "if (.objectName == \"contacts\") then .IBM = \"Y\" else . end"
    ],
    "data": [
      {
        "input": [
          {
            "Element": "acton",
            "objectName": "contacts",
            "Path": "/contacts",
            "Scenario": "",
            "serviceLevel": "",
            "IBM": "",
            "Gap": "",
            "clientPhase": "",
            "parentPhase": "",
            "existsToday": ""
          },
          {
            "Element": "acton",
            "objectName": "optouts",
            "Path": "/optouts",
            "Scenario": "",
            "serviceLevel": "",
            "IBM": "",
            "Dependency": "",
            "Gap": "",
            "clientPhase": "",
            "parentPhase": "",
            "existsToday": ""
          },
          {
            "Element": "acton",
            "objectName": "subscriptionTypes",
            "Path": "/subscription-types",
            "Scenario": "",
            "serviceLevel": "",
            "IBM": "",
            "Dependency": "",
            "Gap": "",
            "clientPhase": "",
            "parentPhase": "",
            "existsToday": ""
          }
        ],
        "output": [
          {
            "Element": "acton",
            "objectName": "contacts",
            "Path": "/contacts",
            "Scenario": "",
            "serviceLevel": "",
            "IBM": "Y",
            "Gap": "",
            "clientPhase": "",
            "parentPhase": "",
            "existsToday": ""
          },
          {
            "Element": "acton",
            "objectName": "optouts",
            "Path": "/optouts",
            "Scenario": "",
            "serviceLevel": "",
            "IBM": "",
            "Dependency": "",
            "Gap": "",
            "clientPhase": "",
            "parentPhase": "",
            "existsToday": ""
          },
          {
            "Element": "acton",
            "objectName": "subscriptionTypes",
            "Path": "/subscription-types",
            "Scenario": "",
            "serviceLevel": "",
            "IBM": "",
            "Dependency": "",
            "Gap": "",
            "clientPhase": "",
            "parentPhase": "",
            "existsToday": ""
          }
        ]
      }
    ],
    "identifier": 48878003
  },
  {
    "context": [
      "echo \"[[{\\\"t\\\":4}]]\" | jq 'index(.[0])'",
      "I was expecting this to return 0.",
      "Instead it's returning null.",
      "So to search for a JSON entity X, using `index([X])` is always safe.",
      "So to recover the least index of X in the input array:",
      ".[[X]][0]"
    ],
    "utterance": "Find the index of the subarray [{\"t\":4}] within the array [[{\"t\":4}]].",
    "expressions": [
      "index([.{t:4}])",
      ".[[{\"t\":4}]][0]"
    ],
    "data": [
      {
        "input": [
          [
            {
              "t": 4
            }
          ]
        ],
        "output": 0
      }
    ],
    "identifier": 48898983
  },
  {
    "context": [
      "I 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.",
      "jq -Rn  --slurp --raw-input --raw-output \\&#39;\r\n    ( input  | split(\"|\") ) as $keys |\r\n    ( inputs | split(\"|\") ) as $vals |\r\n    [[$keys, $vals] | transpose[] | {key:.[0],value:.[1]}] | from_entries\r\n    &#39; $OutPath$FileName > $JsonPath$FileName",
      "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 \"slurp\" the file.",
      "jq  -nrR '\n ( input  | split(\"|\") ) as $keys\n | ( inputs | split(\"|\") ) as $vals\n | [[$keys, $vals] | transpose[] | {key:.[0], value:.[1]|tonumber}]\n | from_entries\n'"
    ],
    "utterance": "Transform a pipe-delimited text file where the first line contains numeric field names into an object with field names as keys and subsequent line values as corresponding values.",
    "expressions": [
      "jq -nrR '\n ( input  | split(\"|\") ) as $keys\n | ( inputs | split(\"|\") ) as $vals\n | [[$keys, $vals] | transpose[] | {key:.[0], value:.[1]|tonumber}]\n | from_entries\n'"
    ],
    "identifier": 48875623
  },
  {
    "context": [
      "For all root keys that end with `/`, I need the value of `.type`, so that the final result for the above example is `token userpass`.",
      "jq -r '. as $o | keys_unsorted[] | select(endswith(\"/\")) | $o[.].type' file.json",
      "to_entries[] | select(.key|endswith(\"/\")) | .value.type"
    ],
    "utterance": "Extract the value of .type for all root-level keys that end with '/'.",
    "expressions": [
      ". as $o | keys_unsorted[] | select(endswith(\"/\")) | $o[.].type",
      "to_entries[] | select(.key|endswith(\"/\")) | .value.type"
    ],
    "data": [
      {
        "input": {
          "token/": {
            "accessor": "auth_token_909d6a81",
            "config": {
              "default_lease_ttl": 0,
              "max_lease_ttl": 0
            },
            "description": "token based credentials",
            "local": false,
            "seal_wrap": false,
            "type": "token"
          },
          "userpass/": {
            "similar_to": {
              "above": null
            },
            "description": "",
            "local": false,
            "seal_wrap": false,
            "type": "userpass"
          },
          "request_id": "f2a4c135-f699-f29d-ca7c-3320dce0a550",
          "more_keys": "more_values",
          "data": {
            "more_data": {
              "even_more_data": "snipped"
            }
          },
          "you_get_the": "idea"
        },
        "output": [
          "token",
          "userpass"
        ]
      }
    ],
    "identifier": 48904371
  },
  {
    "context": [
      "I 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      \"foo\": \"bar\"\r\n    }",
      "jq '.foo as $foo | .stuff[] | select(.foo == $foo)' file.json"
    ],
    "utterance": "Select objects from the stuff array whose foo field matches the outer object's foo field value of \"bar\".",
    "expressions": [
      ".foo as $foo | .stuff[] | select(.foo == $foo)"
    ],
    "data": [
      {
        "input": {
          "foo": "bar",
          "stuff": [
            {
              "foo": "baz"
            },
            {
              "foo": "bar"
            }
          ]
        },
        "output": {
          "foo": "bar"
        }
      }
    ],
    "identifier": 48915926
  },
  {
    "context": [
      "writeFolder=$(jq -r --arg bf \"${BUILD_FOLDER}\" '.server_'${id}'.data_folders[] | sub(\"\\\\${BUILD_FOLDER}\";$bf)' \"${json_path}\")",
      "jq -r --arg bf \"$BUILD_FOLDER\" '.data_folders[] | sub(\"\\\\${BUILD_FOLDER}\";$bf)' \"${json_path}\" |",
      "mkdir -p /Users/me/Desktop/POD_INSTALLS/pod_DB/mybuildfolder/data/table1/",
      "mkdir -p /Users/me/Desktop/POD_INSTALLS/pod_DB/mybuildfolder/data/table2/"
    ],
    "utterance": "Replace all occurrences of ${BUILD_FOLDER} in every value of the data_folders array under server_1 with a specified string such as mybuildfolder.",
    "expressions": [
      ".server_1.data_folders[] | sub(\"\\\\${BUILD_FOLDER}\"; $bf)"
    ],
    "data": [
      {
        "input": {
          "server_1": {
            "tag": "storage_1",
            "user": "me",
            "sshKey": "/Users/me/.ssh/id_rsa",
            "target_folder": "/Users/me/Desktop/",
            "pubIp": "127.0.0.1",
            "data_folders": [
              "/Users/me/Desktop/POD_INSTALLS/pod_DB/${BUILD_FOLDER}/data/table1/",
              "/Users/me/Desktop/POD_INSTALLS/pod_DB/${BUILD_FOLDER}/data/table2/"
            ]
          }
        },
        "output": [
          "/Users/me/Desktop/POD_INSTALLS/pod_DB/mybuildfolder/data/table1/",
          "/Users/me/Desktop/POD_INSTALLS/pod_DB/mybuildfolder/data/table2/"
        ]
      }
    ],
    "identifier": 48911678
  },
  {
    "context": [
      "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.",
      "the correct code looks like this:\r\n\r\n    getting_data_from_dynamo | jq -r '\r\n      (.compoundid.s | split(\"-\")[:2]) + \r\n       [.typeid.n, \r\n       (.datetime.n\r\n        | tonumber \r\n        | (. - 621355968000000000) / 10000000 \r\n        | strftime(\"%F %X\"))] \r\n      | @csv'"
    ],
    "utterance": "Extract the first two parts of the 'compoundid.s' field split by '-', the 'typeid.n' field, and the 'datetime.n' field converted from C# ticks to a formatted datetime string.",
    "expressions": [
      "(.compoundid.s | split(\"-\")[:2]) + [.typeid.n, (.datetime.n | tonumber | (. - 621355968000000000) / 10000000 | strftime(\"%F %X\"))] | @csv"
    ],
    "identifier": 48954626
  },
  {
    "context": [
      "How to extract only \"key\": `\"TECH-456\"`, and \"key\": `\"TECH\"`, (values after key)",
      "jq -r '.issues[0] | .key, .fields.project.key' file.json",
      "The output:\n\n    TECH-456\n    TECH"
    ],
    "utterance": "Extract the value of the top-level issue key and the related project key from the first item in the issues array.",
    "expressions": [
      ".issues[0] | .key, .fields.project.key"
    ],
    "data": [
      {
        "input": {
          "expand": "names,schema",
          "issues": [
            {
              "expand": "operations,versionedRepresentations,editmeta,changelog,renderedFields",
              "fields": {
                "project": {
                  "key": "TECH"
                }
              },
              "id": "15377",
              "key": "TECH-456",
              "self": "https://mycompany/rest/api/2/issue/15377"
            }
          ]
        },
        "output": [
          "TECH-456",
          "TECH"
        ]
      }
    ],
    "identifier": 48937230
  },
  {
    "context": [
      "i have a file \"stats.json\" with the following initial structure\" [{ \"price\": 66.55, \"created\": \"2018-02-24T14:32:57\" }]",
      "i take every 10 minutes data from an api and save it to \"temp.json\" { \"price\": 88.55, \"created\": \"2018-02-24T15:32:57\" }",
      "I would like to merge the temp.json (which is updated every 10min) and to fill the stats.json file.",
      "One way to add the item in temp.obj to the array in stats.json: jq \u2014-slurpfile temp temp.obj '. + $temp' stats.json",
      "Another way: jq \u2014s '.[0] + [.[1]]' stats.json temp.json"
    ],
    "utterance": "Append the object from temp.json as a new element to the array in stats.json.",
    "expressions": [
      "jq --slurpfile temp temp.json '. + $temp' stats.json",
      "jq -s '.[0] + [.[1]]' stats.json temp.json"
    ],
    "data": [
      {
        "input": [
          {
            "file": "stats.json",
            "content": [
              {
                "price": 66.55,
                "created": "2018-02-24T14:32:57"
              }
            ]
          },
          {
            "file": "temp.json",
            "content": {
              "price": 88.55,
              "created": "2018-02-24T15:32:57"
            }
          }
        ],
        "output": [
          {
            "price": 66.55,
            "created": "2018-02-24T14:32:57"
          },
          {
            "price": 88.55,
            "created": "2018-02-24T15:32:57"
          }
        ]
      }
    ],
    "identifier": 48963263
  },
  {
    "context": [
      "I am trying to make a filter using jq to filter the arrays in this json to get only the arrays that have **\"policy_id\": 199383** and exclude the arrays that contain different policy_id value.",
      "I tried this : jq '.incidents[] | select (.links.policy_id == \"199383\")' file.json. But not having anything in return ? Can anyone help.",
      "jq '.incidents[]| select(.links.policy_id==199383)' file.json should do it."
    ],
    "utterance": "Select all items where .links.policy_id equals 199383",
    "expressions": [
      ".incidents[] | select(.links.policy_id == 199383)"
    ],
    "data": [
      {
        "input": {
          "incidents": [
            {
              "links": {
                "policy_id": 199383,
                "violations": [
                  69892478
                ]
              },
              "incident_preference": "PER_CONDITION_AND_TARGET",
              "closed_at": 1519408001909,
              "opened_at": 1519407125437,
              "id": 17821334
            },
            {
              "links": {
                "policy_id": 199383,
                "violations": [
                  69889831
                ]
              },
              "incident_preference": "PER_CONDITION_AND_TARGET",
              "closed_at": 1519408011851,
              "opened_at": 1519406230858,
              "id": 17820349
            },
            {
              "links": {
                "policy_id": 194774,
                "violations": [
                  68446755
                ]
              },
              "incident_preference": "PER_POLICY",
              "closed_at": 1518835775531,
              "opened_at": 1518835745303,
              "id": 17422347
            },
            {
              "links": {
                "policy_id": 199383,
                "violations": [
                  69892488
                ]
              },
              "incident_preference": "PER_CONDITION_AND_TARGET",
              "closed_at": 1519402345676,
              "opened_at": 1519401235467,
              "id": 17821334
            }
          ]
        },
        "output": [
          {
            "links": {
              "policy_id": 199383,
              "violations": [
                69892478
              ]
            },
            "incident_preference": "PER_CONDITION_AND_TARGET",
            "closed_at": 1519408001909,
            "opened_at": 1519407125437,
            "id": 17821334
          },
          {
            "links": {
              "policy_id": 199383,
              "violations": [
                69889831
              ]
            },
            "incident_preference": "PER_CONDITION_AND_TARGET",
            "closed_at": 1519408011851,
            "opened_at": 1519406230858,
            "id": 17820349
          },
          {
            "links": {
              "policy_id": 199383,
              "violations": [
                69892488
              ]
            },
            "incident_preference": "PER_CONDITION_AND_TARGET",
            "closed_at": 1519402345676,
            "opened_at": 1519401235467,
            "id": 17821334
          }
        ]
      }
    ],
    "identifier": 48956030
  },
  {
    "context": [
      "Problem is that produced json file will have `\"ve\\\\rsion\"` instead of `\"ve\\rsion\"`",
      "how can I keep only one backslash.",
      "one option would be to use the -r command-line option to convert the JSON string to \u201craw\u201d text but this will only affect output entities that are actually strings; this option will also remove the outer quotation marks from such strings."
    ],
    "utterance": "Output a string value containing a single backslash, not double-escaped, in the produced result.",
    "expressions": [
      ".items[] | del(.href, .version, .Config) | .tag = $newtag | {\"Clusters\": {\"desired_config\": .}} | .Clusters.desired_config.tag",
      ".items[] | del(.href, .version, .Config) | .tag = $newtag | {\"Clusters\": {\"desired_config\": .}} | .Clusters.desired_config.tag | @text",
      ".items[] | del(.href, .version, .Config) | .tag = $newtag | {\"Clusters\": {\"desired_config\": .}} | .Clusters.desired_config.tag | @sh"
    ],
    "identifier": 48986743
  },
  {
    "context": [
      "jq -r '.issues[] | .key' 1.json",
      "jq -r '.issues[] | .fields.project.key' 1.json",
      "jq -r '.issues[] | .fields.customfield_10107.id' 1.json",
      "I want to store TECH-XXX to project=`jq -r '.issues[] | .key' 1.json` TECH to parent=`jq -r '.issues[] | .fields.project.key' 1.json` 10400 to custom_field=`jq -r '.issues[] | .fields.customfield_10107.id' 1.json` variable"
    ],
    "utterance": "Extract all values for the keys '.issues[].key', '.issues[].fields.project.key', and '.issues[].fields.customfield_10107.id' as separate lists.",
    "expressions": [
      ".issues[].key",
      ".issues[].fields.project.key",
      ".issues[].fields.customfield_10107.id"
    ],
    "identifier": 48994889
  },
  {
    "context": [
      "I would like to append the second object within the \"features\" array to the end of it, creating 3 total objects.",
      "cat red_line_nodes.json | jq '.features |= . + .[length-1]' > red_line_nodes_2.json",
      "Short **`jq`** solution:\n\n    jq '.features |= . + [.[-1]]' red_line_nodes.json",
      "For reference, an alternative to using `|= . + ...` is to use `+=`. In your case, however, you would have to write:\n\n    .features += [.features[-1]]"
    ],
    "utterance": "Append the last object in the 'features' array to the end of the 'features' array, duplicating it.",
    "expressions": [
      ".features |= . + [.[-1]]",
      ".features += [.features[-1]]"
    ],
    "data": [
      {
        "input": {
          "type": "FeatureCollection",
          "features": [
            {
              "type": "Feature",
              "properties": {
                "LINE": "RED",
                "STATION": "Harvard"
              },
              "geometry": {
                "type": "Point",
                "coordinates": [
                  -71.11890607237821,
                  42.37402923068516
                ]
              }
            },
            {
              "type": "Feature",
              "properties": {
                "LINE": "RED",
                "STATION": "Ashmont"
              },
              "geometry": {
                "type": "Point",
                "coordinates": [
                  -71.06343014438998,
                  42.28388354622532
                ]
              }
            }
          ]
        },
        "output": {
          "type": "FeatureCollection",
          "features": [
            {
              "type": "Feature",
              "properties": {
                "LINE": "RED",
                "STATION": "Harvard"
              },
              "geometry": {
                "type": "Point",
                "coordinates": [
                  -71.11890607237821,
                  42.37402923068516
                ]
              }
            },
            {
              "type": "Feature",
              "properties": {
                "LINE": "RED",
                "STATION": "Ashmont"
              },
              "geometry": {
                "type": "Point",
                "coordinates": [
                  -71.06343014438998,
                  42.28388354622532
                ]
              }
            },
            {
              "type": "Feature",
              "properties": {
                "LINE": "RED",
                "STATION": "Ashmont"
              },
              "geometry": {
                "type": "Point",
                "coordinates": [
                  -71.06343014438998,
                  42.28388354622532
                ]
              }
            }
          ]
        }
      }
    ],
    "identifier": 48983196
  },
  {
    "context": [
      "I want to convert the above value in json format like below.",
      "json_value=[ { \"key1\":\"value1\", \"key2\":\"value2\" }, { \"key1\":\"value1\", \"key2\":\"value2\" } ]",
      "To convert it into a JSON array, you should be able to use an incantation such as: for r in \"${a[@]}\" ; do printf \"%s\" \"$r\" ; done | jq -s .",
      "Use the slurp option: jq -s . in.json > out.json"
    ],
    "utterance": "Combine multiple objects, each on a separate line, into a single array containing those objects.",
    "expressions": [
      "jq -s .",
      "for r in \"${a[@]}\" ; do printf \"%s\" \"$r\" ; done | jq -s ."
    ],
    "data": [
      {
        "input": [
          "{\"key1\": \"value1\", \"key2\": \"value2\"}",
          "{\"key1\": \"value1\", \"key2\": \"value2\"}"
        ],
        "output": [
          {
            "key1": "value1",
            "key2": "value2"
          },
          {
            "key1": "value1",
            "key2": "value2"
          }
        ]
      }
    ],
    "identifier": 48991435
  },
  {
    "context": [
      "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?",
      "If you can parse based on the first colon, this will do it:\n\n    jq -Rn '[inputs | capture(\"(?<key>[^:]*): *(?<value>.*)\")] | from_entries'",
      "Or (apart from the trimming):\n\n    jq -Rn '[inputs | index(\":\") as $i | {key: .[:$i], value: .[1+$i:]}] | from_entries'",
      "This can also be done without \"from_entries\" function:\r\n\r\n    jq -Rn '[ inputs |split(\": \") |{ (.[0]):.[1] } ] |add'"
    ],
    "utterance": "Transform newline-separated key-value pairs separated by ': ' into an object with keys mapped to values.",
    "expressions": [
      "jq -Rn '[inputs | capture(\"(?<key>[^:]*): *(?<value>.*)\")] | from_entries'",
      "jq -Rn '[inputs | index(\":\") as $i | {key: .[:$i], value: .[1+$i:]}] | from_entries'",
      "jq -Rn '[ inputs |split(\": \") |{ (.[0]):.[1] } ] |add'"
    ],
    "data": [
      {
        "input": "samaccountname: displayname\nsamaccountname2: displayname2",
        "output": {
          "samaccountname": "displayname",
          "samaccountname2": "displayname2"
        }
      }
    ],
    "identifier": 48996252
  },
  {
    "context": [
      "Is there any option to declare an array item as an integer before using jq to replace the value in the template?",
      "use `--argjson` instead of `--arg`, at least for the numbers",
      "Now we can instantiate the template using the --argjson command-line option of jq:",
      "$ jq -n --argjson NODESTOTAL 1 --argjson NODESUSED 2 --argjson NODESFREE 3 --argjson NODESPERCENT 4 -f inode-template.jq"
    ],
    "utterance": "Substitute numeric variables into a template, ensuring the values are treated as numbers rather than strings.",
    "expressions": [
      "jq -n --argjson NODESTOTAL 1 --argjson NODESUSED 2 --argjson NODESFREE 3 --argjson NODESPERCENT 4 -f inode-template.jq"
    ],
    "data": [
      {
        "input": {
          "template": {
            "name": "inodeparse",
            "metrics": [
              {
                "event_type": "test",
                "provider": "test",
                "fileSystem": "FILESYS",
                "InodesTotal": "$NODESTOTAL",
                "InodesUsed": "$NODESUSED",
                "InodesFree": "$NODESFREE",
                "InodeUsedPercent": "$NODESPERCENT"
              }
            ]
          }
        },
        "output": {
          "name": "inodeparse",
          "metrics": [
            {
              "event_type": "test",
              "provider": "test",
              "fileSystem": "FILESYS",
              "InodesTotal": 1,
              "InodesUsed": 2,
              "InodesFree": 3,
              "InodeUsedPercent": 4
            }
          ]
        }
      }
    ],
    "identifier": 48938815
  },
  {
    "context": [
      "I wanted to try \n\n    jq -r 'try .data |= fromjson catch \"STRING\"'\nbut it is giving me error:",
      "This is one of the occasions when you have to help the parser by using parentheses:\n\n    jq -r 'try (.data |= fromjson) catch \"STRING\"'"
    ],
    "utterance": "Attempt to parse the .data field as an object and, if parsing fails, set the entire result to the string \"STRING\".",
    "expressions": [
      "try (.data |= fromjson) catch \"STRING\""
    ],
    "data": [
      {
        "input": {
          "correlationId": "2c13955ae3bb6c3cc943460b",
          "leg": 0,
          "tag": "sent",
          "offset": 167408,
          "len": 178,
          "prev": {
            "page": {
              "file": 10481,
              "page": 2
            },
            "record": 1736
          },
          "data": "HTTP/1.1 403 Forbidden\r\nDate: Tue, 27 Feb 2018 08:13:32 GMT\r\nServer:\r\nConnection: close\r\nX-CorrelationID: Id-2c13955ae3bb6c3cc943460b 0\r\nContent-Type: text/html\r\n\r\nAccess Denied"
        },
        "output": "STRING"
      }
    ],
    "identifier": 49004447
  },
  {
    "context": [
      "And result i want to achieve(using jq) is:\r\n\r\n    [\r\n      \"groupId1\":5,\r\n      \"groupId2\":4\r\n    ]",
      "jq '. as $o | [ keys_unsorted[] \r\n                    | {(.) : (reduce $o[.].list[] as $i (0; . + $i.count))} ] | add' file.json",
      "With that, you can just write the very readable:\r\n\r\n    map_values( sigma(.list[] | .count ))"
    ],
    "utterance": "For each top-level group, calculate the sum of the count values in its list and return an object mapping each group id to that sum.",
    "expressions": [
      ". as $o | [ keys_unsorted[] | {(.) : (reduce $o[.].list[] as $i (0; . + $i.count))} ] | add",
      "map_values( reduce .list[].count as $c (0; . + $c) )"
    ],
    "data": [
      {
        "input": {
          "groupId1": {
            "list": [
              {
                "field1": "somevalue",
                "count": 2,
                "field3": "somevalue"
              },
              {
                "field1": "somevalue",
                "count": 3,
                "field3": "somevalue"
              }
            ]
          },
          "groupId2": {
            "list": [
              {
                "field1": "somevalue",
                "count": 0,
                "field3": "somevalue"
              },
              {
                "field1": "somevalue",
                "count": 4,
                "field3": "somevalue"
              }
            ]
          }
        },
        "output": {
          "groupId1": 5,
          "groupId2": 4
        }
      }
    ],
    "identifier": 49029532
  },
  {
    "context": [
      "Is there a way to sort the keys of a JSON using `jq` but keeping keys named \"id\" as first descendants on all trees?",
      "Would become something like:\n\n    {\n        \"id\": 256767,\n        \"absorption\": 0.4,\n        \"collections\": [\n            {\n                \"id\" 190:,\n                \"a\": 18,\n                \"b\": 12\n            },\n            {\n                \"id\": 169,\n                \"m\": 22,\n                \"n\": 3\n            }\n        ],\n        \"z-displacement\": 3\n    }",
      "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:\n\ndef reorder:\n  (if has(\"id\") then {id} else null end) + (to_entries | sort | from_entries );\n\nwalk(if type == \"object\" then reorder else . end)",
      "If 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 \"master\" version of [builtin.jq][1]"
    ],
    "utterance": "Sort all object keys recursively, with any key named \"id\" appearing first at every level.",
    "expressions": [
      "def reorder: (if has(\"id\") then {id} else null end) + (to_entries | sort | from_entries ); walk(if type == \"object\" then reorder else . end)"
    ],
    "data": [
      {
        "input": {
          "z-displacement": 3,
          "absorption": 0.4,
          "collections": [
            {
              "b": 12,
              "a": 18,
              "id": 190
            },
            {
              "m": 22,
              "id": 169,
              "n": 3
            }
          ],
          "id": 256767
        },
        "output": {
          "id": 256767,
          "absorption": 0.4,
          "collections": [
            {
              "id": 190,
              "a": 18,
              "b": 12
            },
            {
              "id": 169,
              "m": 22,
              "n": 3
            }
          ],
          "z-displacement": 3
        }
      }
    ],
    "identifier": 49032866
  },
  {
    "context": [
      "This is the command I've tried ...\n    jq -r '.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)\"' streams.json | sh",
      "The *shortest possible change* to your original code is just to add the quotes that were missing:\n\n    jq -r '.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)\"' streams.json | sh",
      "As 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 ...\n\n    jq -j '.streams[] | ( .track + \"\\u0000\" + .link + \"\\u0000\" )' streams.json"
    ],
    "utterance": "Produce, for each stream in the file, a shell command line that invokes ffmpeg with the corresponding link as input and track as output, using the provided ffmpeg options.",
    "expressions": [
      ".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)\"",
      ".streams[] | ( .track + \"\\u0000\" + .link + \"\\u0000\" )"
    ],
    "data": [
      {
        "input": {
          "streams": [
            {
              "track": "/var/www/html/stream1.m3u8",
              "link": "http://playertest.longtailvideo.com/adaptive/bipbop/bipbop.m3u8"
            },
            {
              "track": "/var/www/html/stream2.m3u8",
              "link": "https://mnmedias.api.telequebec.tv/m3u8/29880.m3u8"
            },
            {
              "track": "/var/www/html/stream3.m3u8",
              "link": "http://www.streambox.fr/playlists/test_001/stream.m3u8"
            }
          ]
        },
        "output": [
          "ffmpeg -v verbose -i  'http://playertest.longtailvideo.com/adaptive/bipbop/bipbop.m3u8' -c copy -flags -global_header -hls_time 10 -hls_list_size 6 -hls_wrap 10 -start_number 1 '/var/www/html/stream1.m3u8'",
          "ffmpeg -v verbose -i  'https://mnmedias.api.telequebec.tv/m3u8/29880.m3u8' -c copy -flags -global_header -hls_time 10 -hls_list_size 6 -hls_wrap 10 -start_number 1 '/var/www/html/stream2.m3u8'",
          "ffmpeg -v verbose -i  'http://www.streambox.fr/playlists/test_001/stream.m3u8' -c copy -flags -global_header -hls_time 10 -hls_list_size 6 -hls_wrap 10 -start_number 1 '/var/www/html/stream3.m3u8'"
        ]
      }
    ],
    "identifier": 49034571
  },
  {
    "context": [
      "I have two arrays containing prices for items:",
      "[{\"id\":\"a\",\"p\":5},{\"id\":\"b\",\"p\":7},{\"id\":\"c\",\"p\":8}]",
      "and",
      "[{\"id\":\"a\",\"p\":9},{\"id\":\"b\",\"p\":7},{\"id\":\"d\",\"p\":4}]",
      "I want the primary array to be enriched with the prices from the secondary array, if available. If the price hasn't been updated, the entry should be removed. Thus the wanted output is (\"b\" removed because prices are equal and \"c\" kept):",
      "[{\"id\":\"a\",\"p\":5,\"c\":9},{\"id\":\"c\",\"p\":8,\"c\":null}]",
      "($sec|dict(.id)) as $new\n| reduce $pri[] as $x ([];\n    $new[$x.id] as $y\n    | if ($y.p == $x.p) then .\n      else . + [$x | (.c = $y.p)]\n      end )"
    ],
    "utterance": "For each entry in the primary array, return a list containing its price and the corresponding price from the secondary array (as field 'c'), omitting entries where prices are equal, and including entries from the primary array even if not present in the secondary.",
    "expressions": [
      "def dict(f): reduce .[] as $x ({}; .[$x|f] = $x);\n($sec|dict(.id)) as $new\n| reduce $pri[] as $x ([];\n    $new[$x.id] as $y\n    | if ($y.p == $x.p) then .\n      else . + [$x | (.c = if $y then $y.p else null end)]\n      end )"
    ],
    "data": [
      {
        "input": {
          "pri": [
            {
              "id": "a",
              "p": 5
            },
            {
              "id": "b",
              "p": 7
            },
            {
              "id": "c",
              "p": 8
            }
          ],
          "sec": [
            {
              "id": "a",
              "p": 9
            },
            {
              "id": "b",
              "p": 7
            },
            {
              "id": "d",
              "p": 4
            }
          ]
        },
        "output": [
          {
            "id": "a",
            "p": 5,
            "c": 9
          },
          {
            "id": "c",
            "p": 8,
            "c": null
          }
        ]
      }
    ],
    "identifier": 49040090
  },
  {
    "context": [
      "I want to filter this in order to have only the \"type\": \"filesystem\", and get the following output:",
      "But it destroys the original structure.",
      "jq '.BackupCfg |= map(select(.type == \"filesystem\"))' file.json",
      "The output:",
      "{\n  \"BackupCfg\": [\n    {\n      \"type\": \"filesystem\",\n      \"repository\": \"trunk\",\n      \"url\": \"test.example.com\",\n      \"port\": \"394\",\n      \"cfg\": [ ... ]\n    },\n    {\n      \"type\": \"filesystem\",\n      \"repository\": \"trunk02\",\n      \"url\": \"test.example.com\",\n      \"port\": \"394\",\n      \"cfg\": [ ... ]\n    }\n  ]\n}"
    ],
    "utterance": "Keep only the BackupCfg objects where type is exactly \"filesystem\", preserving the original structure.",
    "expressions": [
      ".BackupCfg |= map(select(.type == \"filesystem\"))"
    ],
    "data": [
      {
        "input": {
          "BackupCfg": [
            {
              "type": "filesystem",
              "repository": "trunk",
              "url": "test.example.com",
              "port": "394",
              "cfg": [
                {
                  "Default": "true",
                  "ID": "trunk00",
                  "Paths": [
                    "/etc",
                    "/home",
                    "/var",
                    "/usr/local",
                    "/opt",
                    "/root"
                  ],
                  "Cron": "33 0 * * *"
                }
              ]
            },
            {
              "type": "filesystem",
              "repository": "trunk02",
              "url": "test.example.com",
              "port": "394",
              "cfg": [
                {
                  "ID": "trunk01",
                  "Paths": [
                    "/opt/example",
                    "/opt/var_example"
                  ],
                  "Cron": "*/30 0-23 * * *"
                }
              ]
            },
            {
              "type": "database",
              "repository": "trunk-db",
              "url": "test.example.com",
              "port": "399",
              "cfg": [
                {
                  "Default": "true",
                  "ID": "trunk00",
                  "db_type": "mysql",
                  "db_hostname": "localhost",
                  "db_port": "3306",
                  "db_user": "root",
                  "db_pwd": "password",
                  "databases": [],
                  "Cron": "40 0 * * *"
                },
                {
                  "ID": "trunk01",
                  "db_type": "mysql",
                  "db_hostname": "localhost",
                  "db_port": "3307",
                  "db_user": "riit",
                  "db_pwd": "passwird",
                  "databases": [],
                  "Cron": "33 3 * * *"
                },
                {
                  "Default": "false",
                  "ID": "trunk02",
                  "db_type": "postgres",
                  "db_hostname": "localhost",
                  "db_port": "3308",
                  "db_user": "ruut",
                  "db_pwd": "passwurd",
                  "databases": [],
                  "Cron": "0 10 * * *"
                }
              ]
            }
          ]
        },
        "output": {
          "BackupCfg": [
            {
              "type": "filesystem",
              "repository": "trunk",
              "url": "test.example.com",
              "port": "394",
              "cfg": [
                {
                  "Default": "true",
                  "ID": "trunk00",
                  "Paths": [
                    "/etc",
                    "/home",
                    "/var",
                    "/usr/local",
                    "/opt",
                    "/root"
                  ],
                  "Cron": "33 0 * * *"
                }
              ]
            },
            {
              "type": "filesystem",
              "repository": "trunk02",
              "url": "test.example.com",
              "port": "394",
              "cfg": [
                {
                  "ID": "trunk01",
                  "Paths": [
                    "/opt/example",
                    "/opt/var_example"
                  ],
                  "Cron": "*/30 0-23 * * *"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 48997962
  },
  {
    "context": [
      "I would like to merge two files containing JSON. They each contain an array of JSON objects.",
      "In the ideal scenario, I would like to have the following as a result of the merge operation:",
      "[ { \"name\": \"User1\", \"editcount\": 164, \"registration\": \"2009-04-18T21:55:40Z\" }, { \"name\": \"User2\", \"editcount\": 150, \"registration\": \"2010-11-17T15:09:43Z\" } ]",
      "jq -s '[ .[0] + .[1] | group_by(.name)[] | select(length > 1) | add ]' registration.json useredits.json",
      "The output:",
      "[ { \"name\": \"User1\", \"registration\": \"2009-04-18T21:55:40Z\", \"editcount\": 164 }, { \"name\": \"User2\", \"registration\": \"2010-11-17T15:09:43Z\", \"editcount\": 150 } ]"
    ],
    "utterance": "Merge two arrays of objects from separate files by matching on the name field, keeping only entries where a matching name exists in both files and combining their properties.",
    "expressions": [
      "[ .[0] + .[1] | group_by(.name)[] | select(length > 1) | add ]"
    ],
    "data": [
      {
        "input": [
          [
            {
              "name": "User1",
              "registration": "2009-04-18T21:55:40Z"
            },
            {
              "name": "User2",
              "registration": "2010-11-17T15:09:43Z"
            }
          ],
          [
            {
              "name": "User1",
              "editcount": 164
            },
            {
              "name": "User2",
              "editcount": 150
            },
            {
              "name": "User3",
              "editcount": 10
            }
          ]
        ],
        "output": [
          {
            "name": "User1",
            "editcount": 164,
            "registration": "2009-04-18T21:55:40Z"
          },
          {
            "name": "User2",
            "editcount": 150,
            "registration": "2010-11-17T15:09:43Z"
          }
        ]
      }
    ],
    "identifier": 49037956
  },
  {
    "context": [
      "I want to promote a value from inside an array element to be the parent key for the entire element.",
      "To start with, I wanted to just add .name as a parent key to each entry. But this doesnt' work:\n\n`jq 'map(.name: {.})'`",
      "The key is to wrap parentheses around `.name` to form the new key:\n\n    map( {(.name): del(.name)} )"
    ],
    "utterance": "Convert an array of objects into an object keyed by each element's 'name' property, using the rest of the object as the value.",
    "expressions": [
      "map({(.name): del(.name)}) | add"
    ],
    "data": [
      {
        "input": [
          {
            "name": "foo",
            "value1": "fooval1",
            "value2": "fooval2"
          },
          {
            "name": "bar",
            "value1": "barval1",
            "value2": "barval2"
          }
        ],
        "output": {
          "foo": {
            "value1": "fooval1",
            "value2": "fooval2"
          },
          "bar": {
            "value1": "barval1",
            "value2": "barval2"
          }
        }
      }
    ],
    "identifier": 49059107
  },
  {
    "context": [
      "1. Replace an child object value with another value, at any depth, having parents objects or arrays, for example:\n    - if .spec.template.spec.containers[n].env[n].name == \"CHANGEME\" then\n    - .spec.template.spec.containers[n].env[n].value = \"xx\"\n    - where n >=0",
      "2. 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",
      "The result will be that all objects that do not exist already will be created.",
      "jq -r '{name:\"CHANGEME\",value: \"xx\"} as $v |\n    map( when(.kind == \"StatefulSet\";\n              .spec.template.spec.containers|arr|.env|arr(.name==$v.name)) |= $v)'"
    ],
    "utterance": "Update the value to \"xx\" for any object where the name is \"CHANGEME\", ensuring all necessary parent objects and arrays are created if missing.",
    "expressions": [
      "{name:\"CHANGEME\",value: \"xx\"} as $v | map( when(.kind == \"StatefulSet\"; .spec.template.spec.containers|arr|.env|arr(.name==$v.name)) |= $v)"
    ],
    "data": [
      {
        "input": [
          {
            "kind": "StatefulSet",
            "spec": {
              "serviceName": "cassandra",
              "template": {
                "spec": {
                  "containers": [
                    {
                      "name": "cassandra",
                      "env": [
                        {
                          "name": "CASSANDRA_SEEDS",
                          "value": "cassandra-0.cassandra.kong.svc.cluster.local"
                        },
                        {
                          "name": "CHANGEME",
                          "value": "K8"
                        }
                      ]
                    }
                  ]
                }
              }
            }
          }
        ],
        "output": [
          {
            "kind": "StatefulSet",
            "spec": {
              "serviceName": "cassandra",
              "template": {
                "spec": {
                  "containers": [
                    {
                      "name": "cassandra",
                      "env": [
                        {
                          "name": "CASSANDRA_SEEDS",
                          "value": "cassandra-0.cassandra.kong.svc.cluster.local"
                        },
                        {
                          "name": "CHANGEME",
                          "value": "xx"
                        }
                      ]
                    }
                  ]
                }
              }
            }
          }
        ]
      }
    ],
    "identifier": 49014616
  },
  {
    "context": [
      "I want a jq query which can replace a JSON key with the given value in the JSON file. something like that,",
      "jq -r --arg var1 $var1 --arg var2 $var2 '(.[].appId=$var1-$var2)' service.json",
      "But i want the variable to be replaced with `$var1-$var2` as a string.",
      "appId value should be replaced with \"root-webserver\"",
      "I recommend to use [String interpolation][1]. It will automatically cast input to a string:",
      "jq -r --arg var1 $var1 --arg var2 $var2 '(.[].appId=\"\\($var1)-\\($var2)\")' service.json"
    ],
    "utterance": "Update the value of the appId key in each object to the concatenation of the variables var1, a hyphen, and var2, e.g., 'root-webserver'.",
    "expressions": [
      "(.[].appId=\"\\($var1)-\\($var2)\")"
    ],
    "data": [
      {
        "input": [
          {
            "appId": "Eternal Flame",
            "age": 1000000,
            "secretIdentity": "Unknown",
            "powers": [
              "Immortality",
              "Heat Immunity",
              "Inferno",
              "Teleportation",
              "Interdimensional travel"
            ]
          }
        ],
        "output": [
          {
            "appId": "root-webserver",
            "age": 1000000,
            "secretIdentity": "Unknown",
            "powers": [
              "Immortality",
              "Heat Immunity",
              "Inferno",
              "Teleportation",
              "Interdimensional travel"
            ]
          }
        ]
      }
    ],
    "identifier": 49048412
  },
  {
    "context": [
      "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.",
      "If you just want the key name, you could instead write:\n\nto_entries | max_by(.value.lastupdated) | .key"
    ],
    "utterance": "Find the ID of the most recently updated scene with a given name, based on the lastupdated field.",
    "expressions": [
      "to_entries | map(select(.value.name == $SCENENAME)) | max_by(.value.lastupdated) | .key"
    ],
    "data": [
      {
        "input": {
          "FUX9A2m4LcuF6YG": {
            "name": "KitchenDay",
            "lastupdated": "2018-02-25T03:35:57"
          },
          "later": {
            "name": "KitchenNight",
            "lastupdated": "2018-02-25T23:35:57"
          },
          "ABCD1234": {
            "name": "KitchenDay",
            "lastupdated": "2018-03-01T10:22:31"
          }
        },
        "output": "ABCD1234"
      }
    ],
    "identifier": 49062033
  },
  {
    "context": [
      "How can one write a jq query that will extract a property from an element that may appear as singleton or list?",
      "extract the URL property from the creator in both example JSON strings below.",
      "I 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?",
      "One possibility that is very straightforward is simply to test whether .creator is an array or not:",
      "if .creator|type == \"array\" then .creator[] else .creator end | .url"
    ],
    "utterance": "Extract the url property from the creator element, which may be either an object or an array of objects.",
    "expressions": [
      "if .creator|type == \"array\" then .creator[] else .creator end | .url"
    ],
    "data": [
      {
        "input": {
          "@type": "example1",
          "creator": {
            "@type": "Organization",
            "url": "https://www.ncei.noaa.gov/"
          }
        },
        "output": "https://www.ncei.noaa.gov/"
      },
      {
        "input": {
          "@type": "example2",
          "creator": [
            {
              "@type": "Person",
              "url": "https://www.example.com/homepage"
            },
            {
              "url": "https://www.example.com/another"
            }
          ]
        },
        "output": [
          "https://www.example.com/homepage",
          "https://www.example.com/another"
        ]
      }
    ],
    "identifier": 49064828
  },
  {
    "context": [
      "I have a text file `data.txt`: \r\n\r\n    Framework1,Version1\r\n    Framework2,Version2\r\n    Framework3,Version3",
      "I need to convert it to `data.json` which would look like:\r\n\r\n    [\r\n    {\"FrameworkName\":\"Framework1\", \"VersionName\":\"Version1\"},\r\n    {\"FrameworkName\":\"Framework3\", \"VersionName\":\"Version2\"},\r\n    {\"FrameworkName\":\"Framework3\", \"VersionName\":\"Version3\"}\r\n    ]",
      "jq -Rs '[ split(\"\\n\")[] | select(length > 0) \r\n          | split(\",\") | {FrameworkName: .[0], VersionName: .[1]} ]' data.txt",
      "The output:\r\n\r\n    [\r\n      {\r\n        \"FrameworkName\": \"Framework1\",\r\n        \"VersionName\": \"Version1\"\r\n      },\r\n      {\r\n        \"FrameworkName\": \"Framework2\",\r\n        \"VersionName\": \"Version2\"\r\n      },\r\n      {\r\n        \"FrameworkName\": \"Framework3\",\r\n        \"VersionName\": \"Version3\"\r\n      }\r\n    ]"
    ],
    "utterance": "Convert a text file containing lines of values separated by commas into an array of objects with fields FrameworkName and VersionName, mapping each line's first and second value respectively.",
    "expressions": [
      "jq -Rs '[ split(\"\\n\")[] | select(length > 0) | split(\",\") | {FrameworkName: .[0], VersionName: .[1]} ]'"
    ],
    "data": [
      {
        "input": "Framework1,Version1\nFramework2,Version2\nFramework3,Version3",
        "output": [
          {
            "FrameworkName": "Framework1",
            "VersionName": "Version1"
          },
          {
            "FrameworkName": "Framework2",
            "VersionName": "Version2"
          },
          {
            "FrameworkName": "Framework3",
            "VersionName": "Version3"
          }
        ]
      }
    ],
    "identifier": 49067568
  },
  {
    "context": [
      "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.",
      "{\n  \"kubectl.kubernetes.io\\last-applied-configuration\": \"test\"\n}",
      "$ cat /tmp/yo | jq .[\"kubectl.kubernetes.io\\last-applied-configuration\"]",
      "parse error: Invalid escape at line 2, column 52",
      "To include a backslash in JSON would instead look like:\n\n    {\n      \"kubectl.kubernetes.io\\\\last-applied-configuration\": \"test\"\n    }",
      "If you had such a valid document, you could then use:\n\n    jq '[\"kubectl.kubernetes.io\\\\last-applied-configuration\"]' </tmp/yo"
    ],
    "utterance": "Access the value of an object property whose key contains a backslash: 'kubectl.kubernetes.io\\last-applied-configuration'.",
    "expressions": [
      ".[\"kubectl.kubernetes.io\\\\last-applied-configuration\"]"
    ],
    "data": [
      {
        "input": {
          "kubectl.kubernetes.io\\last-applied-configuration": "test"
        },
        "output": "test"
      }
    ],
    "identifier": 49073376
  },
  {
    "context": [
      "Goal is to have 1 space replace any occurrence of multiple whitespace of any kind.",
      "echo \"low quality      not gonna apologize\" | jq -Rr 'gsub(\"\\\\s+\";\" \";\"g\")'",
      "$ echo '\"low quality      not gonna apologize\"' | jq -r 'gsub(\"\\\\s+\"; \" \")'",
      "$ jq -n --arg in \"low quality      not gonna apologize\" '$in | gsub(\"\\\\s+\"; \" \")'",
      "The output:\n\n    low quality not gonna apologize"
    ],
    "utterance": "Replace any sequence of multiple whitespace characters with a single space in a string.",
    "expressions": [
      "gsub(\"\\s+\"; \" \")",
      "jq -Rr 'gsub(\"\\s+\";\" \")'",
      "jq -r 'gsub(\"\\s+\"; \" \")'",
      "$in | gsub(\"\\s+\"; \" \")"
    ],
    "data": [
      {
        "input": "low quality      not gonna apologize",
        "output": "low quality not gonna apologize"
      }
    ],
    "identifier": 49087991
  },
  {
    "context": [
      "Is it possible to sort_by GroupName and then for each group by Permissions Port using a single command?",
      "jq '[0].SG |= (map(.Permissions |= sort_by(.Port)) | sort_by(.GroupName))' myfile.json",
      "- `map(.Permissions |= sort_by(.Port))` - get a new array where each internal `.Permissions` array is sorted by key `\"Port\"` value",
      "- `sort_by(.GroupName)` - sort `SG` array items by `\"GroupName\"` key"
    ],
    "utterance": "Sort the SG array by GroupName, and within each group, sort its Permissions by Port.",
    "expressions": [
      ".[0].SG |= (map(.Permissions |= sort_by(.Port)) | sort_by(.GroupName))"
    ],
    "data": [
      {
        "input": [
          {
            "SG": [
              {
                "Id": "17",
                "GroupName": "fistGN",
                "Permissions": [
                  {
                    "Port": 80,
                    "Protocol": "tcp"
                  },
                  {
                    "Port": 8080,
                    "Protocol": "tcp"
                  },
                  {
                    "Port": 5080,
                    "Protocol": "tcp"
                  }
                ]
              },
              {
                "Id": "1",
                "GroupName": "secondGN",
                "Permissions": [
                  {
                    "Port": 80,
                    "Protocol": "tcp"
                  },
                  {
                    "Port": 8080,
                    "Protocol": "tcp"
                  },
                  {
                    "Port": 5080,
                    "Protocol": "tcp"
                  }
                ]
              }
            ]
          }
        ],
        "output": [
          {
            "SG": [
              {
                "Id": "17",
                "GroupName": "fistGN",
                "Permissions": [
                  {
                    "Port": 80,
                    "Protocol": "tcp"
                  },
                  {
                    "Port": 5080,
                    "Protocol": "tcp"
                  },
                  {
                    "Port": 8080,
                    "Protocol": "tcp"
                  }
                ]
              },
              {
                "Id": "1",
                "GroupName": "secondGN",
                "Permissions": [
                  {
                    "Port": 80,
                    "Protocol": "tcp"
                  },
                  {
                    "Port": 5080,
                    "Protocol": "tcp"
                  },
                  {
                    "Port": 8080,
                    "Protocol": "tcp"
                  }
                ]
              }
            ]
          }
        ]
      }
    ],
    "identifier": 49068190
  },
  {
    "context": [
      "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?",
      "It is quite simple when using [`jq`](https://stedolan.github.io/jq/manual/) using the `map()` call.",
      "jq 'map(del(.age))' < json",
      "Using `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."
    ],
    "utterance": "Remove the age key from every object in the top-level array in a single step.",
    "expressions": [
      "map(del(.age))"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "name": "Arthur",
            "age": "21"
          },
          {
            "id": 2,
            "name": "Richard",
            "age": "32"
          }
        ],
        "output": [
          {
            "id": 1,
            "name": "Arthur"
          },
          {
            "id": 2,
            "name": "Richard"
          }
        ]
      }
    ],
    "identifier": 49127676
  },
  {
    "context": [
      "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.",
      "I have tried combinations of ...",
      "all give errors of a similar nature `jq: error (at <stdin>:1): number (0) cannot be matched, as it is not a string`",
      "In the following, I'll assume you want to add \"ADDITIONAL\" to the array at EVERY key that matches a given regex (here \"ccc\"):",
      "walk(if type == \"object\"\n         then with_entries(if (.key|test(\"ccc\"))\n                           then .value += [\"ADDITIONAL\"] else . end)\n         else . end)",
      "If 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]",
      "Alternative formulation",
      "If you have the following general-purpose helper function handy ...",
      "def when(filter; action): if (filter?) // null then action else . end;",
      "walk(when(type == \"object\";\n         with_entries(when(.key|test(\"ccc\"); .value += [\"ADDITIONAL\"]))))"
    ],
    "utterance": "Add an object to every array at all keys matching 'ccc', regardless of their depth or unknown parent keys.",
    "expressions": [
      "walk(if type == \"object\" then with_entries(if (.key|test(\"ccc\")) then .value += [\"ADDITIONAL\"] else . end) else . end)",
      "def when(filter; action): if (filter?) // null then action else . end; walk(when(type == \"object\"; with_entries(when(.key|test(\"ccc\"); .value += [\"ADDITIONAL\"]))))"
    ],
    "data": [
      {
        "input": {
          "zzz": [
            {
              "id": "aaa",
              "des": "object A",
              "parent": "zzz",
              "children": {
                "aaa": [
                  {
                    "id": "bbb",
                    "des": "object B",
                    "parent": "aaa",
                    "children": {
                      "bbb": [
                        {
                          "id": "ccc",
                          "des": "object C",
                          "parent": "bbb",
                          "children": {
                            "ccc": [
                              {
                                "id": "ddd",
                                "des": "object d",
                                "parent": "ccc"
                              }
                            ]
                          }
                        },
                        {
                          "id": "eee",
                          "des": "object e",
                          "parent": "bbb"
                        }
                      ]
                    }
                  },
                  {
                    "id": "fff",
                    "des": "object f",
                    "parent": "aaa"
                  }
                ]
              }
            }
          ]
        }
      }
    ],
    "identifier": 49117626
  },
  {
    "context": [
      "Can I modify this so that `strftime(\"%B %d %Y %I:%M%p %Z\")` only applies to the `.tickTimestmap` value?",
      "Simply use parentheses:\r\n\r\n     (.tickTimestamp | strftime(\"%B %d %Y %I:%M%p %Z\"))"
    ],
    "utterance": "Output the fields highPrice, lowPrice, openPrice, closePrice, volumeTradedToday, totalBuyQuantity, totalSellQuantity as-is, and convert tickTimestamp to formatted date string using strftime",
    "expressions": [
      "[.highPrice, .lowPrice, .openPrice, .closePrice, .volumeTradedToday, .totalBuyQuantity, .totalSellQuantity, (.tickTimestamp | strftime(\"%B %d %Y %I:%M%p %Z\"))]"
    ],
    "data": [
      {
        "input": {
          "mode": "full",
          "tradable": false,
          "instrumentToken": 2997505,
          "lastTradedPrice": 740.0,
          "highPrice": 0.0,
          "lowPrice": 0.0,
          "openPrice": 731.5,
          "closePrice": 739.9,
          "change": 0.01351533991080183,
          "lastTradedQuantity": 23.0,
          "averageTradePrice": 0.0,
          "volumeTradedToday": 12.0,
          "totalBuyQuantity": 285.0,
          "totalSellQuantity": 1469.0,
          "lastTradedTime": 1520245282000,
          "oi": 0.0,
          "tickTimestamp": 1520307004000,
          "openInterestDayHigh": 0.0,
          "openInterestDayLow": 0.0,
          "marketDepth": {
            "buy": [
              {
                "quantity": 1,
                "price": 735.55,
                "orders": 1
              },
              {
                "quantity": 86,
                "price": 731.5,
                "orders": 1
              },
              {
                "quantity": 168,
                "price": 731.0,
                "orders": 1
              },
              {
                "quantity": 25,
                "price": 730.1,
                "orders": 1
              },
              {
                "quantity": 0,
                "price": 0.0,
                "orders": 0
              }
            ],
            "sell": [
              {
                "quantity": 550,
                "price": 743.6,
                "orders": 1
              },
              {
                "quantity": 550,
                "price": 746.6,
                "orders": 1
              },
              {
                "quantity": 10,
                "price": 750.0,
                "orders": 1
              },
              {
                "quantity": 25,
                "price": 777.0,
                "orders": 1
              },
              {
                "quantity": 12,
                "price": -0.01,
                "orders": 1
              }
            ]
          }
        }
      }
    ],
    "identifier": 49131125
  },
  {
    "context": [
      "if I use the `jq` code to parser it like below:\n\n    cat test.json | jq -r '.employees[2].division'\n\nit will work well and give a correct result:\n\n    Marketing * test",
      "but I use `$()`, the bad thing will happen!\n\necho $(cat test.json | jq -r '.employees[2].division')\n\nthe result will list all file names under current folder! like:\n\n    my1.json my2.json test.json test ...",
      "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",
      "result=\"$(jq -r '.employees[2].division' < test.json)\"\necho \"$result\""
    ],
    "utterance": "Get the value of the third employee's division, including an asterisk, treating it as a literal string in the output.",
    "expressions": [
      ".employees[2].division"
    ],
    "data": [
      {
        "input": {
          "name": "Google",
          "location": {
            "street": "1600 Amphitheatre Parkway",
            "city": "Mountain View",
            "state": "California",
            "country": "US"
          },
          "employees": [
            {
              "name": "Michael",
              "division": "Engineering"
            },
            {
              "name": "Laura",
              "division": "HR"
            },
            {
              "name": "Elise",
              "division": "Marketing * test"
            }
          ]
        },
        "output": "Marketing * test"
      }
    ],
    "identifier": 49125451
  },
  {
    "context": [
      "I am trying to find way how to extract only document from following array if finalStatus != null.",
      "I have tried `select(.[].finalStatus != null)`but without success. still I am getting both lines.",
      "Try:",
      "map(select(.finalStatus != null))"
    ],
    "utterance": "Return all elements from the array where finalStatus is not null.",
    "expressions": [
      "map(select(.finalStatus != null))"
    ],
    "data": [
      {
        "input": [
          {
            "_type": "http",
            "uri": "/rest/eFulfillment/V1/stock/5117855/OHK30",
            "status": 200,
            "statustext": "OK",
            "method": "GET",
            "vhost": null,
            "wafStatus": 0,
            "bytesSent": 0,
            "bytesReceived": 0,
            "remoteName": "connecte-esb-bat.dhl.com",
            "remoteAddr": "165.72.94.127",
            "localAddr": "165.72.1.236",
            "remotePort": "443",
            "localPort": "52842",
            "sslsubject": "/C=DE/ST=Nordrhein-Westfalen/L=Bonn/O=Deutsche Post AG/OU=ITSC/CN=connecte-esb-bat.dhl.com",
            "leg": 1,
            "timestamp": 1520235200649,
            "duration": 1099,
            "correlationId": "c0f29c5a3e484ba5419878db",
            "serviceName": "PeP e-Fulfillment API",
            "subject": "d006366e-3b9e-415f-baff-cc1eec24898a",
            "operation": "Get Available Stock",
            "type": "http",
            "finalStatus": null
          },
          {
            "_type": "http",
            "uri": "/efulfillment/v1/stock/5117855/OHK30",
            "status": 200,
            "statustext": "OK",
            "method": "GET",
            "vhost": null,
            "wafStatus": 0,
            "bytesSent": 0,
            "bytesReceived": 0,
            "remoteName": "165.72.87.12",
            "remoteAddr": "165.72.87.12",
            "localAddr": "165.72.1.236",
            "remotePort": "51946",
            "localPort": "6443",
            "sslsubject": null,
            "leg": 0,
            "timestamp": 1520235200642,
            "duration": 1107,
            "correlationId": "c0f29c5a3e484ba5419878db",
            "serviceName": "PeP e-Fulfillment API",
            "subject": "d006366e-3b9e-415f-baff-cc1eec24898a",
            "operation": "Get Available Stock",
            "type": "http",
            "finalStatus": "Pass"
          }
        ],
        "output": [
          {
            "_type": "http",
            "uri": "/efulfillment/v1/stock/5117855/OHK30",
            "status": 200,
            "statustext": "OK",
            "method": "GET",
            "vhost": null,
            "wafStatus": 0,
            "bytesSent": 0,
            "bytesReceived": 0,
            "remoteName": "165.72.87.12",
            "remoteAddr": "165.72.87.12",
            "localAddr": "165.72.1.236",
            "remotePort": "51946",
            "localPort": "6443",
            "sslsubject": null,
            "leg": 0,
            "timestamp": 1520235200642,
            "duration": 1107,
            "correlationId": "c0f29c5a3e484ba5419878db",
            "serviceName": "PeP e-Fulfillment API",
            "subject": "d006366e-3b9e-415f-baff-cc1eec24898a",
            "operation": "Get Available Stock",
            "type": "http",
            "finalStatus": "Pass"
          }
        ]
      }
    ],
    "identifier": 49105880
  },
  {
    "context": [
      "How can I only output the tuples for subreddit nfl?",
      "$ cat head_rc.txt | jq -r 'select(.subreddit==\"nfl\") .author'",
      "$ cat head_rc.txt | jq -r 'select(.subreddit==\"nfl\") .body, .author'",
      "jq -r 'select(.subreddit == \"nfl\") as $o | $o.body, $o.author' head_rc.txt",
      "the simplest solution to your selection problem is to use parentheses",
      "jq -r 'select(.subreddit==\"nfl\") | (.body, .author)' input.json",
      "select(.subreddit==\"nfl\") | [.body, .author] | @tsv"
    ],
    "utterance": "Output the body and author of all objects where subreddit equals nfl.",
    "expressions": [
      "select(.subreddit==\"nfl\") | (.body, .author)",
      "select(.subreddit==\"nfl\") as $o | $o.body, $o.author",
      "select(.subreddit==\"nfl\") | [.body, .author] | @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "author": "403and780",
            "subreddit": "hockey",
            "body": "Don't get why we do this but can't have a Grey Cup GDT."
          },
          {
            "author": "kygiacomo",
            "subreddit": "nfl",
            "body": "lol missed the extra wtf"
          },
          {
            "author": "shitpostlord4321",
            "subreddit": "marvelstudios",
            "body": "I really hope we get Bleeding Edge before we get the all new all different armor. "
          },
          {
            "author": "immortalis",
            "subreddit": "nfl",
            "body": "The ghost of MN kickers will haunt this game."
          },
          {
            "author": "Mimi108",
            "subreddit": "nfl",
            "body": "The Big. The Dick. The Nick. "
          }
        ],
        "output": [
          "lol missed the extra wtf",
          "kygiacomo",
          "The ghost of MN kickers will haunt this game.",
          "immortalis",
          "The Big. The Dick. The Nick. ",
          "Mimi108"
        ]
      }
    ],
    "identifier": 49074415
  },
  {
    "context": [
      "I 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`).",
      "it\u2019s also easy to remove a prefix in `jq`, so there\u2019s no particular reason to do the above:",
      "tail -f -- errors.log | jq -r '\n  def withoutPrefix: sub(\"^([/][^/]+){3}\"; \"\");\n  [.server_name, .server_port, (.request_file | withoutPrefix)] | @tsv'"
    ],
    "utterance": "Output server_name, server_port, and request_file, with request_file modified to remove the /var/www/domain.com prefix and show only the suffix path such as /www/public.",
    "expressions": [
      "def withoutPrefix: sub(\"^([/][^/]+){3}\"; \"\"); [.server_name, .server_port, (.request_file | withoutPrefix)] | @tsv"
    ],
    "identifier": 49142436
  },
  {
    "context": [
      "I have an array that ... has a set of objects that have a different \"title\" (wrapper), but its inside structure is shared by all the elements present into that array.",
      "I'll have on `attr3` only one truthy element, while the rest of the elements of `data` will have a `false` value on that element.",
      "Given that condition (`attr3 == true`), I need to filter that element and get the value of `attr2`.",
      "the filter:\r\n\r\n    .data[][] | select(.attr3) | .attr2\r\n\r\nproduces:\r\n\r\n    \"val2\""
    ],
    "utterance": "Return the value of attr2 from the object inside the data array where attr3 is true.",
    "expressions": [
      ".data[][] | select(.attr3) | .attr2"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "wrapper_1": {
                "attr1": "val1",
                "attr2": "val2",
                "attr3": true
              }
            },
            {
              "wrapper_2": {
                "attr1": "val1",
                "attr2": "val2",
                "attr3": false
              }
            },
            {
              "wrapper_3": {
                "attr1": "val1",
                "attr2": "val2",
                "attr3": false
              }
            }
          ]
        },
        "output": "val2"
      }
    ],
    "identifier": 49141718
  },
  {
    "context": [
      "How do I have jq return the entire json file excluding the json identified in the filter?",
      "del(.rules.children[].children[] | select(.name| contains(\"7004389c-c47a-4611-9bd7-9f5dfe051d17\")))",
      ".rules.children[].children |= \r\n  map(select((.name? // \"\")\r\n             | contains(\"7004389c-c47a-4611-9bd7-9f5dfe051d17\")\r\n             | not))"
    ],
    "utterance": "Remove all objects from .rules.children[].children[] whose name contains '7004389c-c47a-4611-9bd7-9f5dfe051d17', returning the entire updated structure.",
    "expressions": [
      "del(.rules.children[].children[] | select(.name| contains(\"7004389c-c47a-4611-9bd7-9f5dfe051d17\")))",
      ".rules.children[].children |= map(select((.name? // \"\") | contains(\"7004389c-c47a-4611-9bd7-9f5dfe051d17\") | not))"
    ],
    "identifier": 49143828
  },
  {
    "context": [
      "given 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.",
      "now using the `walk` function I can locate the key I want",
      "Now I want to capture the value of `id` not add to the object.",
      "What is the correct syntax to capture the `id` value?",
      "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(\"ccc\"))\r\n    | .value[]\r\n    | select(.parent==\"ccc\")\r\n    | .id",
      "produces:\r\n\r\n    \"ddd\""
    ],
    "utterance": "Extract the id value from the object whose parent is \"ccc\" and that is nested under a key named \"ccc\" at any depth.",
    "expressions": [
      ".. | objects | to_entries[] | select(.key|test(\"ccc\")) | .value[] | select(.parent==\"ccc\") | .id"
    ],
    "data": [
      {
        "input": {
          "zzz": [
            {
              "id": "aaa",
              "des": "object A",
              "parent": "zzz",
              "children": {
                "aaa": [
                  {
                    "id": "bbb",
                    "des": "object B",
                    "parent": "aaa",
                    "children": {
                      "bbb": [
                        {
                          "id": "ccc",
                          "des": "object C",
                          "parent": "bbb",
                          "children": {
                            "ccc": [
                              {
                                "id": "ddd",
                                "des": "object d",
                                "parent": "ccc"
                              }
                            ]
                          }
                        },
                        {
                          "id": "eee",
                          "des": "object e",
                          "parent": "bbb"
                        }
                      ]
                    }
                  },
                  {
                    "id": "fff",
                    "des": "object f",
                    "parent": "aaa"
                  }
                ]
              }
            }
          ]
        },
        "output": "ddd"
      }
    ],
    "identifier": 49139191
  },
  {
    "context": [
      "I would like to select any object (regardless of depth) that has an attribute \"id\", as well as the attribute name of the parent object.",
      "If an object does not have the \"id\" attribute it is not interesting and should not be selected.",
      "A 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.",
      "An example of the desired output would be:",
      "    [",
      "      {",
      "        \"type\": \"tags\",",
      "        \"node\": {",
      "          \"id\": \"tag-1\",",
      "          \"name\": \"Tag 1\"",
      "        }",
      "      },",
      "      {",
      "        \"type\": \"tags\",",
      "        \"node\": {",
      "          \"id\": \"tag-2\",",
      "          \"name\": \"Tag 2\"",
      "        }",
      "      },",
      "      ...",
      "    ]",
      "This works:",
      "[",
      "    foreach (paths | select(.[-1] == \"id\" and length > 1)[:-1]) as $path ({i:.};",
      "        .o = {",
      "            type: last($path[] | strings),",
      "            node: (.i | getpath($path))",
      "        };",
      "        .o",
      "    )",
      "]",
      "propose a shorter and hopefully sleeker version:",
      ". as $document",
      "| paths",
      "| select(length > 1 and .[-1] == \"id\")",
      "| .[0:-1] as $path",
      "| { \"type\": last($path[] | strings),",
      "    \"node\": $document | getpath($path) }"
    ],
    "utterance": "Find all objects at any depth that contain an \"id\" attribute, and for each, return both the object and the immediate parent attribute name, associating array elements with their attribute name.",
    "expressions": [
      "[foreach (paths | select(.[-1] == \"id\" and length > 1)[:-1]) as $path ({i:.}; .o = {type: last($path[] | strings), node: (.i | getpath($path))}; .o)]",
      ". as $document | paths | select(length > 1 and .[-1] == \"id\") | .[0:-1] as $path | { \"type\": last($path[] | strings), \"node\": $document | getpath($path) }",
      "[. as $document | paths | select(length > 1 and .[-1] == \"id\") | .[0:-1] as $path | { \"type\": last($path[] | strings), \"node\": $document | getpath($path) }]"
    ],
    "data": [
      {
        "input": {
          "id": "post-1",
          "type": "blog-post",
          "tags": [
            {
              "id": "tag-1",
              "name": "Tag 1"
            },
            {
              "id": "tag-2",
              "name": "Tag 2"
            }
          ],
          "heading": "Post 1",
          "body": "this is my first blog post",
          "links": [
            {
              "id": "post-2",
              "heading": "Post 2",
              "tags": [
                {
                  "id": "tag-1",
                  "name": "Tag 1"
                },
                {
                  "id": "tag-3",
                  "name": "Tag 3"
                }
              ]
            }
          ],
          "metadata": {
            "user": {
              "social": [
                {
                  "id": "twitter",
                  "handle": "@user"
                },
                {
                  "id": "facebook",
                  "handle": "123456"
                },
                {
                  "id": "youtube",
                  "handle": "ABC123xyz"
                }
              ]
            },
            "categories": [
              {
                "name": "Category 1"
              },
              {
                "name": "Category 2"
              }
            ]
          }
        },
        "output": [
          {
            "type": "tags",
            "node": {
              "id": "tag-1",
              "name": "Tag 1"
            }
          },
          {
            "type": "tags",
            "node": {
              "id": "tag-2",
              "name": "Tag 2"
            }
          },
          {
            "type": "links",
            "node": {
              "id": "post-2",
              "heading": "Post 2",
              "tags": [
                {
                  "id": "tag-1",
                  "name": "Tag 1"
                },
                {
                  "id": "tag-3",
                  "name": "Tag 3"
                }
              ]
            }
          },
          {
            "type": "tags",
            "node": {
              "id": "tag-1",
              "name": "Tag 1"
            }
          },
          {
            "type": "tags",
            "node": {
              "id": "tag-3",
              "name": "Tag 3"
            }
          },
          {
            "type": "social",
            "node": {
              "id": "twitter",
              "handle": "@user"
            }
          },
          {
            "type": "social",
            "node": {
              "id": "facebook",
              "handle": "123456"
            }
          },
          {
            "type": "social",
            "node": {
              "id": "youtube",
              "handle": "ABC123xyz"
            }
          }
        ]
      }
    ],
    "identifier": 48888057
  },
  {
    "context": [
      "How to compare current datetime with each output and if it's older than 3 hours to print \"old\"?",
      "you can use the built-in date manipulation functions to print the old records with something like",
      "jq -r '(now-3600*3) as $when | .issues[] |\n  select(.fields.created | strptime(\"%Y-%m-%dT%H:%M:%S.000+0000\") | mktime < $when) |\n[.id, .fields.created, \"old\"]' 1.json"
    ],
    "utterance": "Select issues whose 'fields.created' datetime is older than 3 hours compared to now, and print their id, created datetime, and the string 'old'.",
    "expressions": [
      "(now-3600*3) as $when | .issues[] | select(.fields.created | strptime(\"%Y-%m-%dT%H:%M:%S.000+0000\") | mktime < $when) | [.id, .fields.created, \"old\"]"
    ],
    "data": [
      {
        "input": {
          "issues": [
            {
              "id": 1,
              "fields": {
                "created": "2018-03-06T21:24:41.000+0000"
              }
            },
            {
              "id": 2,
              "fields": {
                "created": "2018-03-06T22:48:47.000+0000"
              }
            },
            {
              "id": 3,
              "fields": {
                "created": "2018-03-09T22:48:47.000+0000"
              }
            }
          ]
        }
      }
    ],
    "identifier": 49145205
  },
  {
    "context": [
      "How should I edit this command the get all args (args1, args2 and args3) values (\"tail\" \"-f\" \"/dev/null\")",
      "jq -r 'yourfilter | to_entries \n       | map(select(.key | test(\"^args[0-9]+\")).value) | @tsv' testTab.json"
    ],
    "utterance": "Extract all values whose keys match the pattern 'args' followed by a number, such as args1, args2, args3.",
    "expressions": [
      "to_entries | map(select(.key | test(\"^args[0-9]+\")).value) | @tsv"
    ],
    "data": [
      {
        "input": {
          "image": "ubuntu:latest",
          "args1": "tail",
          "args2": "-f",
          "args3": "/dev/null",
          "mounts": {
            "source": "/home/testVolume",
            "target": "/opt"
          },
          "dns_config": null
        },
        "output": "tail\t-f\t/dev/null"
      }
    ],
    "identifier": 49176069
  },
  {
    "context": [
      "Given a bash array, how to convert it to a JSON array in order to output to a file with jq?",
      "Desired output:",
      "{\r\n\t\"client_nohup\": [\r\n\t\t100,\r\n\t\t200,\r\n\t\t300\r\n\t],\r\n\t\"server_nohup\": []\r\n\t}",
      "you can use it in conjunction with the built-in $ARGS pseudo-variable, as illustrated by this example:\r\n$ jq -c -n '$ARGS.positional' --args \"${output[@]}\"",
      "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\nnewArray=(100 200 300)\r\necho \"${newArray[@]}\" |\r\n  jq -s '{client_nohup: ., server_nohup: []}'",
      "You might wish to convert numeric strings to JSON numbers, e.g. using the jq idiom: (tonumber? // .)"
    ],
    "utterance": "Convert a bash array containing numbers into an array of numbers under the key client_nohup, with server_nohup as an empty array.",
    "expressions": [
      "echo \"${newArray[@]}\" | jq -s '{client_nohup: map(tonumber? // .), server_nohup: []}'"
    ],
    "data": [
      {
        "input": "[100, 200, 300]",
        "output": {
          "client_nohup": [
            100,
            200,
            300
          ],
          "server_nohup": []
        }
      }
    ],
    "identifier": 49184557
  },
  {
    "context": [
      "I need to replace part of a value from a json output.",
      "I need to replace the dash \"-\" on the LastModified value to a slash, then remove some stuff too like the \"T\" and the \".000Z\" So I can eventually convert that timestamp to epoch.",
      "With **jq**'s `sub()` and `fromdate()` functions:",
      "jq '.LastModified |= (sub(\"\\\\.000Z\";\"Z\") | fromdate)' input.json",
      ".LastModified |= (sub(\"\\\\.000Z$\"; \"Z\") | fromdateiso8601 | strftime(\"%Y/%m/%d %H:%M:%S\"))",
      ".LastModified |= \"\\(.[:10] | sub(\"-\"; \"/\"; \"g\")) \\(.[11:19])\""
    ],
    "utterance": "Replace dashes with slashes in LastModified, remove 'T' and '.000Z', and reformat the timestamp as 'YYYY/MM/DD HH:MM:SS'.",
    "expressions": [
      ".LastModified |= (sub(\"\\\\.000Z$\"; \"Z\") | fromdateiso8601 | strftime(\"%Y/%m/%d %H:%M:%S\"))",
      ".LastModified |= \"\\(.[:10] | sub(\"-\"; \"/\"; \"g\")) \\(.[11:19])\""
    ],
    "data": [
      {
        "input": {
          "LastModified": "2018-03-07T17:24:33.000Z",
          "Key": "pending/archive/f7ab1684-e94d-483e-ace1-560367c1196c_1000_s.json"
        },
        "output": {
          "LastModified": "2018/03/07 17:24:33",
          "Key": "pending/archive/f7ab1684-e94d-483e-ace1-560367c1196c_1000_s.json"
        }
      }
    ],
    "identifier": 49181898
  },
  {
    "context": [
      "Specifically, I'd like to search for 'imageTags' where an item in the array is \"mytest1\". Returning output should be the dictionary block.",
      ".imageDetails[] | select(any(.imageTags[]; . == \"mytest1\"))"
    ],
    "utterance": "Return objects where any element in imageTags equals \"mytest1\".",
    "expressions": [
      ".imageDetails[] | select(any(.imageTags[]; . == \"mytest1\"))"
    ],
    "data": [
      {
        "input": {
          "imageDetails": [
            {
              "imageSizeInBytes": 2066961,
              "imageDigest": "sha256:ff089cca12407adce49e70771a32c2fd48d53d8d3fb735cee430037e6b27c535123",
              "imageTags": [
                "test",
                "latest"
              ],
              "registryId": "98654010662132",
              "repositoryName": "testrepository",
              "imagePushedAt": 1520462286
            },
            {
              "imageSizeInBytes": 2066961,
              "imageDigest": "sha256:c30974de3423250382f5b33be01103c11de73459ceaedd789dff9b461532eb2dd55",
              "imageTags": [
                "test3"
              ],
              "registryId": "98654010662132",
              "repositoryName": "testrepository",
              "imagePushedAt": 1520462305
            },
            {
              "imageSizeInBytes": 2066961,
              "imageDigest": "sha256:05048eb6cc559e953e6c98afa0e71fd836c37a34563531487af2b5d1c9430570ff9",
              "imageTags": [
                "mytest1",
                "mytest2",
                "mytest3"
              ],
              "registryId": "98654010662132",
              "repositoryName": "testrepository",
              "imagePushedAt": 1520459886
            },
            {
              "imageSizeInBytes": 2066961,
              "imageDigest": "sha256:bf23ada8a14d1c70c476b4f39b9b849fd5191d8fc419312b3d1b8f59aa182b050e6",
              "imageTags": [
                "test3-latest"
              ],
              "registryId": "98654010662132",
              "repositoryName": "testrepository",
              "imagePushedAt": 1520462305
            },
            {
              "imageSizeInBytes": 2066961,
              "imageDigest": "sha256:a040f335556e783930905d0b7bd9f55f1400a2778e39983c3d1e3cc41643c090ee0",
              "imageTags": [
                "test2"
              ],
              "registryId": "98654010662132",
              "repositoryName": "testrepository",
              "imagePushedAt": 1520462304
            }
          ]
        },
        "output": {
          "imageSizeInBytes": 2066961,
          "imageDigest": "sha256:05048eb6cc559e953e6c98afa0e71fd836c37a34563531487af2b5d1c9430570ff9",
          "imageTags": [
            "mytest1",
            "mytest2",
            "mytest3"
          ],
          "registryId": "98654010662132",
          "repositoryName": "testrepository",
          "imagePushedAt": 1520459886
        }
      }
    ],
    "identifier": 49162956
  },
  {
    "context": [
      "I&#39;ve tried to get linux list of my all files and directories in specified path to json format using ls and jq.",
      "Is it possible to build output like above in the picture?",
      "find . -ls | jq -nR '\n  # Return an object with useful information\n  def gather:\n    [splits(\" +\")] as $in\n    | { pathname: $in[-1], entrytype: $in[2][0:1], size: ($in[6] | tonumber) };\n\n  reduce (inputs | gather) as $entry ({};\n      ($entry.pathname | split(\"/\")) as $names\n      | if ($entry|.entrytype == \"-\") then\n           ($names[0:-1] + [\"items\"]) as $p\n           | setpath($p; getpath($p) + [{name: $names[-1], size: $entry.size}])\n        else . end) '"
    ],
    "utterance": "Get a nested representation of all files and directories in a specified path, where files are listed with their names and sizes within their respective directories.",
    "expressions": [
      "find . -ls | jq -nR '\n  def gather:\n    [splits(\" +\")] as $in\n    | { pathname: $in[-1], entrytype: $in[2][0:1], size: ($in[6] | tonumber) };\n  reduce (inputs | gather) as $entry ({};\n      ($entry.pathname | split(\"/\")) as $names\n      | if ($entry|.entrytype == \"-\") then\n           ($names[0:-1] + [\"items\"]) as $p\n           | setpath($p; getpath($p) + [{name: $names[-1], size: $entry.size}])\n        else . end) '"
    ],
    "data": [
      {
        "input": [
          "  131336    4 drwxr-xr-x   3 user user    4096 Nov  4 21:03 .",
          "  131338    4 drwxr-xr-x   2 user user    4096 Nov  4 21:03 ./a",
          "  131339    4 drwxr-xr-x   2 user user    4096 Nov  4 21:03 ./a/b",
          "  131342    0 -rw-r--r--   1 user user       0 Nov  4 21:03 ./a/b/foo",
          "  131340    4 -rw-r--r--   1 user user    1025 Nov  4 21:03 ./big",
          "  131341    4 -rw-r--r--   1 user user     667 Nov  4 21:03 ./so",
          "  131337    0 -rw-r--r--   1 user user       0 Nov  4 21:03 ./foo"
        ],
        "output": {
          ".": {
            "items": [
              {
                "name": "big",
                "size": 1025
              },
              {
                "name": "so",
                "size": 667
              },
              {
                "name": "foo",
                "size": 0
              }
            ],
            "a": {
              "b": {
                "items": [
                  {
                    "name": "foo",
                    "size": 0
                  }
                ]
              }
            }
          }
        }
      }
    ],
    "identifier": 49161220
  },
  {
    "context": [
      "I would like to find a record where `key=id=ddd` && `key=parent=ccc`I would then like to add a new key/value to that record.",
      "the result should look like",
      "\"children\": {\n        \"ccc\": [{\n            \"id\": \"ddd\",\n            \"des\": \"object d\",\n            \"parent\": \"ccc\",\n            \"other\": \"zzz\",\n            \"newkey\": \"newValue\"\n        },{",
      "Here is a response to the \"UPDATED\" question:\n\n    walk(when(type == \"object\";\n              with_entries(when(.key|test(\"ccc\");\n                                .value |= map( when(.id==\"ddd\";\n\t\t\t                          . + {\"newkey\": \"newValue\"})))))"
    ],
    "utterance": "Add a new key-value pair to every object inside arrays under keys matching 'ccc' where the object's 'id' is 'ddd'.",
    "expressions": [
      "walk(when(type == \"object\";\n          with_entries(when(.key|test(\"ccc\");\n                            .value |= map( when(.id==\"ddd\";\n                                              . + {\"newkey\": \"newValue\"}))))))"
    ],
    "data": [
      {
        "input": {
          "children": {
            "ccc": [
              {
                "id": "ddd",
                "des": "object d",
                "parent": "ccc",
                "other": "zzz"
              },
              {
                "id": "zzz",
                "des": "object z",
                "parent": "ccc",
                "other": "ddd"
              }
            ],
            "www": [
              {
                "id": "ddd",
                "des": "object d",
                "parent": "www",
                "other": "ppp"
              },
              {
                "id": "kkk",
                "des": "object z",
                "parent": "www",
                "other": "ddd"
              }
            ]
          }
        },
        "output": {
          "children": {
            "ccc": [
              {
                "id": "ddd",
                "des": "object d",
                "parent": "ccc",
                "other": "zzz",
                "newkey": "newValue"
              },
              {
                "id": "zzz",
                "des": "object z",
                "parent": "ccc",
                "other": "ddd"
              }
            ],
            "www": [
              {
                "id": "ddd",
                "des": "object d",
                "parent": "www",
                "other": "ppp"
              },
              {
                "id": "kkk",
                "des": "object z",
                "parent": "www",
                "other": "ddd"
              }
            ]
          }
        }
      }
    ],
    "identifier": 49132181
  },
  {
    "context": [
      "How to get IAM policies for these 2 users, i need to extract AmazonEC2FullAccess and AmazonS3FullAccess under AttachedManagedPolicies ?",
      "so output can be\n\n    citrix-xendesktop-ec2-provisioning\",AmazonEC2FullAccess\n    citrix-xendesktop-ec2-provisioning\",AmazonS3FullAccess\n    rundeck-read-only-iam-permissions,IAMReadOnlyAccess",
      ".UserDetailList[] \n| .UserName as $u\n| .AttachedManagedPolicies[]\n| [$u, .PolicyName]\n| @csv"
    ],
    "utterance": "List each user's name alongside each of their attached managed policy names as CSV rows.",
    "expressions": [
      ".UserDetailList[] | .UserName as $u | .AttachedManagedPolicies[] | [$u, .PolicyName] | @csv"
    ],
    "data": [
      {
        "input": {
          "UserDetailList": [
            {
              "UserName": "citrix-xendesktop-ec2-provisioning",
              "GroupList": [],
              "CreateDate": "2017-11-07T14:20:14Z",
              "UserId": "1234556",
              "Path": "/",
              "AttachedManagedPolicies": [
                {
                  "PolicyName": "AmazonEC2FullAccess",
                  "PolicyArn": "arn:aws:iam::aws:policy/AmazonEC2FullAccess"
                },
                {
                  "PolicyName": "AmazonS3FullAccess",
                  "PolicyArn": "arn:aws:iam::aws:policy/AmazonS3FullAccess"
                }
              ],
              "Arn": "arn:aws:iam::1234567890:user/citrix-xendesktop-ec2-provisioning"
            },
            {
              "UserName": "rundeck-read-only-iam-permissions",
              "GroupList": [],
              "CreateDate": "2018-03-09T11:13:38Z",
              "UserId": "AIDAJQOQGKISLCWDXG6EQ",
              "Path": "/",
              "AttachedManagedPolicies": [
                {
                  "PolicyName": "IAMReadOnlyAccess",
                  "PolicyArn": "arn:aws:iam::aws:policy/IAMReadOnlyAccess"
                }
              ],
              "Arn": "arn:aws:iam::279052847476:user/rundeck-read-only-iam-permissions"
            }
          ]
        },
        "output": [
          "\"citrix-xendesktop-ec2-provisioning\",\"AmazonEC2FullAccess\"",
          "\"citrix-xendesktop-ec2-provisioning\",\"AmazonS3FullAccess\"",
          "\"rundeck-read-only-iam-permissions\",\"IAMReadOnlyAccess\""
        ]
      }
    ],
    "identifier": 49191968
  },
  {
    "context": [
      "I need to run a single command that searches an array, finds an object that has a key that equals \u201csomeData\u201d, and then delete a key that is in the object, for example, delete a \u201cmaxHeight\u201d key from the object where key equals \u201csomeData\u201d.",
      "I would like to search the \u2018tracks\u2019 array and find the object where label =\u201ccucumber_ChineseLong_v2.gff3\u201d and then remove the \u2018maxHeight: \u201c200px\u201d \u2018 from that object.",
      "Is it possible to return the original file with the 'maxHeight' removed?",
      "For \"editing\" (as opposed to extraction), the trick is to use `|=`. There are many variations possible, for example:",
      ".tracks |=\n  map(if .label==\"cucumber_ChineseLong_v2.gff3\"\n      then del(.maxHeight)\n      else .\n      end)",
      "Some prefer the one-liner:",
      ".tracks[] |= if .label==\"cucumber_ChineseLong_v2.gff3\" then del(.maxHeight) else . end"
    ],
    "utterance": "Remove the maxHeight key from the object in the tracks array where label equals cucumber_ChineseLong_v2.gff3, returning the full modified structure.",
    "expressions": [
      ".tracks |= map(if .label==\"cucumber_ChineseLong_v2.gff3\" then del(.maxHeight) else . end)",
      ".tracks[] |= if .label==\"cucumber_ChineseLong_v2.gff3\" then del(.maxHeight) else . end"
    ],
    "data": [
      {
        "input": {
          "tracks": [
            {
              "storeClass": "JBrowse/Store/Sequence/StaticChunked",
              "chunkSize": 20000,
              "urlTemplate": "seq/{refseq_dirpath}/{refseq}-",
              "label": "DNA",
              "type": "SequenceTrack",
              "category": "Reference sequence",
              "seqType": "dna",
              "key": "Reference sequence"
            },
            {
              "style": {
                "className": "feature",
                "showLabels": false,
                "arrowheadClass": null,
                "featureCss": "padding:3px;"
              },
              "menuTemplate": [
                {
                  "label": "View details"
                },
                {
                  "label": "Highlight a gene"
                },
                {
                  "iconClass": "dijitIconBookmark",
                  "content": "function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( feature[2] ) }",
                  "action": "contentDialog",
                  "title": "(feature{name})",
                  "label": "Create Note"
                }
              ],
              "hooks": {
                "modify": " function(track,feature,div){ var checkArr=[\"Reference\",\"Missing\",\"Heterozygous\",\"NonReference\"];for(var i=0;i<feature.length;i++){for(var j=0;j<checkArr.length;j++){  if( i>3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\"NonReference\"){div.style.backgroundColor=\"red\";}else if(feature[i]==\"Reference\"){div.style.backgroundColor=\"green\";}else if(feature[i]==\"Heterozygous\"){div.style.backgroundColor=\"orange\";}else if(feature[i]==\"Missing\"){div.style.backgroundColor=\"grey\";} }}}}} "
              },
              "key": "CG0001.gff",
              "storeClass": "JBrowse/Store/SeqFeature/NCList",
              "trackType": null,
              "maxHeight": "200px",
              "urlTemplate": "tracks/CG0001.gff/{refseq}/trackData.json",
              "compress": 0,
              "label": "CG0001.gff",
              "type": "FeatureTrack"
            },
            {
              "style": {
                "className": "feature",
                "showLabels": false,
                "arrowheadClass": null,
                "featureCss": "padding:3px;"
              },
              "menuTemplate": [
                {
                  "label": "View details"
                },
                {
                  "label": "Highlight a gene"
                },
                {
                  "iconClass": "dijitIconBookmark",
                  "content": "function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( feature[2] ) }",
                  "action": "contentDialog",
                  "title": "(feature{name})",
                  "label": "Create Note"
                }
              ],
              "hooks": {
                "modify": " function(track,feature,div){ var checkArr=[\"Reference\",\"Missing\",\"Heterozygous\",\"NonReference\"];for(var i=0;i<feature.length;i++){for(var j=0;j<checkArr.length;j++){  if( i>3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\"NonReference\"){div.style.backgroundColor=\"red\";}else if(feature[i]==\"Reference\"){div.style.backgroundColor=\"green\";}else if(feature[i]==\"Heterozygous\"){div.style.backgroundColor=\"orange\";}else if(feature[i]==\"Missing\"){div.style.backgroundColor=\"grey\";} }}}}} "
              },
              "key": "CG0002.gff",
              "storeClass": "JBrowse/Store/SeqFeature/NCList",
              "trackType": null,
              "maxHeight": "200px",
              "urlTemplate": "tracks/CG0002.gff/{refseq}/trackData.json",
              "compress": 0,
              "label": "CG0002.gff",
              "type": "FeatureTrack"
            },
            {
              "style": {
                "className": "feature",
                "showLabels": false,
                "arrowheadClass": null,
                "featureCss": "padding:3px;"
              },
              "menuTemplate": [
                {
                  "label": "View details"
                },
                {
                  "label": "Highlight a gene"
                },
                {
                  "iconClass": "dijitIconBookmark",
                  "content": "function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( feature[2] ) }",
                  "action": "contentDialog",
                  "title": "(feature{name})",
                  "label": "Create Note"
                }
              ],
              "hooks": {
                "modify": " function(track,feature,div){ var checkArr=[\"Reference\",\"Missing\",\"Heterozygous\",\"NonReference\"];for(var i=0;i<feature.length;i++){for(var j=0;j<checkArr.length;j++){  if( i>3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\"NonReference\"){div.style.backgroundColor=\"red\";}else if(feature[i]==\"Reference\"){div.style.backgroundColor=\"green\";}else if(feature[i]==\"Heterozygous\"){div.style.backgroundColor=\"orange\";}else if(feature[i]==\"Missing\"){div.style.backgroundColor=\"grey\";} }}}}} "
              },
              "key": "CG0003.gff",
              "storeClass": "JBrowse/Store/SeqFeature/NCList",
              "trackType": null,
              "maxHeight": "200px",
              "urlTemplate": "tracks/CG0003.gff/{refseq}/trackData.json",
              "compress": 0,
              "label": "CG0003.gff",
              "type": "FeatureTrack"
            },
            {
              "style": {
                "className": "feature",
                "showLabels": false,
                "arrowheadClass": null,
                "featureCss": "padding:3px;"
              },
              "menuTemplate": [
                {
                  "label": "View details"
                },
                {
                  "label": "Highlight a gene"
                },
                {
                  "iconClass": "dijitIconBookmark",
                  "content": "function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( feature[2] ) }",
                  "action": "contentDialog",
                  "title": "(feature{name})",
                  "label": "Create Note"
                }
              ],
              "hooks": {
                "modify": " function(track,feature,div){ var checkArr=[\"Reference\",\"Missing\",\"Heterozygous\",\"NonReference\"];for(var i=0;i<feature.length;i++){for(var j=0;j<checkArr.length;j++){  if( i>3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\"NonReference\"){div.style.backgroundColor=\"red\";}else if(feature[i]==\"Reference\"){div.style.backgroundColor=\"green\";}else if(feature[i]==\"Heterozygous\"){div.style.backgroundColor=\"orange\";}else if(feature[i]==\"Missing\"){div.style.backgroundColor=\"grey\";} }}}}} "
              },
              "key": "CG0004.gff",
              "storeClass": "JBrowse/Store/SeqFeature/NCList",
              "trackType": null,
              "maxHeight": "200px",
              "urlTemplate": "tracks/CG0004.gff/{refseq}/trackData.json",
              "compress": 0,
              "label": "CG0004.gff",
              "type": "FeatureTrack"
            },
            {
              "style": {
                "className": "feature",
                "showLabels": false,
                "arrowheadClass": null,
                "featureCss": "padding:3px;"
              },
              "menuTemplate": [
                {
                  "label": "View details"
                },
                {
                  "label": "Highlight a gene"
                },
                {
                  "iconClass": "dijitIconBookmark",
                  "content": "function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( feature[2] ) }",
                  "action": "contentDialog",
                  "title": "(feature{name})",
                  "label": "Create Note"
                }
              ],
              "hooks": {
                "modify": " function(track,feature,div){ var checkArr=[\"Reference\",\"Missing\",\"Heterozygous\",\"NonReference\"];for(var i=0;i<feature.length;i++){for(var j=0;j<checkArr.length;j++){  if( i>3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\"NonReference\"){div.style.backgroundColor=\"red\";}else if(feature[i]==\"Reference\"){div.style.backgroundColor=\"green\";}else if(feature[i]==\"Heterozygous\"){div.style.backgroundColor=\"orange\";}else if(feature[i]==\"Missing\"){div.style.backgroundColor=\"grey\";} }}}}} "
              },
              "key": "CG0005.gff",
              "storeClass": "JBrowse/Store/SeqFeature/NCList",
              "trackType": null,
              "maxHeight": "200px",
              "urlTemplate": "tracks/CG0005.gff/{refseq}/trackData.json",
              "compress": 0,
              "label": "CG0005.gff",
              "type": "FeatureTrack"
            },
            {
              "style": {
                "className": "feature",
                "showLabels": false,
                "arrowheadClass": null,
                "featureCss": "padding:3px;"
              },
              "menuTemplate": [
                {
                  "label": "View details"
                },
                {
                  "label": "Highlight a gene"
                },
                {
                  "iconClass": "dijitIconBookmark",
                  "content": "function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( feature[2] ) }",
                  "action": "contentDialog",
                  "title": "(feature{name})",
                  "label": "Create Note"
                }
              ],
              "hooks": {
                "modify": " function(track,feature,div){ var checkArr=[\"Reference\",\"Missing\",\"Heterozygous\",\"NonReference\"];for(var i=0;i<feature.length;i++){for(var j=0;j<checkArr.length;j++){  if( i>3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\"NonReference\"){div.style.backgroundColor=\"red\";}else if(feature[i]==\"Reference\"){div.style.backgroundColor=\"green\";}else if(feature[i]==\"Heterozygous\"){div.style.backgroundColor=\"orange\";}else if(feature[i]==\"Missing\"){div.style.backgroundColor=\"grey\";} }}}}} "
              },
              "key": "CG0010.gff",
              "storeClass": "JBrowse/Store/SeqFeature/NCList",
              "trackType": null,
              "maxHeight": "200px",
              "urlTemplate": "tracks/CG0010.gff/{refseq}/trackData.json",
              "compress": 0,
              "label": "CG0010.gff",
              "type": "FeatureTrack"
            },
            {
              "style": {
                "className": "feature",
                "showLabels": false,
                "color": "function(feature, variableName, glyphObject, track){if(feature.get(\"type\") === \"CDS\"){return \"#9CFBF5\";} else if(feature.get(\"type\") === \"exon\"){return \"#43A47F\";} else if(feature.get(\"type\") === \"intron\"){return \"#E8E8E8\";} else if(feature.get(\"type\") === \"five_prime_UTR\"){return \"#F192FE\";} else if(feature.get(\"type\") === \"three_prime_UTR\"){return \"#FEC892\";} else {return \"#FF0000\";}}",
                "arrowheadClass": null,
                "featureCss": "padding:3px;"
              },
              "menuTemplate": [
                {
                  "label": "View details"
                },
                {
                  "label": "Highlight a gene"
                },
                {
                  "iconClass": "dijitIconBookmark",
                  "content": "function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( feature[2] ) }",
                  "action": "contentDialog",
                  "title": "(feature{name})",
                  "label": "Create Note"
                }
              ],
              "hooks": {
                "modify": " function(track,feature,div){   var checkArr=[\"Reference\",\"Missing\",\"Heterozygous\",\"NonReference\"];for(var i=0;i<feature.length;i++){for(var j=0;j<checkArr.length;j++){  if( i>3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\"NonReference\"){div.style.backgroundColor=\"red\";}else if(feature[i]==\"Reference\"){div.style.backgroundColor=\"green\";}else if(feature[i]==\"Heterozygous\"){div.style.backgroundColor=\"orange\";}else if(feature[i]==\"Missing\"){div.style.backgroundColor=\"grey\";} }}}}} "
              },
              "key": "cucumber_ChineseLong_v2.gff3",
              "storeClass": "JBrowse/Store/SeqFeature/NCList",
              "trackType": null,
              "maxHeight": "200px",
              "urlTemplate": "tracks/cucumber_ChineseLong_v2.gff3/{refseq}/trackData.json",
              "compress": 0,
              "label": "cucumber_ChineseLong_v2.gff3",
              "type": "JBrowse/View/Track/CanvasFeatures"
            },
            {
              "storeClass": "JBrowse/Store/SeqFeature/VCFTabix",
              "urlTemplate": "Cucumber115_chronly.vcf.gz",
              "maxHeight": "200px",
              "type": "CanvasVariants",
              "label": "Cucumber115_chronly.vcf",
              "menuTemplate": [
                {
                  "label": "View details"
                },
                {
                  "label": "Zoom"
                },
                {
                  "iconClass": "dijitIconFilter",
                  "content": "function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().selectSequence( div.f.data.end ) }",
                  "action": "contentDialog",
                  "title": "(feature{name})",
                  "label": "Select Sequence"
                },
                {
                  "iconClass": "dijitIconBookmark",
                  "content": "function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( div.f.data.end ) }",
                  "action": "contentDialog",
                  "title": "(feature{name})",
                  "label": "Create Note"
                }
              ]
            },
            {
              "style": {
                "className": "feature",
                "showLabels": false,
                "arrowheadClass": null,
                "featureCss": "padding:7px;"
              },
              "hooks": {
                "modify": " function(track,feature,div){ var checkArr=[\"Gene\",\"Variant\",\"Primer\"];for(var i=0;i<feature.length;i++){for(var j=0;j<checkArr.length;j++){  if( i>3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\"Gene\"){div.style.backgroundColor=\"pink\";}else if(feature[i]==\"Variant\"){div.style.backgroundColor=\"purple\";}else if(feature[i]==\"Primer\"){div.style.backgroundColor=\"blue\";} }}}}} "
              },
              "key": "Notes",
              "storeClass": "JBrowse/Store/SeqFeature/NCList",
              "trackType": null,
              "maxHeight": "200px",
              "urlTemplate": "tracks/Notes/{refseq}/trackData.json",
              "compress": 0,
              "type": "FeatureTrack",
              "label": "Notes"
            }
          ],
          "formatVersion": 1
        },
        "output": {
          "tracks": [
            {
              "storeClass": "JBrowse/Store/Sequence/StaticChunked",
              "chunkSize": 20000,
              "urlTemplate": "seq/{refseq_dirpath}/{refseq}-",
              "label": "DNA",
              "type": "SequenceTrack",
              "category": "Reference sequence",
              "seqType": "dna",
              "key": "Reference sequence"
            },
            {
              "style": {
                "className": "feature",
                "showLabels": false,
                "arrowheadClass": null,
                "featureCss": "padding:3px;"
              },
              "menuTemplate": [
                {
                  "label": "View details"
                },
                {
                  "label": "Highlight a gene"
                },
                {
                  "iconClass": "dijitIconBookmark",
                  "content": "function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( feature[2] ) }",
                  "action": "contentDialog",
                  "title": "(feature{name})",
                  "label": "Create Note"
                }
              ],
              "hooks": {
                "modify": " function(track,feature,div){ var checkArr=[\"Reference\",\"Missing\",\"Heterozygous\",\"NonReference\"];for(var i=0;i<feature.length;i++){for(var j=0;j<checkArr.length;j++){  if( i>3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\"NonReference\"){div.style.backgroundColor=\"red\";}else if(feature[i]==\"Reference\"){div.style.backgroundColor=\"green\";}else if(feature[i]==\"Heterozygous\"){div.style.backgroundColor=\"orange\";}else if(feature[i]==\"Missing\"){div.style.backgroundColor=\"grey\";} }}}}} "
              },
              "key": "CG0001.gff",
              "storeClass": "JBrowse/Store/SeqFeature/NCList",
              "trackType": null,
              "maxHeight": "200px",
              "urlTemplate": "tracks/CG0001.gff/{refseq}/trackData.json",
              "compress": 0,
              "label": "CG0001.gff",
              "type": "FeatureTrack"
            },
            {
              "style": {
                "className": "feature",
                "showLabels": false,
                "arrowheadClass": null,
                "featureCss": "padding:3px;"
              },
              "menuTemplate": [
                {
                  "label": "View details"
                },
                {
                  "label": "Highlight a gene"
                },
                {
                  "iconClass": "dijitIconBookmark",
                  "content": "function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( feature[2] ) }",
                  "action": "contentDialog",
                  "title": "(feature{name})",
                  "label": "Create Note"
                }
              ],
              "hooks": {
                "modify": " function(track,feature,div){ var checkArr=[\"Reference\",\"Missing\",\"Heterozygous\",\"NonReference\"];for(var i=0;i<feature.length;i++){for(var j=0;j<checkArr.length;j++){  if( i>3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\"NonReference\"){div.style.backgroundColor=\"red\";}else if(feature[i]==\"Reference\"){div.style.backgroundColor=\"green\";}else if(feature[i]==\"Heterozygous\"){div.style.backgroundColor=\"orange\";}else if(feature[i]==\"Missing\"){div.style.backgroundColor=\"grey\";} }}}}} "
              },
              "key": "CG0002.gff",
              "storeClass": "JBrowse/Store/SeqFeature/NCList",
              "trackType": null,
              "maxHeight": "200px",
              "urlTemplate": "tracks/CG0002.gff/{refseq}/trackData.json",
              "compress": 0,
              "label": "CG0002.gff",
              "type": "FeatureTrack"
            },
            {
              "style": {
                "className": "feature",
                "showLabels": false,
                "arrowheadClass": null,
                "featureCss": "padding:3px;"
              },
              "menuTemplate": [
                {
                  "label": "View details"
                },
                {
                  "label": "Highlight a gene"
                },
                {
                  "iconClass": "dijitIconBookmark",
                  "content": "function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( feature[2] ) }",
                  "action": "contentDialog",
                  "title": "(feature{name})",
                  "label": "Create Note"
                }
              ],
              "hooks": {
                "modify": " function(track,feature,div){ var checkArr=[\"Reference\",\"Missing\",\"Heterozygous\",\"NonReference\"];for(var i=0;i<feature.length;i++){for(var j=0;j<checkArr.length;j++){  if( i>3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\"NonReference\"){div.style.backgroundColor=\"red\";}else if(feature[i]==\"Reference\"){div.style.backgroundColor=\"green\";}else if(feature[i]==\"Heterozygous\"){div.style.backgroundColor=\"orange\";}else if(feature[i]==\"Missing\"){div.style.backgroundColor=\"grey\";} }}}}} "
              },
              "key": "CG0003.gff",
              "storeClass": "JBrowse/Store/SeqFeature/NCList",
              "trackType": null,
              "maxHeight": "200px",
              "urlTemplate": "tracks/CG0003.gff/{refseq}/trackData.json",
              "compress": 0,
              "label": "CG0003.gff",
              "type": "FeatureTrack"
            },
            {
              "style": {
                "className": "feature",
                "showLabels": false,
                "arrowheadClass": null,
                "featureCss": "padding:3px;"
              },
              "menuTemplate": [
                {
                  "label": "View details"
                },
                {
                  "label": "Highlight a gene"
                },
                {
                  "iconClass": "dijitIconBookmark",
                  "content": "function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( feature[2] ) }",
                  "action": "contentDialog",
                  "title": "(feature{name})",
                  "label": "Create Note"
                }
              ],
              "hooks": {
                "modify": " function(track,feature,div){ var checkArr=[\"Reference\",\"Missing\",\"Heterozygous\",\"NonReference\"];for(var i=0;i<feature.length;i++){for(var j=0;j<checkArr.length;j++){  if( i>3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\"NonReference\"){div.style.backgroundColor=\"red\";}else if(feature[i]==\"Reference\"){div.style.backgroundColor=\"green\";}else if(feature[i]==\"Heterozygous\"){div.style.backgroundColor=\"orange\";}else if(feature[i]==\"Missing\"){div.style.backgroundColor=\"grey\";} }}}}} "
              },
              "key": "CG0004.gff",
              "storeClass": "JBrowse/Store/SeqFeature/NCList",
              "trackType": null,
              "maxHeight": "200px",
              "urlTemplate": "tracks/CG0004.gff/{refseq}/trackData.json",
              "compress": 0,
              "label": "CG0004.gff",
              "type": "FeatureTrack"
            },
            {
              "style": {
                "className": "feature",
                "showLabels": false,
                "arrowheadClass": null,
                "featureCss": "padding:3px;"
              },
              "menuTemplate": [
                {
                  "label": "View details"
                },
                {
                  "label": "Highlight a gene"
                },
                {
                  "iconClass": "dijitIconBookmark",
                  "content": "function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( feature[2] ) }",
                  "action": "contentDialog",
                  "title": "(feature{name})",
                  "label": "Create Note"
                }
              ],
              "hooks": {
                "modify": " function(track,feature,div){ var checkArr=[\"Reference\",\"Missing\",\"Heterozygous\",\"NonReference\"];for(var i=0;i<feature.length;i++){for(var j=0;j<checkArr.length;j++){  if( i>3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\"NonReference\"){div.style.backgroundColor=\"red\";}else if(feature[i]==\"Reference\"){div.style.backgroundColor=\"green\";}else if(feature[i]==\"Heterozygous\"){div.style.backgroundColor=\"orange\";}else if(feature[i]==\"Missing\"){div.style.backgroundColor=\"grey\";} }}}}} "
              },
              "key": "CG0005.gff",
              "storeClass": "JBrowse/Store/SeqFeature/NCList",
              "trackType": null,
              "maxHeight": "200px",
              "urlTemplate": "tracks/CG0005.gff/{refseq}/trackData.json",
              "compress": 0,
              "label": "CG0005.gff",
              "type": "FeatureTrack"
            },
            {
              "style": {
                "className": "feature",
                "showLabels": false,
                "arrowheadClass": null,
                "featureCss": "padding:3px;"
              },
              "menuTemplate": [
                {
                  "label": "View details"
                },
                {
                  "label": "Highlight a gene"
                },
                {
                  "iconClass": "dijitIconBookmark",
                  "content": "function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( feature[2] ) }",
                  "action": "contentDialog",
                  "title": "(feature{name})",
                  "label": "Create Note"
                }
              ],
              "hooks": {
                "modify": " function(track,feature,div){ var checkArr=[\"Reference\",\"Missing\",\"Heterozygous\",\"NonReference\"];for(var i=0;i<feature.length;i++){for(var j=0;j<checkArr.length;j++){  if( i>3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\"NonReference\"){div.style.backgroundColor=\"red\";}else if(feature[i]==\"Reference\"){div.style.backgroundColor=\"green\";}else if(feature[i]==\"Heterozygous\"){div.style.backgroundColor=\"orange\";}else if(feature[i]==\"Missing\"){div.style.backgroundColor=\"grey\";} }}}}} "
              },
              "key": "CG0010.gff",
              "storeClass": "JBrowse/Store/SeqFeature/NCList",
              "trackType": null,
              "maxHeight": "200px",
              "urlTemplate": "tracks/CG0010.gff/{refseq}/trackData.json",
              "compress": 0,
              "label": "CG0010.gff",
              "type": "FeatureTrack"
            },
            {
              "style": {
                "className": "feature",
                "showLabels": false,
                "color": "function(feature, variableName, glyphObject, track){if(feature.get(\"type\") === \"CDS\"){return \"#9CFBF5\";} else if(feature.get(\"type\") === \"exon\"){return \"#43A47F\";} else if(feature.get(\"type\") === \"intron\"){return \"#E8E8E8\";} else if(feature.get(\"type\") === \"five_prime_UTR\"){return \"#F192FE\";} else if(feature.get(\"type\") === \"three_prime_UTR\"){return \"#FEC892\";} else {return \"#FF0000\";}}",
                "arrowheadClass": null,
                "featureCss": "padding:3px;"
              },
              "menuTemplate": [
                {
                  "label": "View details"
                },
                {
                  "label": "Highlight a gene"
                },
                {
                  "iconClass": "dijitIconBookmark",
                  "content": "function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( feature[2] ) }",
                  "action": "contentDialog",
                  "title": "(feature{name})",
                  "label": "Create Note"
                }
              ],
              "hooks": {
                "modify": " function(track,feature,div){   var checkArr=[\"Reference\",\"Missing\",\"Heterozygous\",\"NonReference\"];for(var i=0;i<feature.length;i++){for(var j=0;j<checkArr.length;j++){  if( i>3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\"NonReference\"){div.style.backgroundColor=\"red\";}else if(feature[i]==\"Reference\"){div.style.backgroundColor=\"green\";}else if(feature[i]==\"Heterozygous\"){div.style.backgroundColor=\"orange\";}else if(feature[i]==\"Missing\"){div.style.backgroundColor=\"grey\";} }}}}} "
              },
              "key": "cucumber_ChineseLong_v2.gff3",
              "storeClass": "JBrowse/Store/SeqFeature/NCList",
              "trackType": null,
              "urlTemplate": "tracks/cucumber_ChineseLong_v2.gff3/{refseq}/trackData.json",
              "compress": 0,
              "label": "cucumber_ChineseLong_v2.gff3",
              "type": "JBrowse/View/Track/CanvasFeatures"
            },
            {
              "storeClass": "JBrowse/Store/SeqFeature/VCFTabix",
              "urlTemplate": "Cucumber115_chronly.vcf.gz",
              "maxHeight": "200px",
              "type": "CanvasVariants",
              "label": "Cucumber115_chronly.vcf",
              "menuTemplate": [
                {
                  "label": "View details"
                },
                {
                  "label": "Zoom"
                },
                {
                  "iconClass": "dijitIconFilter",
                  "content": "function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().selectSequence( div.f.data.end ) }",
                  "action": "contentDialog",
                  "title": "(feature{name})",
                  "label": "Select Sequence"
                },
                {
                  "iconClass": "dijitIconBookmark",
                  "content": "function(track,feature,div) { window.parent.angular.element(window.frameElement).scope().specificNote( div.f.data.end ) }",
                  "action": "contentDialog",
                  "title": "(feature{name})",
                  "label": "Create Note"
                }
              ]
            },
            {
              "style": {
                "className": "feature",
                "showLabels": false,
                "arrowheadClass": null,
                "featureCss": "padding:7px;"
              },
              "hooks": {
                "modify": " function(track,feature,div){ var checkArr=[\"Gene\",\"Variant\",\"Primer\"];for(var i=0;i<feature.length;i++){for(var j=0;j<checkArr.length;j++){  if( i>3) { if( feature[i] ===  checkArr[j] ) {  if(feature[i]==\"Gene\"){div.style.backgroundColor=\"pink\";}else if(feature[i]==\"Variant\"){div.style.backgroundColor=\"purple\";}else if(feature[i]==\"Primer\"){div.style.backgroundColor=\"blue\";} }}}}} "
              },
              "key": "Notes",
              "storeClass": "JBrowse/Store/SeqFeature/NCList",
              "trackType": null,
              "maxHeight": "200px",
              "urlTemplate": "tracks/Notes/{refseq}/trackData.json",
              "compress": 0,
              "type": "FeatureTrack",
              "label": "Notes"
            }
          ],
          "formatVersion": 1
        }
      }
    ],
    "identifier": 48526476
  }
]