[
  {
    "context": [
      "From A.json, I grab the **ui** `key`:",
      "myVar=$(jq '.ui' A.json)",
      "I would like to now replace B's **ui** `key`'s with `myVar`."
    ],
    "utterance": "Replace the value of the ui key inside the metadata object of the second file with the ui value from the first file.",
    "expressions": [
      "jq --argjson ui \"$(jq '.ui' A.json)\" '.metadata.ui = $ui' B.json"
    ],
    "identifier": 56746475
  },
  {
    "context": [
      "I have a below json file but I&#39;m struggling to only display the `description` with the latest `createdDate`.",
      "Simply sort by .createdDate and (assuming you only want one value even if there is more than one with the greatest .createdDate value), select the last one:",
      ".items | sort_by(.createdDate)[-1].description"
    ],
    "utterance": "Output the description field of the object with the highest createdDate value in the items array.",
    "expressions": [
      ".items | sort_by(.createdDate)[-1].description"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "createdDate": 1543585940,
              "id": "awefef",
              "description": "this is description 1"
            },
            {
              "createdDate": 1555324487,
              "id": "hjkvhuk",
              "description": "this is description 2"
            },
            {
              "createdDate": 1547034297,
              "id": "xdfxdfv",
              "description": "this is description 3"
            }
          ]
        },
        "output": "this is description 2"
      }
    ],
    "identifier": 56758079
  },
  {
    "context": [
      "I want to interactively query it with fzf and jq, by sending the data through stdin and typing the jq query into the fzf query box.",
      "echo '' | fzf --print-query --preview='jq {q} <(echo \"[{\\\"x\\\": 1}, {\\\"y\\\": 2}]\")'",
      "(export json='[{\"x\": 1}, {\"y\": 2}]'; echo '' | fzf --print-query --preview='jq {q} <(printf \"%s\" \"$json\")')"
    ],
    "utterance": "Interactively enter a filter expression and preview the matching result as the query updates, using given data '[{\"x\": 1}, {\"y\": 2}]' and live-editing the filter.",
    "expressions": [
      "fzf --print-query --preview='jq {q} <(echo \"[{\\\"x\\\": 1}, {\\\"y\\\": 2}]\")'",
      "(export json='[{\"x\": 1}, {\"y\": 2}]'; echo '' | fzf --print-query --preview='jq {q} <(printf \"%s\" \"$json\")')"
    ],
    "data": [
      {
        "input": [
          {
            "x": 1
          },
          {
            "y": 2
          }
        ]
      }
    ],
    "identifier": 56744579
  },
  {
    "context": [
      "I then want to use it to replace content in another JSON file:",
      "jq -r --arg updated_overview_ui_strings \"${overview_ui}\" '.overview_ui.${language} |= $updated_overview_ui_strings' someOtherFile.json",
      "This works, however it also introduces visible newline `\\n` and escape `\\` characters instead of actually preserving the newlines as newlines.",
      "You have read the `overview_ui` variable in as a string (using `--arg`) so when you assigned it, you assigned that string (along with the formatting). You would either have to parse it as an object (using `fromjson`) or just use `--argjson` instead.",
      "jq -r --argjson updated_overview_ui_strings \"${overview_ui}\" ...",
      "$ jq --argfile service service.json --arg language en '\n    .overview_ui[$language] = $service.overview_ui\n    ' someOtherFile.json"
    ],
    "utterance": "Update the overview_ui property for a specified language in another file, using the overview_ui object from service.json, without introducing escaped newlines or characters.",
    "expressions": [
      "jq -r --argjson updated_overview_ui_strings \"${overview_ui}\" '.overview_ui.${language} |= $updated_overview_ui_strings' someOtherFile.json",
      "jq --argfile service service.json --arg language en '.overview_ui[$language] = $service.overview_ui' someOtherFile.json"
    ],
    "data": [
      {
        "input": {
          "service.json": {
            "overview_ui": {
              "display_name": "my display name",
              "long_description": "my long description",
              "description": "my description"
            }
          },
          "someOtherFile.json": {
            "overview_ui": {
              "en": {}
            }
          }
        },
        "output": {
          "overview_ui": {
            "en": {
              "display_name": "my display name",
              "long_description": "my long description",
              "description": "my description"
            }
          }
        }
      }
    ],
    "identifier": 56776388
  },
  {
    "context": [
      "My input JSON:",
      "My expected output:",
      "Each .[] is like a \"for\" loop, so the multiplicative behavior you observe is essentially the result of having nested for loops.  It would seem that what you want is closer to:",
      ".value[] as $v\n| $v.timeseries[].data[] as $d\n| {\"apiId\": $v.id,\n  \"metrics\": $v.name.value,\n  \"timestamp\": $d.timeStamp,\n  \"value\": $d.average }",
      "With your JSON as input, this produces two JSON objects, though the second of these differs very slightly from what you give as the expected output."
    ],
    "utterance": "Extract the id, name.value, timeStamp, and average fields from all data points under value[].timeseries[].data[], returning one object per data point with keys apiId, metrics, timestamp, and value.",
    "expressions": [
      ".value[] as $v | $v.timeseries[].data[] as $d | {\"apiId\": $v.id, \"metrics\": $v.name.value, \"timestamp\": $d.timeStamp, \"value\": $d.average}"
    ],
    "data": [
      {
        "input": {
          "cost": 0.0,
          "interval": "0:01:00",
          "namespace": "Microsoft.ApiManagement/service",
          "resourceregion": "australiaeast",
          "timespan": "2019-05-22T00:00:00Z/2019-05-22T00:02:00Z",
          "value": [
            {
              "id": "/my-api/providers/Microsoft.Insights/metrics/Capacity",
              "name": {
                "localizedValue": "Capacity",
                "value": "Capacity"
              },
              "resourceGroup": "my-group",
              "timeseries": [
                {
                  "data": [
                    {
                      "average": 15,
                      "count": null,
                      "maximum": null,
                      "minimum": null,
                      "timeStamp": "2019-05-22T00:00:00+00:00",
                      "total": null
                    },
                    {
                      "average": 16,
                      "count": null,
                      "maximum": null,
                      "minimum": null,
                      "timeStamp": "2019-05-22T00:01:00+00:00",
                      "total": null
                    }
                  ],
                  "metadatavalues": []
                }
              ],
              "type": "Microsoft.Insights/metrics",
              "unit": "Percent"
            }
          ]
        },
        "output": [
          {
            "apiId": "/my-api/providers/Microsoft.Insights/metrics/Capacity",
            "metrics": "Capacity",
            "timestamp": "2019-05-22T00:00:00+00:00",
            "value": 15
          },
          {
            "apiId": "/my-api/providers/Microsoft.Insights/metrics/Capacity",
            "metrics": "Capacity",
            "timestamp": "2019-05-22T00:01:00+00:00",
            "value": 16
          }
        ]
      }
    ],
    "identifier": 56763203
  },
  {
    "context": [
      "I have a **hierarchical** tree of JSON data as per the example below, and I need to convert this into a two dimensional table in text format, with the semantics of SQL join.",
      "The input JSON:",
      "[ [ [ [ \"machine.example.com\" ], [ { \"VolumeId\": \"vol-070061259e62b931d\", ... }, ... ] ] ] ]",
      "The desired output:",
      "machine.example.com vol-070061259e62b931d",
      "machine.example.com vol-070b6ecf34107389f",
      "machine.example.com vol-0d6188182333509a2",
      "machine.example.com vol-0653708f578c13e36",
      "Drill down to the \"lines\" of data then build out the result values.",
      "$ jq -r '.[][] | \"\\(.[0][]) \\(.[1][].VolumeId)\"' input.json"
    ],
    "utterance": "Print each machine name paired with each of its attached volume IDs, as pairs of values separated by a space.",
    "expressions": [
      ".[][] | \"\\(.[0][]) \\(.[1][].VolumeId)\""
    ],
    "data": [
      {
        "input": [
          [
            [
              [
                [
                  "machine.example.com"
                ],
                [
                  {
                    "VolumeId": "vol-070061259e62b931d",
                    "AttachTime": "2017-11-29T00:58:46.000Z",
                    "DeleteOnTermination": true,
                    "Status": "attached"
                  },
                  {
                    "VolumeId": "vol-070b6ecf34107389f",
                    "AttachTime": "2017-11-29T00:58:46.000Z",
                    "DeleteOnTermination": true,
                    "Status": "attached"
                  },
                  {
                    "VolumeId": "vol-0d6188182333509a2",
                    "AttachTime": "2017-11-29T01:30:51.000Z",
                    "DeleteOnTermination": false,
                    "Status": "attached"
                  },
                  {
                    "VolumeId": "vol-0653708f578c13e36",
                    "AttachTime": "2017-11-29T01:31:06.000Z",
                    "DeleteOnTermination": false,
                    "Status": "attached"
                  }
                ]
              ]
            ]
          ]
        ],
        "output": [
          "machine.example.com vol-070061259e62b931d",
          "machine.example.com vol-070b6ecf34107389f",
          "machine.example.com vol-0d6188182333509a2",
          "machine.example.com vol-0653708f578c13e36"
        ]
      }
    ],
    "identifier": 56754131
  },
  {
    "context": [
      "you're trying to check for the existence of a key in the object and it probably doesn't have a \".scripts.build\" property. It won't check that path like you're probably thinking. Drill down to the object first if you want to use has/1.",
      "if ./jq -e '.scripts | has(\"build\")' package.json > /dev/null; then",
      ".scripts.build",
      "For robustness, though, it might be advisable to go with: `.scripts.build?`"
    ],
    "utterance": "Check if the 'scripts' object in package.json contains a 'build' key.",
    "expressions": [
      ".scripts | has(\"build\")",
      ".scripts.build?",
      ".scripts.build"
    ],
    "data": [
      {
        "input": {
          "scripts": {
            "build": "webpack",
            "test": "jest"
          }
        },
        "output": true
      },
      {
        "input": {
          "scripts": {
            "test": "jest"
          }
        },
        "output": false
      }
    ],
    "identifier": 56800584
  },
  {
    "context": [
      "I see a line by line outline of the output:",
      "\"event\":{\"page_load\":{\"category_list_page\":{},\"load_time\":257,\"status\":\"SUCCESS\"}}",
      "I was expecting the format to be in nice json format - I looked everywhere but I can't seem to find how to append jq on telnet"
    ],
    "utterance": "Format each incoming line to pretty-printed output as soon as it is received",
    "expressions": [
      "jq ."
    ],
    "identifier": 56854675
  },
  {
    "context": [
      "I have to distinguish between the following two paths.",
      "cut -d/ -f4 <<<$url2%/*   # this returns last part of path",
      "but now I have to define same filter for JSON value handled in jq.",
      "split(\"/\")[3]",
      "sub(\"/ *$\";\"\") | split(\"/\")[-1]"
    ],
    "utterance": "Extract the last non-empty segment of the URL path if it exists; otherwise, return nothing.",
    "expressions": [
      ".url | sub(\"/ *$\";\"\") | split(\"/\")[-1]"
    ],
    "data": [
      {
        "input": {
          "url": "https://www.example.com/"
        },
        "output": ""
      },
      {
        "input": {
          "url": "https://www.example.com/foo/"
        },
        "output": "foo"
      }
    ],
    "identifier": 56829000
  },
  {
    "context": [
      "This is a sample of my data:",
      "[\n  {\n    \"media\": {\n      \"track\": [\n        {\n          \"attype\": \"General\",\n          \"FileExtension\": \"MP4\",\n          \"Format\": \"MPEG-4\"\n        },\n        {\n          \"attype\": \"Video\",\n          \"Format\": \"MPEG Video\"\n        }\n      ]\n    }\n  },\n  {\n    \"media\": {\n      \"track\": [\n        {\n          \"attype\": \"General\",\n          \"FileExtension\": \"ts\",\n          \"Format\": \"MPEG-TS\"\n        },\n        {\n          \"attype\": \"Video\",\n          \"Format\": \"MPEG Video\"\n        }\n      ]\n    }\n  }\n]",
      "This is the desired output:",
      "\"MP4\",\"MPEG-4\",\"MPEG Video\"\n\"ts\",\"MPEG-TS\",\"MPEG Video\"",
      "This is my [tag:jq] code:\n\n    .[].media.track[] |\n      [\n        (select(.attype ==\"General\") | .FileExtension, .Format),\n        (select(.attype ==\"Video\") | .Format)\n      ] | @csv",
      "This is the actual output:\n\n    \"MP4\",\"MPEG-4\"\n    \"MPEG Video\"\n    \"ts\",\"MPEG-TS\"\n    \"MPEG Video\"",
      "A solution is to create a cells array for each media rather than for each track :\n\n\n    .[].media | \n      [ \n        .track[] |\n           (select(.attype ==\"General\") | .FileExtension, .Format),\n           (select(.attype ==\"Video\") | .Format)\n      ] | @csv",
      "You\u2019re on the right track (pun intended) -- you just have to expand .track as follows:\n\n    .[].media.track\n    | [.[]\n       | (select(.attype ==\"General\") | .FileExtension, .Format),\n         (select(.attype ==\"Video\") | .Format) ]\n    | @csv",
      "Alternatively ...\nIf you find all those brackets and parentheses to be too distracting, you could go with:\n\n    .[].media.track\n    | map( if .attype ==\"General\" then .FileExtension, .Format\n           elif .attype ==\"Video\" then .Format\n           else empty\n           end )\n    | @csv"
    ],
    "utterance": "For each media, output the General track's FileExtension and Format, and the Video track's Format all on one CSV line.",
    "expressions": [
      ".[].media | [ .track[] | (select(.attype ==\"General\") | .FileExtension, .Format), (select(.attype ==\"Video\") | .Format) ] | @csv",
      ".[].media.track | [.[ ] | (select(.attype ==\"General\") | .FileExtension, .Format), (select(.attype ==\"Video\") | .Format) ] | @csv",
      ".[].media.track | map( if .attype ==\"General\" then .FileExtension, .Format elif .attype ==\"Video\" then .Format else empty end ) | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "media": {
              "track": [
                {
                  "attype": "General",
                  "FileExtension": "MP4",
                  "Format": "MPEG-4"
                },
                {
                  "attype": "Video",
                  "Format": "MPEG Video"
                }
              ]
            }
          },
          {
            "media": {
              "track": [
                {
                  "attype": "General",
                  "FileExtension": "ts",
                  "Format": "MPEG-TS"
                },
                {
                  "attype": "Video",
                  "Format": "MPEG Video"
                }
              ]
            }
          }
        ],
        "output": [
          "\"MP4\",\"MPEG-4\",\"MPEG Video\"",
          "\"ts\",\"MPEG-TS\",\"MPEG Video\""
        ]
      }
    ],
    "identifier": 56755346
  },
  {
    "context": [
      "Both values .p and .q are enclosed between double quotes in the JSON I get from the socket.",
      "When I try to multiply two values, it says I am trying to multiply two strings. So I pass those strings though the tonumber filter and the error message changes a bit, but can't get it to work really.",
      "I would expect just the raw result of multiplication to appear, like so:\r\n15.0072740",
      "Keep it simple,\r\n\r\n    jq -r '(.p | tonumber)*(.q | tonumber)'"
    ],
    "utterance": "Multiply the numeric values of fields 'p' and 'q', both supplied as strings, and output the result.",
    "expressions": [
      "(.p | tonumber)*(.q | tonumber)"
    ],
    "data": [
      {
        "input": {
          "e": "aggTrade",
          "E": 1562109562958,
          "s": "BTCUSDT",
          "a": 134343336,
          "p": "10796.60000000",
          "q": "0.00139000",
          "f": 147532295,
          "l": 147532295,
          "T": 1562109562951,
          "m": false,
          "M": true
        },
        "output": 14.969274
      }
    ],
    "identifier": 56861281
  },
  {
    "context": [
      "I want to add/update `status` field in each `mappings` in a.json by retrieving the value from b.json file.",
      "In this expected JSON file we have `status` field whose value is retrieved from b.json file based on a matching `id` value.",
      "INDEX( $b[] | {id, status}; .id ) as $dict\n| .rs.mappings |= map_values( .status = $dict[.id].status )"
    ],
    "utterance": "For each entry in the mappings object, add or update the status field to the value from the array where the id matches.",
    "expressions": [
      "INDEX( $b[] | {id, status}; .id ) as $dict | .rs.mappings |= map_values( .status = $dict[.id].status )"
    ],
    "data": [
      {
        "input": {
          "a.json": {
            "title": 25886,
            "data": {
              "request": {
                "c": 46369,
                "t1": 1562050127.376641
              }
            },
            "rs": {
              "mappings": {
                "12345": {
                  "id": "12345",
                  "name": "test",
                  "customer_id": "11228"
                },
                "45678": {
                  "id": "45678",
                  "name": "abc",
                  "customer_id": "11206"
                }
              }
            }
          },
          "b.json": [
            {
              "status": "pending",
              "extra": {
                "name": "test"
              },
              "enabled": true,
              "id": "12345"
            },
            {
              "status": "not_started",
              "extra": {
                "name": "abc"
              },
              "enabled": true,
              "id": "45678"
            }
          ]
        },
        "output": {
          "title": 25886,
          "data": {
            "request": {
              "c": 46369,
              "t1": 1562050127.376641
            }
          },
          "rs": {
            "mappings": {
              "12345": {
                "id": "12345",
                "name": "test",
                "customer_id": "11228",
                "status": "pending"
              },
              "45678": {
                "id": "45678",
                "name": "abc",
                "customer_id": "11206",
                "status": "not_started"
              }
            }
          }
        }
      }
    ],
    "identifier": 56847927
  },
  {
    "context": [
      "I want to add a new entry under example, so to get the following output in foobar.json",
      "I am using the following commands in the terminal:",
      "cat foobarbaz.json | jq '.example.new=env.tempvar' > foobar.json",
      "...However, the output in foobar.json is somewhat unexpected:",
      "Use fromjson to convert your string (the format *all* environment variables are in!) to the corresponding data structure, by decoding it as JSON content.",
      "jq '.example.new=(env.tempvar | fromjson)'",
      "Use the --argjson option to pass the pre-existing JSON snippet as a variable to the filter.",
      "jq --argjson x \"$tempvar\" '.example.new=$x' foobarbaz.json",
      "jq '.example.new={newfield: {key: \"value\"}}' foobarbaz.json"
    ],
    "utterance": "Add an object {\"newfield\": {\"key\": \"value\"}} as the new property 'new' under the existing 'example' object, without having it appear as a string value.",
    "expressions": [
      ".example.new=(env.tempvar | fromjson)",
      ".example.new=$x",
      ".example.new={newfield: {key: \"value\"}}"
    ],
    "data": [
      {
        "input": {
          "example": {
            "name": "stackOverflowQuestion"
          }
        },
        "output": {
          "example": {
            "name": "stackOverflowQuestion",
            "new": {
              "newfield": {
                "key": "value"
              }
            }
          }
        }
      }
    ],
    "identifier": 56878409
  },
  {
    "context": [
      "I need to add a `keyX: valueX` to all the `nested_obj`s in `objectx` using jq.",
      "I was trying to apply a map filter using `.objectx | map(.+{keyX: valueX})` but could not figure out how to store this filtered list into the original json object.",
      "`map` is designed to work on arrays, not objects. `map_values` can be used for that instead.",
      ".objectx |= map_values(.keyX = $valueX)",
      ".objectx[].keyX = $valueX"
    ],
    "utterance": "Add a key keyX with value valueX to every nested object within objectx, leaving the rest of the structure unchanged.",
    "expressions": [
      ".objectx |= map_values(.keyX = $valueX)",
      ".objectx[].keyX = $valueX"
    ],
    "data": [
      {
        "input": {
          "foo": 42,
          "objectx": {
            "nested_obj1": {
              "key1": "value1"
            },
            "nested_obj2": {
              "key2": "value2"
            }
          }
        },
        "output": {
          "foo": 42,
          "objectx": {
            "nested_obj1": {
              "key1": "value1",
              "keyX": "valueX"
            },
            "nested_obj2": {
              "key2": "value2",
              "keyX": "valueX"
            }
          }
        }
      }
    ],
    "identifier": 56888324
  },
  {
    "context": [
      "I want to get the values of comment / id and the parent value like (\"file_|-mysoc-po-python-rm2_|-/var/tmp/mysoc-po_|-absent\") where the field result is false.",
      "You can use the following :",
      ".[]\n| to_entries\n| map(select(.value.result == false))\n| map({ name:.key, id:.value.__id__, comment:.value.comment})"
    ],
    "utterance": "Extract objects containing the key name, the field __id__, and the comment for each entry whose result is false, along with the parent key.",
    "expressions": [
      ".[] | to_entries | map(select(.value.result == false)) | map({ name: .key, id: .value.__id__, comment: .value.comment })"
    ],
    "data": [
      {
        "input": {
          "lde-poc-01": {
            "file_|-linux-debian-login-uidmin_|-/etc/login.defs_|-replace": {
              "name": "/etc/login.defs",
              "changes": {},
              "pchanges": {},
              "result": true,
              "comment": "No changes needed to be made",
              "__sls__": "dev/linux/ubuntu/login",
              "__run_num__": 0,
              "start_time": "14:40:20.708675",
              "duration": 17.447,
              "__id__": "linux-debian-login-uidmin"
            },
            "cmd_|-linux-ubuntu-unattended-updrade-service_|-systemctl daemon-reload_|-run": {
              "changes": {},
              "result": false,
              "duration": 0.008,
              "start_time": "14:40:21.159608",
              "comment": "State was not run because none of the onchanges reqs changed",
              "__state_ran__": false,
              "__run_num__": 20,
              "__sls__": "dev/linux/ubuntu/apt"
            },
            "file_|-mysoc-po-python-rm2_|-/var/tmp/mysoc-po_|-absent": {
              "name": "/var/tmp/mysoc-po",
              "changes": {},
              "pchanges": {},
              "result": false,
              "comment": "File /var/tmp/mysoc-po is not present",
              "__sls__": "dev/mysoc-po",
              "__run_num__": 236,
              "start_time": "14:40:38.161788",
              "duration": 0.305,
              "__id__": "mysoc-po-python-rm2"
            }
          }
        },
        "output": [
          {
            "name": "cmd_|-linux-ubuntu-unattended-updrade-service_|-systemctl daemon-reload_|-run",
            "id": null,
            "comment": "State was not run because none of the onchanges reqs changed"
          },
          {
            "name": "file_|-mysoc-po-python-rm2_|-/var/tmp/mysoc-po_|-absent",
            "id": "mysoc-po-python-rm2",
            "comment": "File /var/tmp/mysoc-po is not present"
          }
        ]
      }
    ],
    "identifier": 56751214
  },
  {
    "context": [
      "I want to add/update the enabled status of the json object based on the parent key.",
      "eg: I have a file with below contents.\r\n\r\n    id1 false\r\n    id2 true\r\n    id3 false\r\n    id4 false",
      "I want my output to look like below:\r\n\r\n    {\r\n    \t\"l1\":\"\",\r\n    \t\"values\":{\r\n    \t\t\"id1\":{\r\n    \t\t\t\"name\":\"abc\",\r\n    \t\t\t\"enabled\":\"false\"\r\n    \r\n    \t\t},\r\n    \t\t\"id2\":{\r\n    \t\t    \"name\":\"def\",\r\n    \t\t\t\"enabled\":\"true\"\r\n    \t\t},\r\n    \t\t\"id3\":{\r\n    \t\t\t\"name\":\"jjj\",\r\n    \t\t\t\"enabled\":\"false\"\r\n    \t\t}\r\n    \t}\r\n    }",
      "jq --argjson m '{\"id1\":\"false\",\"id2\":\"true\",\"id3\":\"false\",\"id4\":\"false\"}' '\n    .values |= with_entries(.value.enabled = $m[.key])\n    ' input.json",
      "([inputs |capture(\"(?<key>.*) (?<value>(true|false)) *$\")\n    | select(.value | fromjson | type == \"boolean\") ]\n   | from_entries) as $dict\n  | $in\n  | .values |= with_entries(.value.enabled = $dict[.key])"
    ],
    "utterance": "Update or add the 'enabled' field for each key in 'values' according to a mapping provided separately, even if the mapping includes keys not present in the original data.",
    "expressions": [
      ".values |= with_entries(.value.enabled = $m[.key])",
      ".values |= with_entries(.value.enabled = $dict[.key])"
    ],
    "data": [
      {
        "input": {
          "l1": "",
          "values": {
            "id1": {
              "name": "abc",
              "enabled": "true"
            },
            "id2": {
              "name": "def",
              "enabled": "true"
            },
            "id3": {
              "name": "jjj"
            }
          }
        },
        "output": {
          "l1": "",
          "values": {
            "id1": {
              "name": "abc",
              "enabled": "false"
            },
            "id2": {
              "name": "def",
              "enabled": "true"
            },
            "id3": {
              "name": "jjj",
              "enabled": "false"
            }
          }
        }
      }
    ],
    "identifier": 56863482
  },
  {
    "context": [
      "I'm trying to validate all versions in a `versions.json` file, and get as the output a json with only the invalid versions.",
      "Here's a sample file:",
      "      {\n        \"slamx\": \"16.4.0 \",\n        \"sdbe\": null,\n        \"mimir\": null,\n        \"thoth\": null,\n        \"quasar\": null,\n        \"connectors\": {\n          \"s3\": \"16.0.17\",\n          \"azure\": \"6.0.17\",\n          \"url\": \"8.0.2\",\n          \"mongo\": \"7.0.15\"\n        }\n      }",
      "and get this as the output:\n\n    Bad versions detected in versions.json:\n    {\n      \"slamx\": \"16.4.0 \"\n    }",
      "returns `[[\"slamx\"],\"16.4.0 \"]`, which is what I'm searching for.",
      "For that to happen, the stream has to have the \"close object\" markers -- arrays with just one element, corresponding to the last key of the object being closed.",
      "The jq expression is as follow:\n\n    fromstream(\n        tostream |\n        select(\n            (\n                .[-1] | \n                type==\"string\" and contains(\" \")\n            ) or \n            length==1\n        )\n    )",
      "..\n| objects\n| with_entries(\n    select(( .value|type == \"string\" and contains(\" \")) or (.value|type == \"object\" and length==0)) )\n| select(length>0)"
    ],
    "utterance": "Return an object containing only key-value pairs where the value is a string with a space in it or is an empty object, at any nesting level.",
    "expressions": [
      "fromstream(tostream | select((.[-1] | type==\"string\" and contains(\" \")) or length==1))",
      ".. | objects | with_entries(select((.value|type == \"string\" and contains(\" \")) or (.value|type == \"object\" and length==0))) | select(length>0)"
    ],
    "data": [
      {
        "input": {
          "slamx": "16.4.0 ",
          "sdbe": null,
          "mimir": null,
          "thoth": null,
          "quasar": null,
          "connectors": {
            "s3": "16.0.17",
            "azure": "6.0.17",
            "url": "8.0.2",
            "mongo": "7.0.15"
          }
        },
        "output": {
          "slamx": "16.4.0 "
        }
      }
    ],
    "identifier": 56878970
  },
  {
    "identifier": 56911876
  },
  {
    "context": [
      "Say for example, I wanted to create a csv of the following elements: \n\n - entityName (unique linking identifier)\n - nzbn (unique linking identifier)\n - emailAddress__uniqueIdentifier\n - emailAddress__emailAddress\n - emailAddress__emailPurpose\n - emailAddress__emailPurposeDescription\n - emailAddress__startDate\n\nHow would I go about that?",
      "Here\u2019s a jq solution, apart from the headers:\n\n```\n.companies.entity[]\n| [.entityName, .nzbn]\n  + (.emailAddress[] | [.uniqueIdentifier, .emailAddress, .emailPurpose, .emailPurposeDescription, .startDate])\n| @csv\n```"
    ],
    "utterance": "Extract rows containing entityName, nzbn, and each emailAddress record's uniqueIdentifier, emailAddress, emailPurpose, emailPurposeDescription, and startDate from each company entity.",
    "expressions": [
      ".companies.entity[]\n| [.entityName, .nzbn]\n  + (.emailAddress[] | [.uniqueIdentifier, .emailAddress, .emailPurpose, .emailPurposeDescription, .startDate])\n| @csv"
    ],
    "identifier": 56890557
  },
  {
    "context": [
      "I am trying to run a `jq` query on a windows machine and it extracts values from output on a separate line",
      "jq -r .Accounts[].Id",
      "How do I run the `jq` query so that it combines the output on a single line separated by space",
      "This is what I need-\r\n\r\n    204359864429 224271824096 282276286062 210394168456 090161402717",
      "we can do a simple `join(\" \")` operation\r\n\r\n    jq -r '[.Accounts[].Id]|join(\" \")'",
      "P.S.: I found that the `@sh` filter produces space-separated output as desired, but in addition *delimits each output item in single quotes*.",
      "Here was my workaround, until I discovered that `join()` works just the same as it when used properly (see above):\r\n\r\n    jq -r '.Accounts[].Id | @tsv | sub(\"\\t\";\" \";\"g\")'",
      "If you run jq in a shell, you can use `xargs` like below:\r\n\r\n```\r\njq -r .Accounts[].Id | xargs\r\n```\r\n\r\noutput:\r\n```\r\n204359864429 224271824096 282276286062 210394168456 090161402717\r\n```"
    ],
    "utterance": "Output all values of the Id field from every object in the Accounts array on a single line separated by spaces.",
    "expressions": [
      "[.Accounts[].Id] | join(\" \")",
      ".Accounts[].Id | @tsv | sub(\"\\t\";\" \";\"g\")"
    ],
    "data": [
      {
        "input": {
          "Accounts": [
            {
              "Id": "204359864429"
            },
            {
              "Id": "224271824096"
            },
            {
              "Id": "282276286062"
            },
            {
              "Id": "210394168456"
            },
            {
              "Id": "090161402717"
            }
          ]
        },
        "output": "204359864429 224271824096 282276286062 210394168456 090161402717"
      }
    ],
    "identifier": 56897802
  },
  {
    "context": [
      "I am trying to print as below,\r\n\r\n    Id\r\n    Result\r\n    Others",
      "Assuming the input has been rectified:\r\n\r\n    $ jq -r 'keys_unsorted[]' t1.json\r\n    Id\r\n    Result\r\n    Other"
    ],
    "utterance": "List all top-level keys in the object in any order.",
    "expressions": [
      "keys_unsorted[]",
      ". | keys_unsorted[]",
      "-r 'keys_unsorted[]'"
    ],
    "data": [
      {
        "input": {
          "Id": "Role1",
          "Result": [
            {
              "Sub1": 1,
              "Sub2": 1,
              "StrSub": "ABC"
            },
            {
              "Sub1": 2,
              "Sub2": 1,
              "StrSub": "CDE"
            }
          ],
          "Other": "NA"
        },
        "output": [
          "Id",
          "Result",
          "Other"
        ]
      }
    ],
    "identifier": 56917861
  },
  {
    "context": [
      "Logs in the file like:\n2019-07-04T09:53:04-07:00\tsome.package.placeholder.stderr\t{\"log\": \"The content\", \"foo\": \"bar\", \"baz\": \"blah\"}\n2019-07-04T10:15:37-07:00\tsome.package.placeholder.stderr\t{\"log\": \"I'm actually\", \"foo\": \"bar\", \"baz\": \"blah\"}\n2019-07-04T10:15:37-07:00\tsome.package.placeholder.stderr\t{\"log\": \"Interested on\", \"foo\": \"bar\", \"baz\": \"blah\"}",
      "So when tailing I get:\nThe content\nI'm actually\nInterested on",
      "Or even:\n2019-07-04T09:53:04-07:00\tThe content\n2019-07-04T10:15:37-07:00\tI'm actually\n2019-07-04T10:15:37-07:00\tInterested on",
      "$ tail -f myLogFile | jq -Rr 'split(\"\\t\") | [.[0], (.[2] | fromjson.log)] | join(\"\\t\")'",
      "2019-07-04T09:53:04-07:00   The content\n2019-07-04T10:15:37-07:00   I'm actually\n2019-07-04T10:15:37-07:00   Interested on"
    ],
    "utterance": "Extract the first field (date) and the .log value from each tab-delimited line, outputting both separated by a tab, for each line in the stream.",
    "expressions": [
      "jq -Rr 'split(\"\\t\") | [.[0], (.[2] | fromjson.log)] | join(\"\\t\")'"
    ],
    "data": [
      {
        "input": "2019-07-04T09:53:04-07:00\tsome.package.placeholder.stderr\t{\"log\": \"The content\", \"foo\": \"bar\", \"baz\": \"blah\"}\n2019-07-04T10:15:37-07:00\tsome.package.placeholder.stderr\t{\"log\": \"I'm actually\", \"foo\": \"bar\", \"baz\": \"blah\"}\n2019-07-04T10:15:37-07:00\tsome.package.placeholder.stderr\t{\"log\": \"Interested on\", \"foo\": \"bar\", \"baz\": \"blah\"}",
        "output": "2019-07-04T09:53:04-07:00\tThe content\n2019-07-04T10:15:37-07:00\tI'm actually\n2019-07-04T10:15:37-07:00\tInterested on"
      }
    ],
    "identifier": 56892361
  },
  {
    "context": [
      "I\u2019ve got two Apache Avro schemas (essentially JSON) - one being a \"common\" part across many schemas and another one as an . Looking for a way to merge them in a shell script.",
      "An expected result should be something like this (the order of the keys doesn\u2019t make a difference)\n{\n  \"name\": \"schema1\",\n  \"namespace\": \"test\",\n  \"doc\": \"Test schema\",\n  \"type\": \"record\",\n  \"fields\": [\n      {\n        \"name\": \"property1\",\n        \"type\": [\n          \"null\",\n          \"string\"\n        ],\n        \"default\": null,\n        \"doc\": \"Schema 1 specific field\"\n      },\n    {\n      \"name\": \"id\",\n      \"type\": \"string\"\n    }\n  ]\n}",
      "jq -s '.[0] as $o1 | .[1] as $o2 | ($o1 + $o2) |.fields = ($o2.fields + $o1.fields) ' base.avsc schema1.avsc",
      "jq --argfile base base.avsc '\n  $base + .\n  | .fields += ($base|.fields)\n' schema1.avsc",
      "jq -s '\n  .[0].fields as $f | add | .fields += $f\n' base.avsc schema1.avsc"
    ],
    "utterance": "Combine two Avro schema files by merging all fields from both, so the resulting fields array contains all elements from both schemas.",
    "expressions": [
      "jq -s '.[0] as $o1 | .[1] as $o2 | ($o1 + $o2) | .fields = ($o2.fields + $o1.fields)' base.avsc schema1.avsc",
      "jq --argfile base base.avsc '$base + . | .fields += ($base|.fields)' schema1.avsc",
      "jq -s '.[0].fields as $f | add | .fields += $f' base.avsc schema1.avsc"
    ],
    "data": [
      {
        "input": {
          "base.avsc": {
            "type": "record",
            "fields": [
              {
                "name": "id",
                "type": "string"
              }
            ]
          },
          "schema1.avsc": {
            "name": "schema1",
            "namespace": "test",
            "doc": "Test schema",
            "fields": [
              {
                "name": "property1",
                "type": [
                  "null",
                  "string"
                ],
                "default": null,
                "doc": "Schema 1 specific field"
              }
            ]
          }
        },
        "output": {
          "name": "schema1",
          "namespace": "test",
          "doc": "Test schema",
          "type": "record",
          "fields": [
            {
              "name": "property1",
              "type": [
                "null",
                "string"
              ],
              "default": null,
              "doc": "Schema 1 specific field"
            },
            {
              "name": "id",
              "type": "string"
            }
          ]
        }
      }
    ],
    "identifier": 56784164
  },
  {
    "context": [
      "I want to get the last version of Container Versions from the file.",
      "Assuming you wanted to get the last item of the `SupportedVersions` array and the last item of its `ContainerVersions` array, just use a negative index. Negative indices will index relative to the end of the array, rather than the start.",
      ".SupportedVersions[-1].ContainerVersions[-1]"
    ],
    "utterance": "Get the last value in the ContainerVersions array of the last object in SupportedVersions.",
    "expressions": [
      ".SupportedVersions[-1].ContainerVersions[-1]"
    ],
    "data": [
      {
        "input": {
          "SupportedVersions": [
            {
              "EKSVersion": "1.13",
              "ContainerVersions": [
                "0.0.62",
                "0.0.63",
                "0.0.73",
                "0.0.75",
                "0.0.77"
              ]
            },
            {
              "EKSVersion": "1.14",
              "ContainerVersions": [
                "0.0.62",
                "0.0.63",
                "0.0.66",
                "0.0.67",
                "0.0.68",
                "0.0.69",
                "0.0.70",
                "0.0.71",
                "0.0.72",
                "0.0.73",
                "0.0.74",
                "0.0.75",
                "0.0.79"
              ]
            }
          ]
        },
        "output": "0.0.79"
      }
    ],
    "identifier": 56949357
  },
  {
    "context": [
      "I have an input file that has independent JSON objects (i.e. not an array) and I want to filter a few fields from each of them and create an array with the resulting elements.",
      "From this list of objects I'd like to get only the fields `email` and `time`, and ignore the rest",
      "What is the correct way then, of aggregating the query results into an array, when the input is not an array?",
      "I found the result I wanted, which is a combination of the slurp operator and map.\n\nI realized that the query \n\n`jq -s 'map({email: (.email|values), time:.time })' input.json`",
      "Putting it all together:\n\n    jq -n '[inputs | {email, time }]' input.json",
      "If there are some inputs that you want to filter out, you could use `select`, e.g.\n\n    jq -n '[inputs | select(.email) | {email, time } ]' input.json"
    ],
    "utterance": "Aggregate all objects from a file containing separate objects, each selecting only the email and time fields, into one array, omitting entries without an email field.",
    "expressions": [
      "jq -s 'map({email: (.email|values), time: (.time|values) })' input.json",
      "jq -n '[inputs | select(.email) | {email, time } ]' input.json"
    ],
    "data": [
      {
        "input": [
          {
            "name": "myname",
            "environment": "staging",
            "email": "email1@example.com",
            "time": "2017-04-02T05:00:00.046Z"
          },
          {
            "name": "myname",
            "environment": "staging",
            "email": "email2@example.com",
            "time": "2017-02-02T05:00:00.046Z"
          },
          {
            "name": "myname",
            "environment": "staging",
            "email": "email3@example.com",
            "time": "2017-10-02T05:00:00.046Z"
          },
          {
            "name": "myothername",
            "environment": "staging",
            "time": "2017-10-02T05:00:00.046Z"
          }
        ],
        "output": [
          {
            "email": "email1@example.com",
            "time": "2017-04-02T05:00:00.046Z"
          },
          {
            "email": "email2@example.com",
            "time": "2017-02-02T05:00:00.046Z"
          },
          {
            "email": "email3@example.com",
            "time": "2017-10-02T05:00:00.046Z"
          }
        ]
      }
    ],
    "identifier": 56909701
  },
  {
    "context": [
      "I want to update the memory attribute in a `task_definition.json`. The attribute must be an integer otherwise the API throws an error.",
      "export TASK_DEFINITION_MEMORY=256\njq '.containerDefinitions[0].memory = env.TASK_DEFINITION_MEMORY' task_definition.json > tmp.$$.json && mv tmp.$$.json task_definition.json",
      "actual output\n{\n  \"containerDefinitions\": [\n    {\n      \"cpu\": 128,\n      \"image\": \"...\",\n      \"memory\": \"256\"\n      ...\n    }\n  ]\n}",
      "What\u2019s needed here is a call to `tonumber` to convert the string to a number.",
      "An alternative would be to pass the number into jq using `--argjson`."
    ],
    "utterance": "Update the memory field in the first element of containerDefinitions to the value of the TASK_DEFINITION_MEMORY environment variable as an integer.",
    "expressions": [
      ".containerDefinitions[0].memory = (env.TASK_DEFINITION_MEMORY | tonumber)",
      ".containerDefinitions[0].memory = $MEMORY",
      "--argjson MEMORY \"$TASK_DEFINITION_MEMORY\""
    ],
    "data": [
      {
        "input": {
          "containerDefinitions": [
            {
              "cpu": 128,
              "image": "...",
              "memory": 512
            }
          ]
        },
        "output": {
          "containerDefinitions": [
            {
              "cpu": 128,
              "image": "...",
              "memory": 256
            }
          ]
        }
      }
    ],
    "identifier": 56949964
  },
  {
    "context": [
      "I would like to catch a value using jq for Storage and Container in my json in order to pass it as variable in bash but I have problem parsing it.",
      "The expected result would be that x = abdelvt33cpgsa and y = lama",
      ".parameters.Containers.value[].Storage",
      ".parameters.Containers.value[].Container"
    ],
    "utterance": "Extract the Storage and Container values from each object inside parameters.Containers.value.",
    "expressions": [
      ".parameters.Containers.value[].Storage",
      ".parameters.Containers.value[].Container"
    ],
    "data": [
      {
        "input": {
          "$schema": "https://schema.management.azure.com/schemas/2015-01-01/deploymentParameters.json#",
          "contentVersion": "1.0.0.0",
          "parameters": {
            "Containers": {
              "value": [
                {
                  "Storage": "abdelvt33cpgsa",
                  "RG": "samitestik2",
                  "Container": "lama"
                },
                {
                  "Storage": "abdelvt44cpgsa",
                  "RG": "samitestik2",
                  "Container": "baba"
                }
              ]
            }
          }
        },
        "output": [
          "abdelvt33cpgsa",
          "abdelvt44cpgsa"
        ]
      },
      {
        "input": {
          "$schema": "https://schema.management.azure.com/schemas/2015-01-01/deploymentParameters.json#",
          "contentVersion": "1.0.0.0",
          "parameters": {
            "Containers": {
              "value": [
                {
                  "Storage": "abdelvt33cpgsa",
                  "RG": "samitestik2",
                  "Container": "lama"
                },
                {
                  "Storage": "abdelvt44cpgsa",
                  "RG": "samitestik2",
                  "Container": "baba"
                }
              ]
            }
          }
        },
        "output": [
          "lama",
          "baba"
        ]
      }
    ],
    "identifier": 56965825
  },
  {
    "context": [
      "I would be able to search for a field > x and if it is > x, replace it with x.",
      "if JSONFile.Room2Set < 62\n    set Room2Set = 62",
      "def clamp_min($minInc): if . < $minInc then $minInc else . end;",
      "def clamp_max($maxInc): if . > $maxInc then $maxInc else . end;",
      "def clamp($minInc; $maxInc): clamp_min($minInc) | clamp_max($maxInc);",
      "$ jq --arg col \"Room2Set\" --argjson max '62' '\ndef clamp_max($maxInc): if . > $maxInc then $maxInc else . end;\n(INDEX(.cols|to_entries[]|{id:.value.id,index:.key};.id)) as $cols\n  | .rows[].c[$cols[$col].index] |= (objects.v |= clamp_max($max))\n' input.json",
      "jq --arg col Room2Set --argjson mx 72  --argjson mn 62 -f clamp.jq input.json",
      "def clamp: if . > $mx then $mx elif . < $mn then $mn else . end;\n(.cols | map(.id) | index($col)) as $ix\n| .rows[].c[$ix].v |= clamp"
    ],
    "utterance": "Replace all values in the Room2Set column with 62 if they are less than 62, or with 72 if they are greater than 72; otherwise, leave them unchanged.",
    "expressions": [
      "def clamp: if . > $mx then $mx elif . < $mn then $mn else . end;\n(.cols | map(.id) | index($col)) as $ix\n| .rows[].c[$ix].v |= clamp"
    ],
    "data": [
      {
        "input": {
          "cols": [
            {
              "type": "datetime",
              "id": "Time",
              "label": "Time"
            },
            {
              "type": "number",
              "id": "Room1Temp",
              "label": "Room One Temp"
            },
            {
              "type": "number",
              "id": "Room1Set",
              "label": "Room One Set"
            },
            {
              "type": "string",
              "id": "Annot1",
              "label": "Room One Note"
            },
            {
              "type": "number",
              "id": "Room2Temp",
              "label": "Room Two Temp"
            },
            {
              "type": "number",
              "id": "Room2Set",
              "label": "Room Two Set"
            },
            {
              "type": "string",
              "id": "Annot2",
              "label": "Room Two Note"
            },
            {
              "type": "number",
              "id": "Room3Temp",
              "label": "Room Three Temp"
            },
            {
              "type": "number",
              "id": "State",
              "label": "State"
            },
            {
              "type": "number",
              "id": "Room4Temp",
              "label": "Room Four Temp"
            },
            {
              "type": "number",
              "id": "Quality",
              "label": "Quality"
            }
          ],
          "rows": [
            {
              "c": [
                {
                  "v": "Date(2019,6,4,20,31,13)"
                },
                {
                  "v": 68.01
                },
                {
                  "v": 68.0
                },
                null,
                {
                  "v": 62.02
                },
                {
                  "v": 55.89
                },
                null,
                null,
                {
                  "v": 4
                },
                {
                  "v": 69.0
                },
                {
                  "v": 1.052
                }
              ]
            }
          ]
        },
        "output": {
          "cols": [
            {
              "type": "datetime",
              "id": "Time",
              "label": "Time"
            },
            {
              "type": "number",
              "id": "Room1Temp",
              "label": "Room One Temp"
            },
            {
              "type": "number",
              "id": "Room1Set",
              "label": "Room One Set"
            },
            {
              "type": "string",
              "id": "Annot1",
              "label": "Room One Note"
            },
            {
              "type": "number",
              "id": "Room2Temp",
              "label": "Room Two Temp"
            },
            {
              "type": "number",
              "id": "Room2Set",
              "label": "Room Two Set"
            },
            {
              "type": "string",
              "id": "Annot2",
              "label": "Room Two Note"
            },
            {
              "type": "number",
              "id": "Room3Temp",
              "label": "Room Three Temp"
            },
            {
              "type": "number",
              "id": "State",
              "label": "State"
            },
            {
              "type": "number",
              "id": "Room4Temp",
              "label": "Room Four Temp"
            },
            {
              "type": "number",
              "id": "Quality",
              "label": "Quality"
            }
          ],
          "rows": [
            {
              "c": [
                {
                  "v": "Date(2019,6,4,20,31,13)"
                },
                {
                  "v": 68.01
                },
                {
                  "v": 68.0
                },
                null,
                {
                  "v": 62.02
                },
                {
                  "v": 62
                },
                null,
                null,
                {
                  "v": 4
                },
                {
                  "v": 69.0
                },
                {
                  "v": 1.052
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 56907530
  },
  {
    "context": [
      "I want to extract only the items where the url starts with `/classroom-videos/`",
      "Ideally my output would look like this:\n\n[\n    {\n    \"url\": \"/classroom-videos/lesson1/sublesson1/video\",\n        \"data\": {\n            \"fieldset\": \"lesson-video-overview\",\n            \"title\": \"5th Grade Math - Interpreting Fractions\",\n        },\n        \"order\": 4\n    },\n    {\n    \"url\": \"/classroom-videos/lesson1/sublesson2/video\",\n        \"data\": {\n            \"fieldset\": \"lesson-video-clip-single\",\n            \"title\": \"Post-Lesson Debrief Part 5\",\n        },\n        \"order\": 14\n    }\n]\n",
      "`jq '.[] | select(.url |test(\"classroom-videos\"))'`"
    ],
    "utterance": "Select all items whose url field starts with '/classroom-videos/'.",
    "expressions": [
      ".[] | select(.url | startswith(\"/classroom-videos/\"))",
      "map(select(.url | startswith(\"/classroom-videos/\")))"
    ],
    "data": [
      {
        "input": [
          {
            "url": "/classroom-videos/lesson1/sublesson1/video",
            "data": {
              "fieldset": "lesson-video-overview",
              "title": "5th Grade Math - Interpreting Fractions"
            },
            "order": 4
          },
          {
            "url": "/classroom-videos/lesson1/sublesson2/video",
            "data": {
              "fieldset": "lesson-video-clip-single",
              "title": "Post-Lesson Debrief Part 5"
            },
            "order": 14
          },
          {
            "url": "about-us",
            "data": {
              "fieldset": "lesson-video-clip-single",
              "title": "Lesson Part 2B"
            },
            "order": 6
          }
        ],
        "output": [
          {
            "url": "/classroom-videos/lesson1/sublesson1/video",
            "data": {
              "fieldset": "lesson-video-overview",
              "title": "5th Grade Math - Interpreting Fractions"
            },
            "order": 4
          },
          {
            "url": "/classroom-videos/lesson1/sublesson2/video",
            "data": {
              "fieldset": "lesson-video-clip-single",
              "title": "Post-Lesson Debrief Part 5"
            },
            "order": 14
          }
        ]
      }
    ],
    "identifier": 56958052
  },
  {
    "context": [
      "How could I output an array-type output like this? The main challenge for me is extracting the key e.g. \"yomama/first key\" and in the ideal world, I can filter like just give me an array of those keys that start with \"yomama\" (but not yopapa)",
      "Assuming the input is in `so.json` and corrected to well-formatted JSON you may use:\n```\njq '[.pages | to_entries[] | {\"url\": .key, \"data\": .value.data, \"order\": .value.order}]' < so.json \n```",
      "Here's a solution that does not require being explicit about including all the other keys:\n```\n.pages\n| [ to_entries[]\n    | select(.key | startswith(\"yomama\"))\n    | {url: .key} + .value ]\n```"
    ],
    "utterance": "Produce an array of objects containing url, data, and order for each entry whose key starts with \"yomama\".",
    "expressions": [
      ".pages | [to_entries[] | select(.key | startswith(\"yomama\")) | {url: .key} + .value]",
      "[.pages | to_entries[] | select(.key | startswith(\"yomama\")) | {\"url\": .key, \"data\": .value.data, \"order\": .value.order}]"
    ],
    "data": [
      {
        "input": {
          "pages": {
            "yomama/first key": {
              "data": {
                "fieldset": "lesson-video-overview",
                "title": "5th Grade Math - Interpreting Fractions"
              },
              "order": 4
            },
            "yomama/second key": {
              "data": {
                "fieldset": "lesson-video-clip-single",
                "title": "Post-Lesson Debrief Part 5"
              },
              "order": 14
            },
            "yopapa/Third key": {
              "data": {
                "fieldset": "lesson-video-clip-single",
                "title": "Lesson Part 2B"
              },
              "order": 6
            }
          }
        },
        "output": [
          {
            "url": "yomama/first key",
            "data": {
              "fieldset": "lesson-video-overview",
              "title": "5th Grade Math - Interpreting Fractions"
            },
            "order": 4
          },
          {
            "url": "yomama/second key",
            "data": {
              "fieldset": "lesson-video-clip-single",
              "title": "Post-Lesson Debrief Part 5"
            },
            "order": 14
          }
        ]
      }
    ],
    "identifier": 56956419
  },
  {
    "context": [
      "The two strings I wanted to search and grep from it are\r\n\r\n1. \"first_review\": true \r\n2. \"firstReview\": true\r\n\r\nIf any one of them (or both of them) are true, then I want to print  Results as 'fail' and only if both are 'false' , then I want to print results as Pass.",
      "if any(..|objects|.first_review,.firstReview; . == true) then \"Fail\" else \"Pass\" end",
      ".packages[0].Treat.firstReview\n       or .packages[0].license_approval_flags.first_review\n      | if . == true then \"Fail\" else \"Pass\" end",
      "reduce (.. | objects) as $o ({};\n  if $o.firstReview == false then .firstReview = false else . end\n   | if $o.first_review == false then .first_review = false else . end )\n| if length == 2 then \"Pass\" else \"Fail\" end"
    ],
    "utterance": "Check if any key named either first_review or firstReview anywhere in the structure is true, and print 'Fail' if found, otherwise print 'Pass'.",
    "expressions": [
      "if any(..|objects|.first_review,.firstReview; . == true) then \"Fail\" else \"Pass\" end",
      ".packages[0].Treat.firstReview or .packages[0].license_approval_flags.first_review | if . == true then \"Fail\" else \"Pass\" end",
      "reduce (.. | objects) as $o ({};\n  if $o.firstReview == false then .firstReview = false else . end\n   | if $o.first_review == false then .first_review = false else . end )\n| if length == 2 then \"Pass\" else \"Fail\" end"
    ],
    "data": [
      {
        "input": {
          "scan-dir": "/var/local",
          "scan_time_ms": "20394 ms",
          "by": "a user",
          "project": "local",
          "date": "2019-06-30T10:48:07.270Z",
          "g_version": "2.2.16",
          "q_version": "1.0.112",
          "directories_scanned": 25,
          "files_scanned": 41,
          "packages": [
            {
              "name": "flow",
              "version": "unknown",
              "path": "development_environment/flow",
              "source": "__init__.py",
              "file_path": "development_environment/flow/__init__.py",
              "analyzer": "package-finder",
              "license_files": [
                {
                  "file": "development_environment/flow/__init__.py",
                  "legal": false,
                  "legal_category": "Other",
                  "contains_keywords": true,
                  "blocks": [
                    {
                      "text": "# -*- coding: utf-8 -*-\n#\n# ",
                      "matches": null
                    }
                  ],
                  "license_types": [
                    "Apache-2.0"
                  ],
                  "license_approval_flags": {
                    "approved": true,
                    "first_review": false,
                    "needs_legal_approval": false,
                    "prohibited": false,
                    "no_license_info": false
                  },
                  "affects_package_license_types": true
                },
                {
                  "file": "development_environment/flow/base_flow.py",
                  "legal": false,
                  "legal_category": "Other",
                  "contains_keywords": true,
                  "blocks": [],
                  "license_types": [
                    "Apache-2.0"
                  ],
                  "license_approval_flags": {
                    "approved": true,
                    "first_review": false,
                    "needs_legal_approval": false,
                    "prohibited": false,
                    "no_license_info": false
                  },
                  "affects_package_license_types": true
                }
              ],
              "license_types": [
                "Apache-2.0"
              ],
              "license_approval_flags": {
                "approved": true,
                "first_review": false,
                "needs_legal_approval": false,
                "prohibited": false,
                "no_license_info": false,
                "reference_only": false
              },
              "license_approval_status": "Approved",
              "package_hash": "c7d6757c6c814a22b44d8299cace3ec1",
              "Treat": {
                "TreatReviewed": false,
                "possiblyRelatedPackages": [],
                "searchedName": "flow",
                "searchedVersion": "unknown",
                "allLicensesMatch": false,
                "firstReview": true,
                "firstReviewReason": "New package and not exempt"
              }
            }
          ],
          "Treat_checked": true
        },
        "output": "Fail"
      }
    ],
    "identifier": 56839659
  },
  {
    "context": [
      "I am trying to merge the files using --argjson but it throws \r\n\r\n> argument list too long",
      "Is there any other way I can merge these files?",
      "File 1: \r\n\r\n    {\r\n        \"id\": \"test\",\r\n        \"data\": [\r\n            {\r\n                \"path\": \"a/1\"\r\n            },\r\n            {\r\n                \"path\": \"a/2\"\r\n            }\r\n        ],\r\n        \"information\": {\r\n            \"id\": \"1\"\r\n        }\r\n    }\r\n\r\nFile 2:\r\n        \r\n    {\r\n      \"records\": [\r\n        {\r\n          \"version\": {\r\n            \"data\": [\r\n                {\r\n                    \"path\": \"1\"\r\n                }\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }",
      "Output File:\r\n        \r\n    {\r\n      \"records\": [\r\n        {\r\n          \"version\": {\r\n            \"data\": [\r\n              {\r\n                \"path\": \"1\"\r\n              },\r\n              {\r\n                \"path\": \"a/1\"\r\n              },\r\n              {\r\n                \"path\": \"a/2\"\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n",
      "jq --argfile groupInfo <(jq .data file1.json) '.records[].version.data+=$groupInfo' file2.json",
      "jq -s '\n  .[0].data as $groupInfo\n  | .[1]\n  | .records[].version.data+=$groupInfo\n' file1.json file2.json"
    ],
    "utterance": "Append the data array from the first file to the records[].version.data arrays in the second file.",
    "expressions": [
      ".records[].version.data += $groupInfo",
      ".[0].data as $groupInfo | .[1] | .records[].version.data += $groupInfo"
    ],
    "data": [
      {
        "input": {
          "file1.json": {
            "id": "test",
            "data": [
              {
                "path": "a/1"
              },
              {
                "path": "a/2"
              }
            ],
            "information": {
              "id": "1"
            }
          },
          "file2.json": {
            "records": [
              {
                "version": {
                  "data": [
                    {
                      "path": "1"
                    }
                  ]
                }
              }
            ]
          }
        },
        "output": {
          "records": [
            {
              "version": {
                "data": [
                  {
                    "path": "1"
                  },
                  {
                    "path": "a/1"
                  },
                  {
                    "path": "a/2"
                  }
                ]
              }
            }
          ]
        }
      }
    ],
    "identifier": 56974336
  },
  {
    "context": [
      "I want to be able to narrow my search and only retrieve objects that are greater or less(older or younger) than YEAR(example 2015). This is tricky because the attributes can have multiple year values, some greater and less than the year I am searching for.",
      "can figure out how to search all the values and determine if all of them are less than 2000.",
      "If I search for anything less than 2000, I want a query that will only return \"stack overflow\" since it does not have a 20XX value in the available values.",
      "In brief, `all/2` is your friend.",
      ".tokens[] | select( all(.year[]; . < $mx) )"
    ],
    "utterance": "Find objects where all values in the year attribute are less than 2000.",
    "expressions": [
      ".tokens[] | select( all(.year[]; . < $mx) )"
    ],
    "data": [
      {
        "input": {
          "tokens": [
            {
              "Name": "stack overflow",
              "year": [
                "1997",
                "1998",
                "1997"
              ]
            },
            {
              "Name": "Return pizza",
              "year": [
                "1998",
                "2015",
                "2014",
                "1998"
              ]
            }
          ]
        },
        "output": {
          "Name": "stack overflow",
          "year": [
            "1997",
            "1998",
            "1997"
          ]
        }
      }
    ],
    "identifier": 56977748
  },
  {
    "identifier": 57007962
  },
  {
    "context": [
      "aws ec2 describe-network-acls |jq -r '.NetworkAcls[].Entries[] | [.RuleNumber, .Protocol, .Egress, .CidrBlock, .RuleAction] |@csv'",
      ".NetworkAcls[]\n| [.VpcId, .NetworkAclId]\n + (.Entries[] | [.RuleNumber, .Protocol, .Egress, .CidrBlock, .RuleAction])\n| @csv",
      "\"vpc-e68f6f8d\",\"acl-b6d916dd\",100,\"-1\",true,\"0.0.0.0/0\",\"allow\""
    ],
    "utterance": "For each network ACL, output VpcId, NetworkAclId, RuleNumber, Protocol, Egress, CidrBlock, and RuleAction as CSV rows.",
    "expressions": [
      ".NetworkAcls[] | [.VpcId, .NetworkAclId] + (.Entries[] | [.RuleNumber, .Protocol, .Egress, .CidrBlock, .RuleAction]) | @csv"
    ],
    "identifier": 56989947
  },
  {
    "context": [
      "I am trying to extract the content of dumpName using jq, but it does not work. I have attempted to simplify the structure of the original file as I cannot post the full details here.",
      "I would also like to get the content of param2. This can be collected in a separate jq statement if needed.",
      "Desired output:\n\n    name_of_dump\n    random_val\n    testtest",
      "Since the user asked to display **dumpName** and **param2**, here is the correct code:\n\n    jq -r '.get.download.detail[] | .dumpInfo.dumpName, .datastore[].param2'\n\nOutput:\n\n    name_of_dump\n    random_val\n    testtest",
      "You might like to consider this one-liner:\n\n    jq '.. | (.dumpName? // empty), (.param2? // empty)' input.json"
    ],
    "utterance": "Extract the values of dumpName and every param2 field from all detail entries.",
    "expressions": [
      ".get.download.detail[] | .dumpInfo.dumpName, .datastore[].param2",
      ".. | (.dumpName? // empty), (.param2? // empty)"
    ],
    "data": [
      {
        "input": {
          "get": {
            "download": {
              "ebR": true,
              "detail": [
                {
                  "downloadHost": "xxx.jgs.com",
                  "downloadURL": "xxx.jgs.com",
                  "dumpInfo": {
                    "dumpCategory": "Other",
                    "dumpContentType": "UNKNOWN",
                    "dumpId": "test",
                    "dumpName": "name_of_dump",
                    "dumpSize": 1200,
                    "dumpStatus": "COMPLETED",
                    "dumpUploadDate": "date",
                    "vis": "who_see_it"
                  },
                  "datastore": [
                    {
                      "param1": "random_val",
                      "param2": "random_val"
                    },
                    {
                      "param1": "testtest",
                      "param2": "testtest"
                    }
                  ],
                  "Info": {
                    "webpage": "test@test.com"
                  }
                }
              ]
            }
          }
        },
        "output": [
          "name_of_dump",
          "random_val",
          "testtest"
        ]
      }
    ],
    "identifier": 56988352
  },
  {
    "context": [
      "I want to aggregate the json present on each line of file based on the date and account. There might be multiple records with same date and account, we have to aggregate count based on date and account_no.",
      "sample file:",
      "{\u0013date\u0013:\u00132019-04-01\u0013,\u0013count\u0013:0,\u0013account_no\u0013:\u00131591\u0013}",
      "{\u0013date\u0013:\u00132019-04-01\u0013,\u0013count\u0013:1,\u0013account_no\u0013:\u00131592\u0013}",
      "jq using `inputs` is a good way to go.",
      "Then a solution could be achieved by:",
      "sigma_by(inputs; \"\\(.date):\\(.account_no)\"; .count)",
      "provided the -n command-line option is used.",
      "With the sample input, the output would be:",
      "{",
      "  \"2019-04-01:1591\": 0,",
      "  \"2019-04-01:1592\": 1",
      "}",
      "a variant of `sigma_by` that uses a dictionary of dictionaries might be warranted",
      "def sigma_by(s; a; b; g):\n  reduce s as $x  (null; .[$x|a][$x|b] += ($x|g));\n\nsigma_by(inputs; .date; .account_no; .count)"
    ],
    "utterance": "Aggregate the sums of the count field for each unique pair of date and account_no, grouping by both fields.",
    "expressions": [
      "def sigma_by(s; f; g): reduce s as $x  (null; .[$x|f] += ($x|g)); sigma_by(inputs; \"\\(.date):\\(.account_no)\"; .count)",
      "def sigma_by(s; a; b; g): reduce s as $x  (null; .[$x|a][$x|b] += ($x|g)); sigma_by(inputs; .date; .account_no; .count)"
    ],
    "data": [
      {
        "input": [
          {
            "date": "2019-04-01",
            "count": 0,
            "account_no": "1591"
          },
          {
            "date": "2019-04-01",
            "count": 1,
            "account_no": "1592"
          }
        ],
        "output": {
          "2019-04-01:1591": 0,
          "2019-04-01:1592": 1
        }
      }
    ],
    "identifier": 56986527
  },
  {
    "context": [
      "But when I try to pipe it again to `jq`,",
      "echo '{\"foo\":\"bar\"}' | jq | jq",
      "I get the following message",
      "I was lacking the `.`",
      "echo '{\"foo\":\"bar\"}' | jq . | jq ."
    ],
    "utterance": "Pipe object output through two commands, each passing its input to the output without changes.",
    "expressions": [
      "jq . | jq ."
    ],
    "data": [
      {
        "input": {
          "foo": "bar"
        },
        "output": {
          "foo": "bar"
        }
      }
    ],
    "identifier": 57021765
  },
  {
    "context": [
      "Sample `json` output:\n\n    {\n      \"id\": 2,\n      \"name\": \"Cluster B\"\n    }\n    {\n      \"id\": 1,\n      \"name\": \"Cluster A\"\n    }",
      "Desired output:\n\n    \"1:Cluster A\"\n    \"2:Cluster B\"",
      "sort_by(.id)[]\n| \"\\(.id): \\(.name)\"",
      "[inputs | (.id|tostring) + \":\" + (.name|tostring)] | sort[]"
    ],
    "utterance": "Produce a string for each object combining id and name separated by a colon, in order of id ascending.",
    "expressions": [
      "sort_by(.id)[] | \"\\(.id):\\(.name)\"",
      "[inputs | (.id|tostring) + \":\" + (.name|tostring)] | sort[]"
    ],
    "data": [
      {
        "input": [
          {
            "id": 2,
            "name": "Cluster B"
          },
          {
            "id": 1,
            "name": "Cluster A"
          }
        ],
        "output": [
          "1:Cluster A",
          "2:Cluster B"
        ]
      }
    ],
    "identifier": 57016079
  },
  {
    "context": [
      "From here, I want to be able to rename the percentage field to the gender and grades values. I then want to group by id.",
      "Here is what I expect:\r\n\r\n{\r\n         \"id\": \"abc\",\r\n         \"students\": \"elementary\",\r\n         \"demo_K-2_unspecified\": \"0.1\",\r\n         \"demo_K-2_male\": \"0.5\",\r\n         \"demo_K-2_female\": \"0.4\",\r\n         \"demo_3-6_male\": \"0.3\",\r\n         \"demo_3-6_unspecified\": \"0.6\",\r\n         \"demo_3-6_female\": \"0.5\",\r\n            },\r\n      {\r\n         \"id\": \"def\",\r\n         \"students\": \"midhigh\",\r\n         \"demo_7-9_unspecified\": \"0.2\",\r\n         \"demo_7-9_male\": \"0.2\",\r\n         \"demo_7-9_female\": \"0.6\",\r\n         \"demo_10-12_male\": \"0.1\",\r\n         \"demo_10-12_unspecified\": \"0.1\",\r\n         \"demo_10-12_female\": \"0.8\",\r\n\r\n      }\r\n",
      "With the sample data, the following filter produces the desired output:\r\n```\r\n.data[]\r\n| {id, students} as $ix\r\n| .demographics\r\n| map( {\"demo_\\(.grade)_\\(.gender)\": .percentage} )\r\n| $ix + add\r\n```",
      "As a one-liner\r\n\r\n    jq '.data[] | {id,students} + (.demographics | map( {\"demo_\\(.grade)_\\(.gender)\": .percentage} ) | add)' test2.json"
    ],
    "utterance": "For each item, combine id and students fields with demographic percentage values, using keys formatted as demo_{grade}_{gender}.",
    "expressions": [
      ".data[] | {id,students} + (.demographics | map( {\"demo_\\(.grade)_\\(.gender)\": .percentage} ) | add)"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": "abc",
              "students": "elementary",
              "demographics": [
                {
                  "grade": "K-2",
                  "percentage": "0.1",
                  "gender": "unspecified"
                },
                {
                  "grade": "K-2",
                  "gender": "male",
                  "percentage": "0.5"
                },
                {
                  "gender": "female",
                  "percentage": "0.4",
                  "grade": "K-2"
                },
                {
                  "grade": "3-6",
                  "percentage": "0.3",
                  "gender": "male"
                },
                {
                  "percentage": "0.2",
                  "gender": "unspecified",
                  "grade": "3-6"
                },
                {
                  "grade": "3-6",
                  "gender": "female",
                  "percentage": "0.5"
                }
              ],
              "neighborhood_name": [
                {
                  "percentage": "0.5",
                  "neighborhood": "atwood"
                },
                {
                  "region": "bluff",
                  "percentage": "0.5"
                }
              ]
            },
            {
              "id": "def",
              "students": "midhigh",
              "demographics": [
                {
                  "grade": "7-9",
                  "percentage": "0.2",
                  "gender": "unspecified"
                },
                {
                  "grade": "7-9",
                  "gender": "male",
                  "percentage": "0.2"
                },
                {
                  "gender": "female",
                  "percentage": "0.6",
                  "grade": "7-9"
                },
                {
                  "grade": "10-12",
                  "percentage": "0.1",
                  "gender": "male"
                },
                {
                  "percentage": "0.1",
                  "gender": "unspecified",
                  "grade": "10-12"
                },
                {
                  "grade": "10-12",
                  "gender": "female",
                  "percentage": "0.8"
                }
              ],
              "neighborhood_name": [
                {
                  "percentage": "0.2",
                  "neighborhood": "atwood"
                },
                {
                  "region": "bluff",
                  "percentage": "0.8"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "id": "abc",
            "students": "elementary",
            "demo_K-2_unspecified": "0.1",
            "demo_K-2_male": "0.5",
            "demo_K-2_female": "0.4",
            "demo_3-6_male": "0.3",
            "demo_3-6_unspecified": "0.2",
            "demo_3-6_female": "0.5"
          },
          {
            "id": "def",
            "students": "midhigh",
            "demo_7-9_unspecified": "0.2",
            "demo_7-9_male": "0.2",
            "demo_7-9_female": "0.6",
            "demo_10-12_male": "0.1",
            "demo_10-12_unspecified": "0.1",
            "demo_10-12_female": "0.8"
          }
        ]
      }
    ],
    "identifier": 56967351
  },
  {
    "context": [
      "How to parsing an array inside the array in the same JSON file?",
      "I would like to get output like this:\n\n    {\n      \"id\": 268467952,\n      \"id\": 360891952,\n      \"value\": \"info@thatweblook.co.uk\",\n      \"type\": \"work\"\n    }",
      "This can be generated by the jq filter:\n\n    .customers[] | {customerid: .id} + ._embedded.emails[]"
    ],
    "utterance": "Retrieve each customer's id along with all fields from their embedded emails, producing one object per email.",
    "expressions": [
      ".customers[] | {customerid: .id} + ._embedded.emails[]"
    ],
    "data": [
      {
        "input": {
          "customers": [
            {
              "id": 268467952,
              "firstName": "And",
              "lastName": "Little",
              "gender": "Unknown",
              "photoType": "default",
              "photoUrl": "https://d33v4339jhl8k0.cloudfront.net/customer-avatar/02.png",
              "createdAt": "2019-07-10T12:37:42Z",
              "updatedAt": "2019-07-10T12:37:41Z",
              "background": "",
              "_embedded": {
                "emails": [
                  {
                    "id": 360891952,
                    "value": "info@look.co.uk",
                    "type": "work"
                  }
                ]
              }
            }
          ]
        },
        "output": {
          "customerid": 268467952,
          "id": 360891952,
          "value": "info@look.co.uk",
          "type": "work"
        }
      }
    ],
    "identifier": 57035582
  },
  {
    "context": [
      "I have that json file that I&#39;m trying to convert to csv using the following command:",
      "jq -r &#39;. | map(.Description[], .Encrypted, .ID, .Progress, .Time, .Owner, .Status, .Volume, .Size | join(&quot;,&quot;)) | join(&quot;\\n&quot;)&#39; snapshots1.json",
      "But I&#39;m getting error:",
      "jq: error (at snapshots1.json:24): Cannot iterate over string (&quot;Copied for...)\r\n",
      "I think you were on the right track. Here is how I&#39;d do it:\r\n\r\n    jq -r &#39;.[] | map(..) | @csv&#39; snapshot1.json &gt; snapshot1.csv",
      "There&#39;s a risk in using `..` here to extract the &quot;values&quot; in an object: what if the ordering of the keys in the input objects differs between objects?",
      "Here&#39;s a generic filter which addresses this and other issues. It also emits a suitable &quot;header&quot; line:",
      "So the solution to the original problem would essentially be:\r\n\r\n    object2array(.[]) | @csv",
      "jq -r &#39;(map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.])) as $rows | $cols, $rows[] | @csv&#39; snapshots1.json &gt;&gt; myfile.csv"
    ],
    "utterance": "Output all records as CSV, including a header row with the keys and rows with values from each object, handling different object key orderings.",
    "expressions": [
      "(map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.])) as $rows | $cols, $rows[] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "Description": "Copied for Destination xxx from Sourc 30c for Snapshot 1. Task created on X,52,87,14,76.",
            "Encrypted": false,
            "ID": "snap-074",
            "Progress": "100%",
            "Time": "2019-06-11T09:25:23.110Z",
            "Owner": "883065",
            "Status": "completed",
            "Volume": "vol1",
            "Size": 16
          },
          {
            "Description": "Copied for Destination yy from Source 31c for Snapshot 2. Task created on X,52,87,14,76.",
            "Encrypted": false,
            "ID": "snap-096",
            "Progress": "100%",
            "Time": "2019-06-11T10:18:01.410Z",
            "Owner": "1259",
            "Status": "completed",
            "Volume": "vol-2",
            "Size": 4
          }
        ],
        "output": [
          "\"Description\",\"Encrypted\",\"ID\",\"Progress\",\"Time\",\"Owner\",\"Status\",\"Volume\",\"Size\"",
          "\"Copied for Destination xxx from Sourc 30c for Snapshot 1. Task created on X,52,87,14,76.\",false,\"snap-074\",\"100%\",\"2019-06-11T09:25:23.110Z\",\"883065\",\"completed\",\"vol1\",16",
          "\"Copied for Destination yy from Source 31c for Snapshot 2. Task created on X,52,87,14,76.\",false,\"snap-096\",\"100%\",\"2019-06-11T10:18:01.410Z\",\"1259\",\"completed\",\"vol-2\",4"
        ]
      }
    ],
    "identifier": 56998661
  },
  {
    "context": [
      "I've got the `test.json` file:",
      "What I want to do is to extract `timestamp` and `report` values and store them in some env variables:",
      "the result is:\n\necho $TIMESTAMP $REPORT\n1234567890 'AgeReport'\n\nThe problem is that those single quotes break other commands.\nHow can I get rid of those single quotes?",
      "Rather simply emit the variables by joining them with NULL (`\\u0000`) and read it back in the shell environment\n\n    {\n      IFS= read -r -d '' TIMESTAMP \n      IFS= read -r -d '' REPORT\n    } < <(jq -r '(.timestamp|tostring) + \"\\u0000\" + .report + \"\\u0000\"' test.json)\n\nThis makes your parsing more robust by making the fields joined by NULL delimiter, which can't be part of your string sequence."
    ],
    "utterance": "Extract the values of 'timestamp' and 'report' as strings, separated by a NULL character.",
    "expressions": [
      "(.timestamp|tostring) + \"\\u0000\" + .report + \"\\u0000\""
    ],
    "data": [
      {
        "input": {
          "timestamp": 1234567890,
          "report": "AgeReport"
        },
        "output": "1234567890\u0000AgeReport\u0000"
      }
    ],
    "identifier": 57042755
  },
  {
    "context": [
      "I need to get USD_in",
      "jq: error (at <stdin>:0): Cannot index array with string \"USD_in\"",
      "You evidently meant:",
      "    .[0] | .USD_in",
      "which can be abbreviated to `.[0].USD_in `",
      "You might also wish to consider:",
      "    .[].USD_in"
    ],
    "utterance": "Extract the value of USD_in from the first element of an array.",
    "expressions": [
      ".[0] | .USD_in",
      ".[0].USD_in",
      ".[].USD_in"
    ],
    "data": [
      {
        "input": [
          {
            "USD_in": "2.0200",
            "USD_out": "2.0420",
            "EUR_in": "2.2400",
            "EUR_out": "2.2970",
            "RUB_in": "3.0500",
            "RUB_out": "3.2300",
            "GBP_in": "0.0000",
            "GBP_out": "0.0000",
            "CAD_in": "0.0000",
            "CAD_out": "0.0000",
            "PLN_in": "4.2000",
            "PLN_out": "5.4500",
            "UAH_in": "7.3000",
            "UAH_out": "9.4500",
            "SEK_in": "0.0000",
            "SEK_out": "0.0000",
            "CHF_in": "0.0000",
            "CHF_out": "0.0000",
            "USD_EUR_in": "0.8795",
            "USD_EUR_out": "1.0970",
            "USD_RUB_in": "62.5390",
            "USD_RUB_out": "0.0149",
            "RUB_EUR_in": "0.0133",
            "RUB_EUR_out": "69.3500",
            "JPY_in": "0.0000",
            "JPY_out": "0.0000",
            "CNY_in": "0.0000",
            "CNY_out": "0.0000",
            "CZK_in": "0.0000",
            "CZK_out": "0.0000",
            "NOK_in": "0.0000",
            "NOK_out": "0.0000",
            "filial_id": "16",
            "sap_id": "50011756",
            "info_worktime": "\u041f\u043d 9 00 19 00    |\u0412\u0442 9 00 19 00    |\u0421\u0440 9 00 19 00    |\u0427\u0442 9 00 19 00    |\u041f\u0442 9 00 19 00    |\u0421\u0431 9 00 15 00    |\u0412\u0441        |",
            "street_type": "\u043f\u0440.",
            "street": "\u041f\u0430\u0440\u0442\u0438\u0437\u0430\u043d\u0441\u043a\u0438\u0439",
            "filials_text": "\u041e\u0442\u0434\u0435\u043b\u0435\u043d\u0438\u0435 100/212",
            "home_number": "8-49",
            "name": "\u0411\u0440\u0435\u0441\u0442",
            "name_type": "\u0433."
          }
        ],
        "output": "2.0200"
      }
    ],
    "identifier": 57015284
  },
  {
    "context": [
      "How to read the value of \"a\" & \"b\" using `jq` approach",
      "To extract the values `a` and `b` use:",
      "echo \"$JSON\" | jq '.a'",
      "echo \"$JSON\" | jq '.b'"
    ],
    "utterance": "Extract the values associated with the keys \"a\" and \"b\".",
    "expressions": [
      ".a",
      ".b"
    ],
    "data": [
      {
        "input": {
          "a": "1",
          "b": "2",
          "c": "3"
        },
        "output": "1"
      },
      {
        "input": {
          "a": "1",
          "b": "2",
          "c": "3"
        },
        "output": "2"
      }
    ],
    "identifier": 57064992
  },
  {
    "context": [
      "I have a json like this:\r\n{\r\n  \"key_1\": {\r\n    \"type\": \"string\",\r\n    \"value\": \"foo\"\r\n  },\r\n  \"key_2\": {\r\n    \"type\": \"string\",\r\n    \"value\": \"bar\"\r\n  }\r\n}",
      "that I would like to output like this\r\n{\r\n  \"key_1\": \"foo\",\r\n  \"key_2\": \"bar\"\r\n}",
      "Since the task entails mapping the values of the top-level keys, `map_values` should come to mind:\r\n\r\n    map_values(.value)",
      "You could also use `with_entries`, which might make sense if you wanted to manipulate the top-level keys as well:\r\n\r\n    with_entries( .value |= .value )"
    ],
    "utterance": "For each top-level key, replace its value with the nested 'value' property",
    "expressions": [
      "map_values(.value)",
      "with_entries(.value |= .value)"
    ],
    "data": [
      {
        "input": {
          "key_1": {
            "type": "string",
            "value": "foo"
          },
          "key_2": {
            "type": "string",
            "value": "bar"
          }
        },
        "output": {
          "key_1": "foo",
          "key_2": "bar"
        }
      }
    ],
    "identifier": 57055808
  },
  {
    "context": [
      "I have some data that looks like this\n{\n    \"type1\": [\n      \"a\", \"b\"\n    ],\n    \"type2\": [\n      \"c\", \"d\"\n    ],\n    \"type3\": \"x\"\n}\n\nAnd I would like to convert it into \n[\n    {\"value\": \"a\", \"type\": \"type1\" },\n    {\"value\": \"b\", \"type\": \"type1\" },\n    {\"value\": \"c\", \"type\": \"type2\" },\n    {\"value\": \"d\", \"type\": \"type2\" },\n    {\"value\": \"x\", \"type\": \"type3\" },\n]",
      "to_entries \n  | map_values({value:[.value]|flatten, type:.key})\n  | map_values({value:.value[], type:.type})",
      "Here is an efficient, concise and perhaps \"canonical\" solution:\n\n    [to_entries[]\n     | (if .value|type == \"array\" then {value: .value[]} else {value} end)\n       + {type: .key} ]",
      "I prefer to use the various type filters with alternation to make it more compact. Assuming you would only have to deal with values of arrays or scalars, I would write it this way:\n\n    [to_entries[] | {value:(.value | arrays[] // .), type:.key}]"
    ],
    "utterance": "Convert an object with keys mapping to either arrays or scalar values into an array of objects, each having 'type' as the original key and 'value' as each array element or scalar.",
    "expressions": [
      "[to_entries[] | (if .value|type == \"array\" then {value: .value[]} else {value} end) + {type: .key} ]",
      "[to_entries[] | {value:(.value | arrays[] // .), type:.key}]"
    ],
    "data": [
      {
        "input": {
          "type1": [
            "a",
            "b"
          ],
          "type2": [
            "c",
            "d"
          ],
          "type3": "x"
        },
        "output": [
          {
            "value": "a",
            "type": "type1"
          },
          {
            "value": "b",
            "type": "type1"
          },
          {
            "value": "c",
            "type": "type2"
          },
          {
            "value": "d",
            "type": "type2"
          },
          {
            "value": "x",
            "type": "type3"
          }
        ]
      }
    ],
    "identifier": 57054073
  },
  {
    "context": [
      "VALUES=$(cat $JSON_FILE | jq '[\"resources\"] | map([.name,.type,.url])|.array')",
      "echo VALUES is [ [ \"br_wind_rain_tex_png\", \"image\", \"assets/language/zh-cn/bloodriver/gamescene/effect/xiayu/br_wind_rain_tex.png\" ], [ \"baccarat_goodWayListItemBg_png\", \"image\", \"assets/language/zh-cn/baccarat/game/baccarat_goodWayListItemBg.png\" ] ]",
      "jq '.. | scalars' <<< \"$JSON\" | while read -r value\ndo\necho \"$value\"\ndone"
    ],
    "utterance": "Extract all scalar values from a two-dimensional array where each inner array contains three elements.",
    "expressions": [
      ".. | scalars"
    ],
    "data": [
      {
        "input": [
          [
            "br_wind_rain_tex_png",
            "image",
            "assets/language/zh-cn/bloodriver/gamescene/effect/xiayu/br_wind_rain_tex.png"
          ],
          [
            "baccarat_goodWayListItemBg_png",
            "image",
            "assets/language/zh-cn/baccarat/game/baccarat_goodWayListItemBg.png"
          ]
        ],
        "output": [
          "br_wind_rain_tex_png",
          "image",
          "assets/language/zh-cn/bloodriver/gamescene/effect/xiayu/br_wind_rain_tex.png",
          "baccarat_goodWayListItemBg_png",
          "image",
          "assets/language/zh-cn/baccarat/game/baccarat_goodWayListItemBg.png"
        ]
      }
    ],
    "identifier": 57053511
  },
  {
    "context": [
      "I want to produce a new file of the descriptions with their IDs converted to the `idA` values in the lookup file.",
      "For simplicity, we'll begin by constructing a dictionary containing the relevant mapping using `INDEX/2`:\n\n    INDEX($idmap[]; .idB) | map_values(.idA)\n\nNow the task is easy:\n\n    (INDEX($idmap[]; .idB) | map_values(.idA)) as $dict\n    | map( {description, \"idA\": $dict[.idB] } )",
      "This assumes an invocation that uses --argfile idmap ids.json to avoid\nthe unwanted \"slurping\" caused by --slurpfile, but if the latter is used, then you would use `$idmap[][]` instead as noted in the original question."
    ],
    "utterance": "Produce a list where each object's idB in the descriptions file is replaced with the corresponding idA from the id mapping file, keeping the description.",
    "expressions": [
      "(INDEX($idmap[]; .idB) | map_values(.idA)) as $dict | map({description, idA: $dict[.idB]})"
    ],
    "data": [
      {
        "input": {
          "idmap": [
            {
              "idA": 2547,
              "idB": "5d0bf91d191c6554d14572a6"
            },
            {
              "idA": 2549,
              "idB": "5b0473f93d4e53db19f8c249"
            },
            {
              "idA": 2550,
              "idB": "5d0bfabc8f20917b92ff07dc"
            }
          ],
          "descriptions": [
            {
              "idB": "5d0bf91d191c6554d14572a6",
              "description": "Description for 5d0bf91d191c6554d14572a6"
            },
            {
              "idB": "5d0bf49e9236c57281811cfc",
              "description": "Description for 5d0bf49e9236c57281811cfc"
            },
            {
              "idB": "5d0bfabc8f20917b92ff07dc",
              "description": "Description for 5d0bfabc8f20917b92ff07dc"
            }
          ]
        },
        "output": [
          {
            "description": "Description for 5d0bf91d191c6554d14572a6",
            "idA": 2547
          },
          {
            "description": "Description for 5d0bf49e9236c57281811cfc",
            "idA": null
          },
          {
            "description": "Description for 5d0bfabc8f20917b92ff07dc",
            "idA": 2550
          }
        ]
      }
    ],
    "identifier": 57064694
  },
  {
    "context": [
      "I want to write my jq command so if b is missing for a record, then it isn\u2019t output.",
      "Use the if condition to check against the presence of .b to be null. Form the structure to have all fields when not null.",
      "if .b != null then { a, \"b2\":(.b|fromjson), c } else {a, c} end",
      "{a} + ((select(has(\"b\")) | {\"b2\": .b | fromjson}) // {}) + {c}",
      "echo '{\"a\": 123, \"b\": \"{\\\"embedded\\\": 456}\", \"c\": 789}' | jq '{a, c} + if has(\"b\") then {\"b2\": .b | fromjson} else {} end'"
    ],
    "utterance": "Produce an object with fields a and c, and include b2 as the parsed value of b only if b exists; omit b2 if b is missing.",
    "expressions": [
      "if .b != null then { a, \"b2\": (.b | fromjson), c } else {a, c} end",
      "{a} + ((select(has(\"b\")) | {\"b2\": .b | fromjson}) // {}) + {c}",
      "[{a}, (select(.b) | {b2: .b | fromjson}), {c}] | add",
      "{a, \"b2\": (.b | fromjson? // null), c} | if .b2 == null then del(.b2) else . end",
      "{a, c} + if has(\"b\") then {\"b2\": .b | fromjson} else {} end"
    ],
    "data": [
      {
        "input": {
          "a": 123,
          "b": "{\"embedded\": 456}",
          "c": 789
        },
        "output": {
          "a": 123,
          "b2": {
            "embedded": 456
          },
          "c": 789
        }
      },
      {
        "input": {
          "a": 123,
          "c": 789
        },
        "output": {
          "a": 123,
          "c": 789
        }
      }
    ],
    "identifier": 57069940
  },
  {
    "context": [
      "What I would like to extract for example, will be the value for each id that is an integer.",
      "What I\u2019m looking for, is that according to a key and a value, the program returns the object whose specified key contains the value.",
      "To perform the selection based on `.id`, you could use the technique exemplified in the following:",
      "jq --argjson id 10 -f select.jq <<< \"$var\"",
      "where select.jq contains:",
      ".results[] | select( .id == $id )",
      "Since the jq filter here is so short, you might want to include the filter on the command-line instead of putting it in a file."
    ],
    "utterance": "Retrieve all objects from the results array where the id key equals 10.",
    "expressions": [
      ".results[] | select(.id == 10)"
    ],
    "data": [
      {
        "input": {
          "count": 19,
          "next": null,
          "previous": null,
          "results": [
            {
              "id": 10,
              "name": "XXXXXXXXXXXXXXXXXXX",
              "rd": "XXXXXXXXXXX",
              "tenant": "XXXXXXXXXXX",
              "enforce_unique": "XXXXXXXXXXX",
              "description": "XXXXXXXXXXX",
              "tags": [],
              "display_name": "XXXXXXXXXXX",
              "custom_fields": "XXXXXXXXXXX",
              "created": "XXXXXXXXXXX",
              "last_updated": "XXXXXXXXXXX"
            },
            {
              "id": 11,
              "name": "XXXXXXXXXXX",
              "rd": "XXXXXXXXXXX",
              "tenant": "XXXXXXXXXXX",
              "enforce_unique": "XXXXXXXXXXX",
              "description": "XXXXXXXXXXX",
              "tags": "XXXXXXXXXXX",
              "display_name": "XXXXXXXXXXX",
              "custom_fields": "XXXXXXXXXXX",
              "created": "XXXXXXXXXXX",
              "last_updated": "XXXXXXXXXXX"
            }
          ]
        },
        "output": {
          "id": 10,
          "name": "XXXXXXXXXXXXXXXXXXX",
          "rd": "XXXXXXXXXXX",
          "tenant": "XXXXXXXXXXX",
          "enforce_unique": "XXXXXXXXXXX",
          "description": "XXXXXXXXXXX",
          "tags": [],
          "display_name": "XXXXXXXXXXX",
          "custom_fields": "XXXXXXXXXXX",
          "created": "XXXXXXXXXXX",
          "last_updated": "XXXXXXXXXXX"
        }
      }
    ],
    "identifier": 57098068
  },
  {
    "context": [
      "When I use `max_by`, `jq` return `0.1.9` instead of `0.1.21` probably due to the quoted value :",
      "cat test.json | jq 'max_by(.version)'",
      "How can I get the element with version=0.1.21 ?",
      "jq 'sort_by(.version | split(\".\") | map(tonumber))[-1]'",
      "max_by(.version | [splits(\"[.]\"))] | map(tonumber))",
      "def parse:\n [splits(\"[-.]\")]\n | map(tonumber? // .) ;\n\nmax_by(.version|parse)"
    ],
    "utterance": "Find the object with the highest version number, correctly comparing dotted numeric versions such as 0.1.21.",
    "expressions": [
      "sort_by(.version | split(\".\") | map(tonumber))[-1]",
      "max_by(.version | [splits(\"[.]\")] | map(tonumber))",
      "def parse: [splits(\"[-.]\")] | map(tonumber? // .); max_by(.version|parse)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "nodejs",
            "version": "0.1.21",
            "apiVersion": "v1"
          },
          {
            "name": "nodejs",
            "version": "0.1.20",
            "apiVersion": "v1"
          },
          {
            "name": "nodejs",
            "version": "0.1.11",
            "apiVersion": "v1"
          },
          {
            "name": "nodejs",
            "version": "0.1.9",
            "apiVersion": "v1"
          },
          {
            "name": "nodejs",
            "version": "0.1.8",
            "apiVersion": "v1"
          }
        ],
        "output": {
          "name": "nodejs",
          "version": "0.1.21",
          "apiVersion": "v1"
        }
      }
    ],
    "identifier": 57071166
  },
  {
    "context": [
      "I would like to write a simple jq file that allows me to count items grouped by a specified key.",
      "and to invoke it something like",
      "`cat my.json | jq --from-file count_by.jq --args group .header.messageType`",
      "the program would begin with:",
      "group_by(getpath($group)) | ...",
      "jq -f count_by.jq --argjson group '[\"header\", \"messageType\"]'",
      "If you really want to pass in arguments such as `.header.messageType`, there is a way: convert the string $group into a jq path:",
      "($group|split(\".\")|map(select(length>0))) as $path",
      "| group_by(getpath($path)) | map({group: $group, cnt: length})"
    ],
    "utterance": "Count items grouped by a user-specified key, where the key can be provided as a path (such as '.header.messageType') at runtime.",
    "expressions": [
      "($group|split(\".\")|map(select(length>0))) as $path | group_by(getpath($path)) | map({group: $group, cnt: length})"
    ],
    "identifier": 57115265
  },
  {
    "context": [
      "I\u0019m trying to find all common keys in a Json file, given that we don\u0019t know names of keys in the file.",
      "the Json file looks like:\n\n```\n{\n   \"DynamicKey1\" : {\n    \"foo\" : 1,\n    \"bar\" : 2\n\n   },\n   \"DynamicKey2\" : {\n     \"bar\" : 3\n\n   },\n   \"DynamicKey3\" : {\n     \"foo\" : 5,\n     \"zyx\" : 5\n\n   }   \n}\n```",
      "Expect result:\n\n```\n{\n \"foo\"\n}\n```",
      "Keys in all the objects\n\nHere's a solution using a similar approach:\n\n    length as $length\n    | [.[] | keys_unsorted[]] | group_by(.)[]\n    | select(length==$length) \n    | .[0]",
      "Here is a sort-free and time-efficient answer that relies on the efficiency of jq's implementation of lookups in a JSON dictionary.  Since keys are strings, we can simply use the concept of a \"bag of words\" (`bow`): \n\ndef bow(stream): \n  reduce stream as $word ({}; .[$word|tostring] += 1);\n\nWe can now solve the \"Keys common to all objects\" problem as follows:\n\n    length as $length\n    | bow(.[] | keys_unsorted[])\n    | to_entries[]\n    | select(.value==$length).key"
    ],
    "utterance": "Find all keys that are present in every nested object.",
    "expressions": [
      "length as $length | [.[] | keys_unsorted[]] | group_by(.)[] | select(length==$length) | .[0]",
      "length as $length | def bow(stream): reduce stream as $word ({}; .[$word|tostring] += 1); bow(.[] | keys_unsorted[]) | to_entries[] | select(.value==$length).key"
    ],
    "data": [
      {
        "input": {
          "DynamicKey1": {
            "foo": 1,
            "bar": 2
          },
          "DynamicKey2": {
            "bar": 3
          },
          "DynamicKey3": {
            "foo": 5,
            "zyx": 5
          }
        },
        "output": []
      }
    ],
    "identifier": 57103069
  },
  {
    "context": [
      "I want to: \n\n```\n{\n  \"user\": \"a\",\n  \"title\": \"aaa\"\n}\n{\n  \"user\": \"b\"\n}\n\n```",
      "The most direct approach would be simply to delete the unwanted key where it occurs, e.g. by:\n\n    map( if .title == null then del(.title) else . end)"
    ],
    "utterance": "Remove keys named title when their value is null, leaving all other keys unchanged.",
    "expressions": [
      "map(if .title == null then del(.title) else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "user": "a",
            "title": "aaa"
          },
          {
            "user": "b",
            "title": null
          }
        ],
        "output": [
          {
            "user": "a",
            "title": "aaa"
          },
          {
            "user": "b"
          }
        ]
      }
    ],
    "identifier": 57122910
  },
  {
    "context": [
      "Is it possible by using jq and for example RegExp to extract some data and insert it as new variable in object, I wish to achive something like this:",
      "{\"Name\": \"Forrest.Gump.1994.MULTi.1080p.AMZN.WEB-DL.DDP5.1.H264-Ao\",\"ID\": \"SMwIkBoC2blXeWnBa9Hjge9YPs90\",\"Year\": \"1994\",\"Res\": \"1080p\"}",
      "map( . as $in\n         | .Name | capture(\".*[.](?<year>[12][0-9]{3})[.](?<rest>.*)\")\n         | .year as $year\n         | (.rest | split(\".\") | .[1]) as $res\n         | $in + {Year: $year, Res: $res} )",
      "map(. + (.Name | capture(\".*[.](?<Year>[12][0-9]{3})[.](?<Res>.*)\") | {Year, Res: (.Res | split(\".\")[1])}))"
    ],
    "utterance": "For each object, extract the 4-digit year and the resolution (such as '1080p' or '2160p') from the 'Name' field and add them as new fields 'Year' and 'Res' to the object.",
    "expressions": [
      "map(. + (.Name | capture(\".*[.](?<Year>[12][0-9]{3})[.](?<Res>.*)\") | {Year, Res: (.Res | split(\".\")[1])}))",
      "map( . as $in | .Name | capture(\".*[.](?<year>[12][0-9]{3})[.](?<rest>.*)\") | .year as $year | (.rest | split(\".\") | .[1]) as $res | $in + {Year: $year, Res: $res} )"
    ],
    "data": [
      {
        "input": [
          {
            "Name": "Forrest.Gump.1994.MULTi.1080p.AMZN.WEB-DL.DDP5.1.H264-Ao",
            "ID": "SMwIkBoC2blXeWnBa9Hjge9YPs90"
          },
          {
            "Name": "Point.Blank.2019.MULTi.1080p.NF.WEB-DL.DDP5.1.x264-Ao",
            "ID": "OZI4mOuBXuJ7b89FLgXJoozyhHe9"
          },
          {
            "Name": "The.Incredible.Hulk.2008.MULTi.2160p.UHD.BluRay.REMUX.HDR.HEVC.DTS-HD.MA.7.1",
            "ID": "jZzR4_B_vjm593cYKR7j97XAMv6d"
          }
        ],
        "output": [
          {
            "Name": "Forrest.Gump.1994.MULTi.1080p.AMZN.WEB-DL.DDP5.1.H264-Ao",
            "ID": "SMwIkBoC2blXeWnBa9Hjge9YPs90",
            "Year": "1994",
            "Res": "1080p"
          },
          {
            "Name": "Point.Blank.2019.MULTi.1080p.NF.WEB-DL.DDP5.1.x264-Ao",
            "ID": "OZI4mOuBXuJ7b89FLgXJoozyhHe9",
            "Year": "2019",
            "Res": "1080p"
          },
          {
            "Name": "The.Incredible.Hulk.2008.MULTi.2160p.UHD.BluRay.REMUX.HDR.HEVC.DTS-HD.MA.7.1",
            "ID": "jZzR4_B_vjm593cYKR7j97XAMv6d",
            "Year": "2008",
            "Res": "2160p"
          }
        ]
      }
    ],
    "identifier": 57098580
  },
  {
    "context": [
      "I need to find if length of any value in any of the array exceeds a limit, say 1000.",
      "If it exceeds I have to trim the length of that particular value.",
      "To truncate strings longer than a given length, say $mx, you could use `walk/1`, like so:",
      "walk(if type == \"string\" and length > $mx\n         then .[:$mx] else . end)"
    ],
    "utterance": "Trim all string values in arrays so that no string exceeds a length of 1000 characters, modifying only those that are too long.",
    "expressions": [
      "walk(if type == \"string\" and length > 1000 then .[:1000] else . end)"
    ],
    "identifier": 57158039
  },
  {
    "context": [
      "What I need help is how to transform such an output JSON back to the original form using jq?",
      "With your sample input, the filter:",
      "    reduce to_entries[] as $kv ({}; setpath($kv.key|split(\"_\"); $kv.value))",
      "produces:",
      "{\n  \"X1\": {\n    \"X1o1\": {\n      \"X1o1o1\": \"abc\",\n      \"X1o1o2\": \"def\"\n    },\n    \"X1o2\": {\n      \"X1o2o1\": \"ghi\",\n      \"X1o2o2\": \"jkl\"\n    },\n    \"X1o3\": \"mno\"\n  },\n  \"X2\": \"pqr\"\n}"
    ],
    "utterance": "Convert an object with flattened keys joined by underscores back into nested objects where those keys represent path segments.",
    "expressions": [
      "reduce to_entries[] as $kv ({}; setpath($kv.key|split(\"_\"); $kv.value))"
    ],
    "data": [
      {
        "input": {
          "X1_X1o1_X1o1o1": "abc",
          "X1_X1o1_X1o1o2": "def",
          "X1_X1o2_X1o2o1": "ghi",
          "X1_X1o2_X1o2o2": "jkl",
          "X1_X1o3": "mno",
          "X2": "pqr"
        },
        "output": {
          "X1": {
            "X1o1": {
              "X1o1o1": "abc",
              "X1o1o2": "def"
            },
            "X1o2": {
              "X1o2o1": "ghi",
              "X1o2o2": "jkl"
            },
            "X1o3": "mno"
          },
          "X2": "pqr"
        }
      }
    ],
    "identifier": 57154970
  },
  {
    "context": [
      "The desired csv file is\n\n```\n1,first_input,\"xxx\"\n1,second_input,3\n2,my_first_arg:\"yyy\"\n2,my_second_arg,0\n```",
      "Basically I want the value of the `step` field, all keys of `inputs`, and the children nodes of values of `inputs`, but having related data stay in the same row in the csv.",
      "To produce an array of the desired values:\n\n    .step as $step\n    | .inputs\n    | to_entries[]\n    | .key as $key\n    | [$step, .key]\n      + (.value | if type==\"object\" then to_entries[] | [.key, .value] else [$key, .] end)\n\nTacking on `@csv` at the end would produce CSV values, with numbers unquoted.",
      "If you really want the output as indicated in the Q, then conditionally add the quotation marks (``\"\\\"\"``) where desired, and use `join(\",\")` instead of `@csv`."
    ],
    "utterance": "Extract for each object the step number, each key in inputs, and the corresponding value or nested file_id value, placing them on the same row.",
    "expressions": [
      ".step as $step | .inputs | to_entries[] | .key as $key | [$step, .key] + (.value | if type==\"object\" then to_entries[] | [.key, .value] else [$key, .] end) | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "step": 1,
            "inputs": {
              "first_input": {
                "file_id": "xxx"
              },
              "second_input": 3
            }
          },
          {
            "step": 2,
            "inputs": {
              "my_first_arg": {
                "file_id": "yyy"
              },
              "my_second_arg": 0
            }
          }
        ],
        "output": [
          "1,\"first_input\",\"file_id\",\"xxx\"",
          "1,\"second_input\",\"second_input\",3",
          "2,\"my_first_arg\",\"file_id\",\"yyy\"",
          "2,\"my_second_arg\",\"my_second_arg\",0"
        ]
      }
    ],
    "identifier": 57126911
  },
  {
    "context": [
      "I have a json file A: \n\n{ \"remove\" : [\"foo\", \"bar\"] }\n\nand a json file B: \n\n{ \"someDynamicKey\" : { \"foo\" : 1, \"xyz\" : 2, \"bar\" : \"x\" } }\n\nI want to remove all keys in file B that match in \"remove\" section in file A.",
      "Expect:\n\n{ \"someDynamicKey\" : { \"xyz\" : 2 } }",
      "jq --argfile A A.json '\n  $A.remove as $keys \n  | .someDynamicKey\n    |= with_entries( .key as $k\n                     | if $keys | index($k)\n                       then empty \n                       else . end)' B.json",
      "jq --slurpfile A A.json '$A[0].remove as $keys | .someDynamicKey |= with_entries(select( .key as $k | $keys | index($k) | not))' B.json"
    ],
    "utterance": "Remove all keys in the object under someDynamicKey whose names are listed in the remove array from another file",
    "expressions": [
      "$A.remove as $keys | .someDynamicKey |= with_entries( .key as $k | if $keys | index($k) then empty else . end)",
      "$A[0].remove as $keys | .someDynamicKey |= with_entries(select( .key as $k | $keys | index($k) | not))"
    ],
    "data": [
      {
        "input": {
          "A.json": {
            "remove": [
              "foo",
              "bar"
            ]
          },
          "B.json": {
            "someDynamicKey": {
              "foo": 1,
              "xyz": 2,
              "bar": "x"
            }
          }
        },
        "output": {
          "someDynamicKey": {
            "xyz": 2
          }
        }
      }
    ],
    "identifier": 57137918
  },
  {
    "context": [
      "I have file that looks like this:",
      "{\r\n  \"logRef\": \"c4fa4367-23f6-462f-b5fd-f972d0916a30\",\r\n  \"timestamp\": 1563268297545,\r\n  \"someOtherField\": \"nonImportantValue\"\r\n}\r\n{\r\n  \"logRef\": \"c4fa4367-23f6-462f-b5fd-f972d0916a31\",\r\n  \"timestamp\": 1563268297595,\r\n  \"someOtherField2\": \"nonImportantValue3\"\r\n}",
      "And I would like to convert it to csv like this:",
      "logRef;timestamp\nc4fa4367-23f6-462f-b5fd-f972d0916a30;1563268297545\nc4fa4367-23f6-462f-b5fd-f972d0916a31;1563268297595",
      "The problem with your filter is that @csv expects an array.  So this will work:\n\n    [.logRef,.timestamp] | @csv",
      "However it quotes strings, so if you want your strings unquoted (which might mean the result won't be CSV), then you could use:\n\n    \"\\(.logRef),\\(.timestamp)\"",
      "In all cases, you'll need to use jq's`-r` command-line option."
    ],
    "utterance": "Produce a semicolon-delimited list with logRef and timestamp fields as columns, extracting them from each object in a JSON stream.",
    "expressions": [
      "[.logRef, .timestamp] | @csv",
      "\"\\(.logRef);\\(.timestamp)\""
    ],
    "data": [
      {
        "input": [
          {
            "logRef": "c4fa4367-23f6-462f-b5fd-f972d0916a30",
            "timestamp": 1563268297545,
            "someOtherField": "nonImportantValue"
          },
          {
            "logRef": "c4fa4367-23f6-462f-b5fd-f972d0916a31",
            "timestamp": 1563268297595,
            "someOtherField2": "nonImportantValue3"
          }
        ],
        "output": [
          "c4fa4367-23f6-462f-b5fd-f972d0916a30;1563268297545",
          "c4fa4367-23f6-462f-b5fd-f972d0916a31;1563268297595"
        ]
      }
    ],
    "identifier": 57158138
  },
  {
    "context": [
      "I have the following code which works but the `| . [ ] ` section looks redundant.",
      "jq -r '[.items[] | {name:.metadata.name} ] | . [ ] .name'",
      "the pipeline could be streamlined to just:",
      ".items[] | .metadata.name",
      "This avoids all the overhead of constructing an array, constructing an object, and then dismantling everything."
    ],
    "utterance": "Extract all values of the metadata.name field from each item in the items array.",
    "expressions": [
      ".items[] | .metadata.name"
    ],
    "identifier": 57172513
  },
  {
    "context": [
      "I'd like to check if the value for a particular field belongs to a list of 'valid' values for the field and leave it unmodified if it does.",
      "if . == \"chrome\" or . == \"edge\" or . == \"firefox\" or . == \"safari\" or . == \"opera\" then .",
      "I'm wondering if there's a cleaner method that looks more like a pythonic:",
      "if . in [\"chrome\", \"edge\", \"firefox\", \"safari\", \"opera\"] then .",
      "I'd like to know how to take an element with a single value (e.g. a string) from the JSON data and check whether this element appears in an array provided as part of a conditional. The JSON data itself doesn't contain any arrays."
    ],
    "utterance": "Check whether a value matches any of the values in the list [\"chrome\", \"edge\", \"firefox\", \"safari\", \"opera\"], and leave it unmodified if it does.",
    "expressions": [
      "if [. == \"chrome\", . == \"edge\", . == \"firefox\", . == \"safari\", . == \"opera\"] | any then .",
      "if index([\"chrome\", \"edge\", \"firefox\", \"safari\", \"opera\"]; .) != null then .",
      "if ([\"chrome\", \"edge\", \"firefox\", \"safari\", \"opera\"] | index(.)) != null then ."
    ],
    "identifier": 57205628
  },
  {
    "context": [
      "- I am not able to filter the Inner Array of Assets. (rendition == dog)",
      "- I am not able to limit / remove the unwanted fields from the inner Array of Assets , i want only ID, Rendition and FileName..",
      "Expected response:",
      "{ \"AppMap\": { \"testFile1234\": { \"assets\": [ { \"filename\": \"testFile1234.scc\", \"rendition\": \"Dog\", \"assetId\": 6565223 }, ... ] }, ... }, \"CompletedInstances\": 0, \"status\": \"Completed\" }",
      "This gets the expected output:",
      "{ \"AppMap\": (.serviceResponse | map({ (.appId): ({\"assets\": (.assets | (map(select(.rendition==\"Dog\")) | map({filename, rendition, assetId}) ))})}) | add), CompletedInstances, status }"
    ],
    "utterance": "For each entry in serviceResponse, map the appId to an object containing only assets with rendition equal to \"Dog\", and for each asset keep only filename, rendition, and assetId fields.",
    "expressions": [
      "{ \"AppMap\": (.serviceResponse | map({ (.appId): ({\"assets\": (.assets | (map(select(.rendition==\"Dog\")) | map({filename, rendition, assetId}) ))})}) | add), CompletedInstances, status }"
    ],
    "data": [
      {
        "input": {
          "CompletedInstances": 0,
          "status": "Completed",
          "serviceResponse": [
            {
              "appId": "testFile1234",
              "assets": [
                {
                  "filename": "testFile1234.scc",
                  "rendition": "Dog",
                  "assetId": 6565223,
                  "extra": "x"
                },
                {
                  "filename": "testFile1234-BG.wav",
                  "rendition": "Dog",
                  "assetId": 8234169
                },
                {
                  "filename": "testFile1234-DK.wav",
                  "rendition": "Dog",
                  "assetId": 8234171
                },
                {
                  "filename": "testFile1234-cat.wav",
                  "rendition": "Cat",
                  "assetId": 8234199
                }
              ]
            },
            {
              "appId": "testFile4444",
              "assets": [
                {
                  "filename": "testFile1234.scc",
                  "rendition": "Dog",
                  "assetId": 8842169,
                  "foo": "bar"
                },
                {
                  "filename": "testFile4444-BG.wav",
                  "rendition": "Wolf",
                  "assetId": 9564567
                }
              ]
            }
          ]
        },
        "output": {
          "AppMap": {
            "testFile1234": {
              "assets": [
                {
                  "filename": "testFile1234.scc",
                  "rendition": "Dog",
                  "assetId": 6565223
                },
                {
                  "filename": "testFile1234-BG.wav",
                  "rendition": "Dog",
                  "assetId": 8234169
                },
                {
                  "filename": "testFile1234-DK.wav",
                  "rendition": "Dog",
                  "assetId": 8234171
                }
              ]
            },
            "testFile4444": {
              "assets": [
                {
                  "filename": "testFile1234.scc",
                  "rendition": "Dog",
                  "assetId": 8842169
                }
              ]
            }
          },
          "CompletedInstances": 0,
          "status": "Completed"
        }
      }
    ],
    "identifier": 57168327
  },
  {
    "context": [
      "The goal is to label each event so that if message begins with a TR, .sourcetype=application_log, else if message begins with an IP, .sourcetype=access_log.",
      ".log |= fromjson\n| .message[0:2] as $code    \n| if ($code == \"TR\") then .log.sourcetype = \"application_log\"\n  elif ($code == \"IP\") then .log.sourcetype = \"access_log\"\n  else .\n  end\n| .log |= tostring . # is this line really needed?"
    ],
    "utterance": "Label each event with sourcetype as application_log if message begins with TR, or access_log if message begins with IP.",
    "expressions": [
      ".log |= fromjson | .log.message[0:2] as $code | if ($code == \"TR\") then .log.sourcetype = \"application_log\" elif ($code == \"IP\") then .log.sourcetype = \"access_log\" else . end | .log |= tostring"
    ],
    "data": [
      {
        "input": {
          "log": "{\"message\":\"TR=failed to send order confirmation to \\\"someone@example.com\\\": rpc error: code = Unavailable desc = all SubConns are in TransientFailure, latest connection error: connection error: desc = \\\"transport: Error while dialing dial tcp 10.64.5.235:5000: i/o timeout\\\"\",\"severity\":\"warning\",\"timestamp\":\"2019-07-23T00:47:07.216693578Z\"}\n",
          "stream": "stdout",
          "time": "2019-07-23T00:47:07.222368843Z"
        },
        "output": {
          "log": "{\"message\":\"TR=failed to send order confirmation to \\\"someone@example.com\\\": rpc error: code = Unavailable desc = all SubConns are in TransientFailure, latest connection error: connection error: desc = \\\"transport: Error while dialing dial tcp 10.64.5.235:5000: i/o timeout\\\"\",\"severity\":\"warning\",\"timestamp\":\"2019-07-23T00:47:07.216693578Z\",\"sourcetype\":\"application_log\"}",
          "stream": "stdout",
          "time": "2019-07-23T00:47:07.222368843Z"
        }
      },
      {
        "input": {
          "log": "{\"message\":\"IP=failed to send order confirmation to \\\"someone@example.com\\\": rpc error: code = Unavailable desc = all SubConns are in TransientFailure, latest connection error: connection error: desc = \\\"transport: Error while dialing dial tcp 10.64.5.235:5000: i/o timeout\\\"\",\"severity\":\"warning\",\"timestamp\":\"2019-07-23T00:47:07.216693578Z\"}\n",
          "stream": "stdout",
          "time": "2019-07-23T00:47:07.222368843Z"
        },
        "output": {
          "log": "{\"message\":\"IP=failed to send order confirmation to \\\"someone@example.com\\\": rpc error: code = Unavailable desc = all SubConns are in TransientFailure, latest connection error: connection error: desc = \\\"transport: Error while dialing dial tcp 10.64.5.235:5000: i/o timeout\\\"\",\"severity\":\"warning\",\"timestamp\":\"2019-07-23T00:47:07.216693578Z\",\"sourcetype\":\"access_log\"}",
          "stream": "stdout",
          "time": "2019-07-23T00:47:07.222368843Z"
        }
      }
    ],
    "identifier": 57170294
  },
  {
    "context": [
      "How do I parse the following JSON to:\r\n\r\n- A single nested object and also add additional top level keys (\"cities\", \"uppsala\", and \"locations\" in the example)\r\n- Use the values for the keys ```name``` as keys for the objects?",
      "I haven't managed to get the values for ```name``` as keys for the objects.",
      "Since you want to hard-code the three top-most keys, the key to a solution is `add`:\r\n\r\n    {\r\n      \"cities\": {\r\n        \"uppsala\": {\r\n          \"locations\":\r\n            [.features[]\r\n             | {name: .properties.name,\r\n                coordinates:\r\n    \t          {_latitude: .geometry.coordinates[0],\r\n    \t           _longitude: .geometry.coordinates[1]\r\n    \t          }\r\n    \t        }\r\n    \t     | {(.name): .}\r\n            ] | add\r\n        }\r\n      }\r\n    }",
      "The critical `add` gets a bit lost in the above, so you might like to consider this equivalent alternative:\r\n\r\n    [.features[]\r\n     | {name: .properties.name,\r\n        coordinates:\r\n          { _latitude: .geometry.coordinates[0],\r\n            _longitude: .geometry.coordinates[1]\r\n          }\r\n       } | {(.name): .} ]\r\n    | add as $v\r\n    | ({} | .cities.uppsala.locations = $v)"
    ],
    "utterance": "Transform feature objects so their names become keys inside a nested object structure with three hardcoded top keys: cities, uppsala, and locations; convert feature coordinates to objects with keys _latitude and _longitude.",
    "expressions": [
      "{cities: {uppsala: {locations: [ .features[] | {name: .properties.name, coordinates: {_latitude: .geometry.coordinates[0], _longitude: .geometry.coordinates[1]} } | {(.name): .} ] | add }}}",
      "[.features[] | {name: .properties.name, coordinates: { _latitude: .geometry.coordinates[0], _longitude: .geometry.coordinates[1] } } | {(.name): .} ] | add as $v | ({} | .cities.uppsala.locations = $v)"
    ],
    "data": [
      {
        "input": {
          "type": "FeatureCollection",
          "features": [
            {
              "type": "Feature",
              "properties": {
                "name": "Uppsala domkyrka"
              },
              "geometry": {
                "coordinates": [
                  17.6336159,
                  59.8581466
                ]
              }
            },
            {
              "type": "Feature",
              "properties": {
                "name": "Uppsala mosk\u00e9"
              },
              "geometry": {
                "coordinates": [
                  17.6382165,
                  59.874003
                ]
              }
            }
          ]
        },
        "output": {
          "cities": {
            "uppsala": {
              "locations": {
                "Uppsala domkyrka": {
                  "name": "Uppsala domkyrka",
                  "coordinates": {
                    "_latitude": 17.6336159,
                    "_longitude": 59.8581466
                  }
                },
                "Uppsala mosk\u00e9": {
                  "name": "Uppsala mosk\u00e9",
                  "coordinates": {
                    "_latitude": 17.6382165,
                    "_longitude": 59.874003
                  }
                }
              }
            }
          }
        }
      }
    ],
    "identifier": 57186653
  },
  {
    "context": [
      "I have a below JSON and I need to convert it to a CSV. The problem I&#39;m having is that those values have no key.",
      "Ideally I would like CSV to look like this, I just don&#39;t know how to do it using jq.",
      "year;points;surname;name;point1;points2;points3;city;district;url",
      ".data[] is a stream of flat arrays, so to produce the CSV rows for the data, you could:\r\n\r\n    .data[] | @csv",
      "The question mentions CSV but the sample output shows semicolon-separated values, so here&#39;s a def that is like jq&#39;s built-in for tab-separated values but produces SSV, being careful to \"escape\" pre-existing semicolons in particular:\r\n\r\ndef ssv:\r\n  map(if type == \"string\" then gsub(\";\"; \"\\\\;\") else . end)\r\n  | @tsv\r\n  | gsub(\"\\t\"; \";\") ;"
    ],
    "utterance": "Convert the 'data' array of value-only arrays into a semicolon-separated CSV string with a specific header row: year;points;surname;name;point1;points2;points3;city;district;url.",
    "expressions": [
      "\"year;points;surname;name;point1;points2;points3;city;district;url\",\n(.data[] | @csv)",
      "\"year;points;surname;name;point1;points2;points3;city;district;url\",\n(.data[] | ssv)",
      "def ssv: map(if type == \"string\" then gsub(\";\"; \"\\\\;\") else . end) | @tsv | gsub(\"\\t\"; \";\") ;\n\"year;points;surname;name;point1;points2;points3;city;district;url\",\n(.data[] | ssv)"
    ],
    "data": [
      {
        "input": {
          "draw": 0,
          "total": "44",
          "filtered": "8",
          "data": [
            [
              "2020",
              "54",
              "Smith ",
              "John",
              "",
              "",
              "",
              "London",
              "Waterloo",
              "URL"
            ],
            [
              "2015",
              "380",
              "Helen ",
              "Smith",
              "",
              "",
              "",
              "New York",
              "Manhattan",
              "URL"
            ]
          ],
          "District": []
        },
        "output": "year;points;surname;name;point1;points2;points3;city;district;url\n2020;54;Smith ;John;;;London;Waterloo;URL\n2015;380;Helen ;Smith;;;New York;Manhattan;URL\n"
      }
    ],
    "identifier": 57205694
  },
  {
    "context": [
      "Content of myjq.txt\n\n```\n.spec.template.spec.containers[0].args as $myarray | $myarray | length as $mylength | $myarray[($mylength - 1)] |= $portVal\n```\n",
      "shell: yq --arg portVal \"8443\" -f {{ playbook_dir }}/myjq.txt simple-service-test.yaml > output.txt"
    ],
    "utterance": "Replace the last element of the array at .spec.template.spec.containers[0].args with the value provided as portVal.",
    "expressions": [
      ".spec.template.spec.containers[0].args as $myarray | $myarray | length as $mylength | $myarray[($mylength - 1)] |= $portVal"
    ],
    "data": [
      {
        "input": {
          "spec": {
            "template": {
              "spec": {
                "containers": [
                  {
                    "args": [
                      "proxy",
                      "--statusPort",
                      "15020",
                      "--applicationPorts",
                      "2525"
                    ]
                  }
                ]
              }
            }
          }
        },
        "output": {
          "spec": {
            "template": {
              "spec": {
                "containers": [
                  {
                    "args": [
                      "proxy",
                      "--statusPort",
                      "15020",
                      "--applicationPorts",
                      "8443"
                    ]
                  }
                ]
              }
            }
          }
        }
      }
    ],
    "identifier": 57211050
  },
  {
    "context": [
      "I want to retrieve some information from a JSON with jq.",
      "let AllKOMoves = await jq.run(`. | map(select(.Moves | map(select(.Max == 100)) | length > 1)) | map({Nature: .Nature, EV: .EV, Moves: [.Moves | map(select(.Max == 100))[] | .Move], MovesCount: .Moves | length})`,getAllInflictedDamage(pokemonSubject, allMoves, pokemonJSON[0]),{ input: 'json' })",
      "Here is a sample of the JSON generate by this portion of code getAllInflictedDamage(pokemonSubject, allMoves, pokemonJSON[0]):",
      "[   {      \"Opponent\":\"abomasnow\",      \"Move\":\"wood-hammer\",      \"Min\":16.15,      \"Max\":19.25,      \"Crit\":28.88   },   {      \"Opponent\":\"abomasnow\",      \"Move\":\"round\",      \"Min\":15.84,      \"Max\":18.94,      \"Crit\":28.26   } ]",
      "Normally my code should retrieve information like this:",
      "[   {      \"Nature\":\"brave\",      \"EV\":[         4,         0,         0,         0,         252,         252      ],      \"Moves\":[         \"focus-punch\",         \"natural-gift-fire90\",         \"natural-gift-fire100\",         \"natural-gift-fire80\"      ],      \"MovesCount\":4   },   {      \"Nature\":\"brave\",      \"EV\":[         0,         252,         252,         4,         0,         0      ],      \"Moves\":[         \"natural-gift-fire90\",         \"natural-gift-fire100\",         \"natural-gift-fire80\"      ],      \"MovesCount\":3   } ]"
    ],
    "utterance": "Extract all objects where Moves has more than one move with Max equal to 100, and for each, return Nature, EV, array of move names with Max 100, and total number of Moves.",
    "expressions": [
      ". | map(select(.Moves | map(select(.Max == 100)) | length > 1)) | map({Nature: .Nature, EV: .EV, Moves: [.Moves | map(select(.Max == 100))[] | .Move], MovesCount: .Moves | length})"
    ],
    "identifier": 57166113
  },
  {
    "context": [
      "I have an array of strings stored in variable $odd_fields ([\"one\",\"three\",...,\"nine\"]). Without using a convoluted iterative process (since I can do this statically with only map({one,three,...,nine}), I'd like to be able to re-cast my array of objects into an array of objects with reference to my array of keys, and in that order, like map({$odd_fields[]}).",
      "I want whole consistent subset objects as if any key not in my list was never present.",
      "To recast an object using the keys and key ordering in an array, $array:\n\ndef recast($array):\n  . as $in\n  | reduce $array[] as $k ({}; .[$k] = $in[$k]);",
      "map(recast($odd_fields))",
      "map([$array[] as $p|{($p):.[$p]}]|add)"
    ],
    "utterance": "Select only the keys named in a given array of strings, in that array's order, from each object in an array of objects.",
    "expressions": [
      "def recast($array): . as $in | reduce $array[] as $k ({}; .[$k] = $in[$k]); map(recast($odd_fields))",
      "map([$odd_fields[] as $p | {($p): .[$p]}] | add)"
    ],
    "identifier": 57223059
  },
  {
    "context": [
      "How can I create the below json with jq?\r\n\r\n    {\"RedrivePolicy\":{\"deadLetterTargetArn\":\"arn:aws:sqs:us-east-1:12345678:reptar-dlq\",\"maxReceiveCount\":\"15\"}}",
      "I was able to create the jq json using the command listed below -\r\n\r\n    redrive_policy=$(jq -n --arg arn \"$dlq_arn\" --arg max \"$max_count\" '{RedrivePolicy:{deadLetterTargetArn: $arn,maxReceiveCount: $max}}')"
    ],
    "utterance": "Produce an object with RedrivePolicy containing deadLetterTargetArn and maxReceiveCount fields, using shell variables for their values.",
    "expressions": [
      "jq -n --arg arn \"$dlq_arn\" --arg max \"$max_count\" '{RedrivePolicy:{deadLetterTargetArn: $arn,maxReceiveCount: $max}}'"
    ],
    "data": [
      {
        "input": {
          "dlq_arn": "arn:aws:sqs:us-east-1:12345678:reptar-dlq",
          "max_count": "15"
        },
        "output": {
          "RedrivePolicy": {
            "deadLetterTargetArn": "arn:aws:sqs:us-east-1:12345678:reptar-dlq",
            "maxReceiveCount": "15"
          }
        }
      }
    ],
    "identifier": 57273222
  },
  {
    "context": [
      "Need to add array elements with same field name",
      "Input:\n\n    [\n      {\n        \"all\": 1,\n        \"sys\": \"bus\"\n      },\n      {\n        \"all\": 14,\n        \"sys\": \"bus\"\n      }\n    ]",
      "I have tried like below:\n\n    .[] | (.all +.all)\n\nbut got result like \n\n    2\n    28",
      "Expected result: `15` (1 + 14)",
      "First map, then add:\n\n    map(.all) | add"
    ],
    "utterance": "Sum all values of the 'all' fields from each object in a list where each object has an 'all' field.",
    "expressions": [
      "map(.all) | add"
    ],
    "data": [
      {
        "input": [
          {
            "all": 1,
            "sys": "bus"
          },
          {
            "all": 14,
            "sys": "bus"
          }
        ],
        "output": 15
      }
    ],
    "identifier": 57274554
  },
  {
    "identifier": 57280534
  },
  {
    "context": [
      "I am trying to extract like below,",
      "{\n  \"main\": \"Marketing and Public Relations\",\n  \"parent\": \"Marketing Software\",\n  \"children\": [\n    \"Sun Application Server\",\n    \"Kenshoo\"\n  ]\n}\n{\n  \"main\": \"Sales\",\n  \"parent\": \"Online Sales\",\n  \"children\": [\n    \"Online Sales\",\n    \"Internet Sales\"\n  ]\n}\n{\n  \"main\": \"Sales\",\n  \"parent\": \"Online Sales2\",\n  \"children\": [\n    \"Online Sales2\",\n    \"Internet Sales2\"\n  ]\n}",
      "You only need to iterate over the subarrays (.parentName) once:",
      "```\n.value[]\n| {main: .label}\n  + (.parentname[] \n     | {parent: .label, children: [ .children[].label ] }) \n```"
    ],
    "utterance": "Extract an object for each parentname that includes the main label, the parent label, and an array of its children labels.",
    "expressions": [
      ".value[] | (.parentname[] | {main: .label, parent: .label, children: [ .children[].label ]} )",
      ".value[] | {main: .label} + (.parentname[] | {parent: .label, children: [ .children[].label ] })"
    ],
    "data": [
      {
        "input": {
          "@odata.context": "https://from.some.API",
          "value": [
            {
              "id": 2,
              "label": "Marketing and Public Relations",
              "parentname": [
                {
                  "id": 336,
                  "label": "Marketing Software",
                  "children": [
                    {
                      "id": 16543,
                      "label": "Sun Application Server"
                    },
                    {
                      "id": 15735,
                      "label": "Kenshoo"
                    }
                  ]
                }
              ]
            },
            {
              "id": 3,
              "label": "Sales",
              "parentname": [
                {
                  "id": 115,
                  "label": "Online Sales",
                  "children": [
                    {
                      "id": 9919,
                      "label": "Online Sales"
                    },
                    {
                      "id": 9489,
                      "label": "Internet Sales"
                    }
                  ]
                },
                {
                  "id": 115,
                  "label": "Online Sales2",
                  "children": [
                    {
                      "id": 9919,
                      "label": "Online Sales2"
                    },
                    {
                      "id": 9489,
                      "label": "Internet Sales2"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          {
            "main": "Marketing and Public Relations",
            "parent": "Marketing Software",
            "children": [
              "Sun Application Server",
              "Kenshoo"
            ]
          },
          {
            "main": "Sales",
            "parent": "Online Sales",
            "children": [
              "Online Sales",
              "Internet Sales"
            ]
          },
          {
            "main": "Sales",
            "parent": "Online Sales2",
            "children": [
              "Online Sales2",
              "Internet Sales2"
            ]
          }
        ]
      }
    ],
    "identifier": 57247786
  },
  {
    "context": [
      "I'm trying to make simple script which queries my ec2 instances and gets public dns name of instances which matches my filter.",
      "It almost works but I get something ugly:",
      "[ ...",
      "    [",
      "        \"\"",
      "    ],",
      "    [",
      "        \"ec2-xxx-xxx-xxx-xxx.venus-central-1.compute.amazonaws.com\"",
      "    ]",
      "]",
      "I want just list of FQDNs, one per line. How to format output?",
      "By using jq you can parse the JSON response to get what you want."
    ],
    "utterance": "Output a flat list of all non-empty public DNS names from the describe-instances result, one per line.",
    "expressions": [
      "jq -r '.[][] | select(length>0) | .'"
    ],
    "identifier": 57280498
  },
  {
    "context": [
      "And, I want to convert it with lists(assume all lists have equal length `N`) zipped and output like this:\r\n...\r\n{\"user\":\"stedolan\",\"title\":\"JQ Primer\",\"year\":2013}\r\n{\"user\":\"stedolan\",\"title\":\"More JQ\",\"year\":2016}",
      "then it output:\r\n...\r\n{\"user\":\"stedolan\",\"title\":\"JQ Primer\",\"year\":2013}\r\n{\"user\":\"stedolan\",\"title\":\"JQ Primer\",\"year\":2016}\r\n{\"user\":\"stedolan\",\"title\":\"More JQ\",\"year\":2013}\r\n{\"user\":\"stedolan\",\"title\":\"More JQ\",\"year\":2016}\r\nIt produces `N*N ...` lines result, instead of `N` lines result.",
      "([.titles,.years]|transpose[]) as [$title,$year] | {user,$title,$year}",
      "([.titles,.years]|transpose[]) as $p | {user,title:$p[0],year:$p[1]}"
    ],
    "utterance": "Output objects pairing corresponding elements of 'titles' and 'years' lists as 'title' and 'year', along with the 'user' field, producing one object per matched pair.",
    "expressions": [
      "([.titles,.years]|transpose[]) as [$title,$year] | {user,$title,$year}",
      "([.titles,.years]|transpose[]) as $p | {user,title:$p[0],year:$p[1]}"
    ],
    "data": [
      {
        "input": {
          "user": "stedolan",
          "titles": [
            "JQ Primer",
            "More JQ"
          ],
          "years": [
            2013,
            2016
          ]
        },
        "output": [
          {
            "user": "stedolan",
            "title": "JQ Primer",
            "year": 2013
          },
          {
            "user": "stedolan",
            "title": "More JQ",
            "year": 2016
          }
        ]
      }
    ],
    "identifier": 57283364
  },
  {
    "context": [
      "So I want to get the video information first followed by audio information:",
      "Expected result:",
      "\"1080,h264,aac\"",
      "Here is the code I am trying, which gives me a blank output:",
      ".streams[] | \"\\(select(.codec_type==\\\"video\\\") | \\(.height),\\(.codec_name))\\(select(.codec_type==\\\"audio\\\") | \\(.codec_name))\"",
      "The following seems to be what you want:",
      ".streams\n| (.[] | select(.codec_type == \"video\") | \"\\(.height),\\(.codec_name),\")\n+ (.[] | select(.codec_type == \"audio\") | \"\\(.codec_name)\")",
      "It does produce the desired output, and it does match the problem description and sample code"
    ],
    "utterance": "Return a string combining the height and codec_name of the first video stream and the codec_name of the first audio stream, separated by commas, e.g. \"1080,h264,aac\".",
    "expressions": [
      ".streams | (.[] | select(.codec_type == \"video\") | \"\\(.height),\\(.codec_name),\") + (.[] | select(.codec_type == \"audio\") | \"\\(.codec_name)\")",
      "(.streams[] | select(.codec_type==\"video\") | \"\\(.height),\\(.codec_name),\") + (.streams[] | select(.codec_type==\"audio\") | \"\\(.codec_name)\")"
    ],
    "data": [
      {
        "input": {
          "streams": [
            {
              "index": 0,
              "codec_name": "h264",
              "codec_long_name": "H.264 / AVC / MPEG-4 AVC / MPEG-4 part 10",
              "profile": "Main",
              "codec_type": "video",
              "codec_time_base": "0/2",
              "codec_tag_string": "[27][0][0][0]",
              "codec_tag": "0x001b",
              "width": 1920,
              "height": 1080,
              "coded_width": 1920,
              "coded_height": 1088,
              "has_b_frames": 1,
              "sample_aspect_ratio": "1:1",
              "display_aspect_ratio": "16:9",
              "pix_fmt": "yuv420p",
              "level": 40,
              "chroma_location": "left",
              "field_order": "progressive",
              "refs": 1,
              "is_avc": "false",
              "nal_length_size": "0",
              "id": "0x100",
              "r_frame_rate": "25/1",
              "avg_frame_rate": "0/0",
              "time_base": "1/90000",
              "start_pts": 1397779146,
              "start_time": "15530.879400",
              "bits_per_raw_sample": "8",
              "disposition": {
                "default": 0,
                "dub": 0,
                "original": 0,
                "comment": 0,
                "lyrics": 0,
                "karaoke": 0,
                "forced": 0,
                "hearing_impaired": 0,
                "visual_impaired": 0,
                "clean_effects": 0,
                "attached_pic": 0,
                "timed_thumbnails": 0
              }
            },
            {
              "index": 1,
              "codec_name": "aac",
              "codec_long_name": "AAC (Advanced Audio Coding)",
              "codec_type": "audio",
              "codec_time_base": "1/0",
              "codec_tag_string": "[15][0][0][0]",
              "codec_tag": "0x000f",
              "sample_fmt": "fltp",
              "sample_rate": "0",
              "channels": 0,
              "bits_per_sample": 0,
              "id": "0x101",
              "r_frame_rate": "0/0",
              "avg_frame_rate": "0/0",
              "time_base": "1/90000",
              "disposition": {
                "default": 0,
                "dub": 0,
                "original": 0,
                "comment": 0,
                "lyrics": 0,
                "karaoke": 0,
                "forced": 0,
                "hearing_impaired": 0,
                "visual_impaired": 0,
                "clean_effects": 0,
                "attached_pic": 0,
                "timed_thumbnails": 0
              },
              "tags": {
                "language": "eng"
              }
            },
            {
              "index": 2,
              "codec_name": "dvb_teletext",
              "codec_long_name": "DVB teletext",
              "codec_type": "subtitle",
              "codec_tag_string": "[6][0][0][0]",
              "codec_tag": "0x0006",
              "id": "0x102",
              "r_frame_rate": "0/0",
              "avg_frame_rate": "0/0",
              "time_base": "1/90000",
              "disposition": {
                "default": 0,
                "dub": 0,
                "original": 0,
                "comment": 0,
                "lyrics": 0,
                "karaoke": 0,
                "forced": 0,
                "hearing_impaired": 0,
                "visual_impaired": 0,
                "clean_effects": 0,
                "attached_pic": 0,
                "timed_thumbnails": 0
              },
              "tags": {
                "language": "eng"
              }
            }
          ]
        },
        "output": "1080,h264,aac"
      }
    ],
    "identifier": 57110596
  },
  {
    "context": [
      "Main caveats here are:\n - There are optional fields within the struct - especially 'name' (see `\"random\": {\"files\": [{\"type\": \"dynamic\"}]` -> 'dynamic/random')",
      "As you can see it has several issues:\n\n - duplicates\n - created strings out of non-existing keys (e.g. while `\"static/main/ca.crt\"` is correct, `\"dynamic/main/ca.crt\"` and `\"dynamic/main/ca.crt\"` are not).\n - `\"dynamic/random/\"` should be `\"dynamic/random\"` (without trailing slash)",
      "Optional fields can be handled using an `if-then-else` statement. And you don't need `to_entries` here, just keep keys in a variable.",
      "$ jq -r 'keys_unsorted[] as $k | .[$k].files[] | .type + \"/\" + $k +\nif has(\"name\") then \".\" + .name else \"\" end' file.json"
    ],
    "utterance": "Create a string for each file, combining its type, the parent key, and, if present, a dot and the file's name; omit the dot and name if not present.",
    "expressions": [
      "keys_unsorted[] as $k | .[$k].files[] | .type + \"/\" + $k + (if has(\"name\") then \".\" + .name else \"\" end)"
    ],
    "data": [
      {
        "input": {
          "main": {
            "files": [
              {
                "name": "ca.crt",
                "type": "static"
              },
              {
                "name": "key",
                "type": "dynamic"
              },
              {
                "name": "crt",
                "type": "dynamic"
              }
            ],
            "FOO": "BAR",
            "BLA": "BLUB"
          },
          "ota": {
            "EEKS": "POOPS",
            "files": [
              {
                "name": "ca.crt",
                "type": "static"
              },
              {
                "name": "sig.pub",
                "type": "static"
              }
            ]
          },
          "random": {
            "files": [
              {
                "type": "dynamic"
              }
            ]
          }
        },
        "output": [
          "static/main.ca.crt",
          "dynamic/main.key",
          "dynamic/main.crt",
          "static/ota.ca.crt",
          "static/ota.sig.pub",
          "dynamic/random"
        ]
      }
    ],
    "identifier": 57284849
  },
  {
    "context": [
      "I use this command \n```\nvar1=$(jq '.[\\'$cpt'] | ._source .element1' file.json) \n```\nand I can receive my value, however I receive this error: \n\n>jq error Cannot index number with number",
      "I already try with \n\n```\nvar1=$(jq '.[] | ._source .element1' file.json) \n```\n\nbut I receive all data and I need to receive the data by index.",
      "to extract .element1:\n\n    ```\n    .[0]._source.element1\n    ```",
      "var1=$(jq --argjson cpt \"$cpt\" '.[$cpt]._source.element1' file.json)"
    ],
    "utterance": "Extract the value of 'element1' from the _source object of the array item at a given index.",
    "expressions": [
      ".[0]._source.element1",
      ".[$cpt]._source.element1",
      ".[$cpt]._source[\"element1\"]"
    ],
    "data": [
      {
        "input": [
          {
            "aaa": "lklklk",
            "bbb": "uiop",
            "kkk": "zeez",
            "lll": 3,
            "_source": {
              "element1": "zzzz",
              "element2": "eeee",
              "element3": "hhhhh",
              "element4": "jjjjjj",
              "@timestamp": "2019-07-31T08:32:45.000Z",
              "element5": "1",
              "element6": "6768",
              "element7": "gggg",
              "element8": "ppppp"
            }
          },
          {
            "aaa": "lklklk",
            "bbb": "uiop",
            "kkk": "zeez",
            "lll": 3,
            "_source": {
              "element1": "zzzz",
              "element2": "eeee",
              "element3": "hhhhh",
              "element4": "jjjjjj",
              "@timestamp": "2019-07-31T08:32:45.000Z",
              "element5": "1",
              "element6": "6768",
              "element7": "gggg",
              "element8": "ppppp"
            }
          }
        ],
        "output": "zzzz"
      }
    ],
    "identifier": 57297397
  },
  {
    "context": [
      "Now i have to extract the value of TargetGroupArn for \"RuleArn\": \"xyz\" which means i need to get that targetgroup arn so that i can use that in my next command something like :-",
      "aws elbv2 --region us-west-2 describe-rules \\\n    '--listener-arn=************' \\\n    --output json | jq -r '.Rules[]|select(.RuleArn == \"xyz\")| .Actions[0].TargetGroupArn'"
    ],
    "utterance": "Extract the TargetGroupArn value from the rule where RuleArn equals \"xyz\".",
    "expressions": [
      ".Rules[] | select(.RuleArn == \"xyz\") | .Actions[0].TargetGroupArn"
    ],
    "data": [
      {
        "input": {
          "Rules": [
            {
              "Priority": "1",
              "Conditions": [
                {
                  "Field": "host-header",
                  "HostHeaderConfig": {
                    "Values": [
                      "****"
                    ]
                  },
                  "Values": [
                    "****"
                  ]
                }
              ],
              "RuleArn": "xyz",
              "IsDefault": false,
              "Actions": [
                {
                  "TargetGroupArn": "****",
                  "Type": "forward"
                }
              ]
            },
            {
              "Priority": "default",
              "Conditions": [],
              "RuleArn": "abc",
              "IsDefault": true,
              "Actions": [
                {
                  "TargetGroupArn": "***",
                  "Type": "forward",
                  "Order": 1
                }
              ]
            }
          ]
        },
        "output": "****"
      }
    ],
    "identifier": 57300115
  },
  {
    "context": [
      "jq -c '.[]' smoke-test-logs/error-log.json | while read i; do",
      "msg=$(echo $i | jq -r '.msg')",
      "type=$(echo $i | jq -r '.name')",
      "parse error: Expected separator between values at line 1, column 254",
      "jq -c '.[]' smoke-test-logs/error-log.json | while read -r i"
    ],
    "utterance": "Output each object in the array as a compact single line for subsequent processing in a shell pipeline.",
    "expressions": [
      "jq -c '.[]' smoke-test-logs/error-log.json"
    ],
    "data": [
      {
        "input": [
          {
            "name": "single_schedule",
            "hostname": "ip-172-31-23-92",
            "pid": 22408,
            "level": 50,
            "msg": "Exception found while processing : Property address: Unit 43, 8-14 Fullerton Street, Woollahra Nsw 2025 Property Id: 95 Lease Id: 29 ErrorCode: 400 ErrorMessage 400 - \\\"[{\\\\\\\"errorCode\\\\\\\":400002,\\\\\\\"message\\\\\\\":\\\\\\\"Field Validation Error\\\\\\\",\\\\\\\"details\\\\\\\":\\\\\\\"Missing mandatory field dbc.\\\\\\\",\\\\\\\"type\\\\\\\":\\\\\\\"REQUEST_ERROR\\\\\\\",\\\\\\\"field\\\\\\\":\\\\\\\"dbc\\\\\\\"}]\\\"",
            "time": "2019-07-26T10:57:02.079Z",
            "v": 0
          },
          {
            "name": "single_schedule",
            "hostname": "ip-172-31-23-92",
            "pid": 22408,
            "level": 50,
            "msg": "Exception found while processing : Property address: 8 Chunooma Road, North Wahroonga Nsw 2076 Property Id: 96 Lease Id: 30 ErrorCode: 400 ErrorMessage 400 - \\\"[{\\\\\\\"errorCode\\\\\\\":400002,\\\\\\\"message\\\\\\\":\\\\\\\"Field Validation Error\\\\\\\",\\\\\\\"details\\\\\\\":\\\\\\\"Missing mandatory field dbc.\\\\\\\",\\\\\\\"type\\\\\\\":\\\\\\\"REQUEST_ERROR\\\\\\\",\\\\\\\"field\\\\\\\":\\\\\\\"dbc\\\\\\\"}]\\\"",
            "time": "2019-07-26T10:57:03.287Z",
            "v": 0
          }
        ],
        "output": [
          "{\"name\":\"single_schedule\",\"hostname\":\"ip-172-31-23-92\",\"pid\":22408,\"level\":50,\"msg\":\"Exception found while processing : Property address: Unit 43, 8-14 Fullerton Street, Woollahra Nsw 2025 Property Id: 95 Lease Id: 29 ErrorCode: 400 ErrorMessage 400 - \\\"[{\\\\\\\"errorCode\\\\\\\":400002,\\\\\\\"message\\\\\\\":\\\\\\\"Field Validation Error\\\\\\\",\\\\\\\"details\\\\\\\":\\\\\\\"Missing mandatory field dbc.\\\\\\\",\\\\\\\"type\\\\\\\":\\\\\\\"REQUEST_ERROR\\\\\\\",\\\\\\\"field\\\\\\\":\\\\\\\"dbc\\\\\\\"}]\\\"\",\"time\":\"2019-07-26T10:57:02.079Z\",\"v\":0}",
          "{\"name\":\"single_schedule\",\"hostname\":\"ip-172-31-23-92\",\"pid\":22408,\"level\":50,\"msg\":\"Exception found while processing : Property address: 8 Chunooma Road, North Wahroonga Nsw 2076 Property Id: 96 Lease Id: 30 ErrorCode: 400 ErrorMessage 400 - \\\"[{\\\\\\\"errorCode\\\\\\\":400002,\\\\\\\"message\\\\\\\":\\\\\\\"Field Validation Error\\\\\\\",\\\\\\\"details\\\\\\\":\\\\\\\"Missing mandatory field dbc.\\\\\\\",\\\\\\\"type\\\\\\\":\\\\\\\"REQUEST_ERROR\\\\\\\",\\\\\\\"field\\\\\\\":\\\\\\\"dbc\\\\\\\"}]\\\"\",\"time\":\"2019-07-26T10:57:03.287Z\",\"v\":0}"
        ]
      }
    ],
    "identifier": 57219782
  },
  {
    "context": [
      "I want to have something like this\n\n> **New (In Bold and Red Color)**\n> \n> Ready\n> \n> \n> **Old (In Bold and Red Color)**\n> \n> Stopped\n\nto make it more readable",
      "def colors:\n {\n \"black\": \"\\u001b[30m\",\n \"red\": \"\\u001b[31m\",\n \"green\": \"\\u001b[32m\",\n \"yellow\": \"\\u001b[33m\",\n \"blue\": \"\\u001b[34m\",\n \"magenta\": \"\\u001b[35m\",\n \"cyan\": \"\\u001b[36m\",\n \"white\": \"\\u001b[37m\",\n \"reset\": \"\\u001b[0m\",\n};",
      "def pc($text; color):\n  (colors | color) + $text + colors.reset;",
      "# Usage example:\npc(\"red\"; .red) + pc(\"green\"; .green)"
    ],
    "utterance": "Print the value field as bold and red and other fields normally in terminal output for each object in the array",
    "expressions": [
      "def colors: { \"red\": \"\\u001b[31m\", \"bold\": \"\\u001b[1m\", \"reset\": \"\\u001b[0m\" }; def boldred($txt): (colors.bold + colors.red + $txt + colors.reset); .[] | \"\\n\" + boldred(.value) + \"\\n\" + .onclick + \"\\n\""
    ],
    "data": [
      {
        "input": [
          {
            "value": "New",
            "onclick": "Ready"
          },
          {
            "value": "Old",
            "onclick": "Stopped"
          }
        ],
        "output": "\u001b[1m\u001b[31mNew\u001b[0m\nReady\n\n\u001b[1m\u001b[31mOld\u001b[0m\nStopped\n"
      }
    ],
    "identifier": 57298373
  },
  {
    "context": [
      "Using `.rows`, I successfully get the array:",
      "[{\"a\":[\"x\",\"y\"],\"b\":\"some\",\"c\":\"string\"},{\"a\":[\"u\",\"v\"],\"b\":\"another\",\"c\":\"string\"}]",
      "But `.rows | @csv` says: `object ({\"a\":[\"x\",...) is not valid in a csv row`. So, I somehow have to join the array in key \"a\".",
      "Using `.rows[] | .a | join(\" \")` I get:",
      "\"x y\"",
      "\"u v\"",
      "But how do I get this back into my JSON to then use `... | @csv` to get my desired CSV data?",
      "With your input, the following [tag:jq] program:",
      "```\n.rows[]\n| map_values(if type == \"array\" then join(\" \") else . end)\n| [.[]]\n| @csv\n```",
      "produces the comma-separated-values output:",
      "\"x y\",\"some\",\"string\"",
      "\"u v\",\"another\",\"string\"",
      "It's a simple matter to add the headers, so I'll leave that to you."
    ],
    "utterance": "Transform an array of objects where key 'a' contains arrays into rows with all values joined by spaces, and output with fields a, b, and c as comma-separated values.",
    "expressions": [
      ".rows[]\n| map_values(if type == \"array\" then join(\" \") else . end)\n| [.[]]\n| @csv"
    ],
    "data": [
      {
        "input": {
          "rows": [
            {
              "a": [
                "x",
                "y"
              ],
              "b": "some",
              "c": "string"
            },
            {
              "a": [
                "u",
                "v"
              ],
              "b": "another",
              "c": "string"
            }
          ]
        },
        "output": [
          "\"x y\",\"some\",\"string\"",
          "\"u v\",\"another\",\"string\""
        ]
      }
    ],
    "identifier": 57307098
  },
  {
    "context": [
      "make the nodes consistent so that if any ... node is an array in any of the nodes, then the remaining nodes should be converted into arrays.",
      "If a path to a value in .[] is an array, then ensure all corresponding values are also arrays",
      "def paths_to_array:\n  [paths as $path\n   | select( any(.[]; (getpath($path[1:] )? | type) == \"array\"))\n   | $path] ;",
      "def make_uniform:\n  reduce (paths_to_array[][1:]) as $path (.;\n    map( (getpath($path)? // null) as $value\n         | if $value and ($value|type != \"array\")\n           then setpath($path; [$value])\n           else . end )  ) ;",
      "make_uniform",
      "For the second task, let's define a utility function:\n# Input is assumed to be an object:\ndef flatten_top_level_keys:\n  [ to_entries[]\n    | if (.value|type) == \"object\" \n      then .key as $k\n      | (.value|to_entries)[] as $kv\n      | {key: ($k + \".\" + $kv.key), value: $kv.value} \n      else .\n      end ]\n  | from_entries;",
      "This can be used in conjunction with `walk/1` to achieve recursive\nflattening.",
      "make_uniform\n| walk( if type == \"object\" then flatten_top_level_keys else . end )",
      "def update_array($path):\n  (getpath($path)? // null) as $value\n    | (if $value and ($value|type != \"array\")\n          then . as $data | (try (setpath($path; [$value]))\n                    catch $data)\n       else . end);",
      "def make_uniform($paths):\n  map( .\n       | reduce($paths[]) as $path (\n          . ; update_array($path)\n         )\n     );",
      "def flatten_top_level_keys:\n  [ to_entries[]\n    | if (.value|type) == \"object\"\n      then .key as $k\n      | (.value|to_entries)[] as $kv\n      | {key: ($k + \".\" + $kv.key), value: $kv.value}\n      else .\n      end ]\n  | from_entries;",
      "make_uniform({path})\n| map( .\n       | walk( if type == \"object\" then\n                  flatten_top_level_keys\n               else . end ))"
    ],
    "utterance": "Normalize all fields so that any key appearing as an array in any record always appears as an array, then flatten nested objects so that their keys are joined with dots, while arrays stay as arrays.",
    "expressions": [
      "def paths_to_array:\n  [paths as $path\n   | select( any(.[]; (getpath($path[1:] )? | type) == \"array\"))\n   | $path] ;\n\ndef make_uniform:\n  reduce (paths_to_array[][1:]) as $path (.;\n    map( (getpath($path)? // null) as $value\n         | if $value and ($value|type != \"array\")\n           then setpath($path; [$value])\n           else . end )  ) ;\n\nmake_uniform",
      "def flatten_top_level_keys:\n  [ to_entries[]\n    | if (.value|type) == \"object\"\n      then .key as $k\n      | (.value|to_entries)[] as $kv\n      | {key: ($k + \".\" + $kv.key), value: $kv.value}\n      else .\n      end ]\n  | from_entries;\n\nwalk( if type == \"object\" then flatten_top_level_keys else . end )",
      "make_uniform\n| walk( if type == \"object\" then flatten_top_level_keys else . end )",
      "def update_array($path):\n  (getpath($path)? // null) as $value\n    | (if $value and ($value|type != \"array\")\n          then . as $data | (try (setpath($path; [$value]))\n                    catch $data)\n       else . end);\n\ndef make_uniform($paths):\n  map( .\n       | reduce($paths[]) as $path (\n          . ; update_array($path)\n         )\n     );",
      "make_uniform({path})\n| map( .\n       | walk( if type == \"object\" then\n                  flatten_top_level_keys\n               else . end ))"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "person": {
              "addresses": {
                "address": {
                  "city": "FL"
                }
              },
              "phones": [
                {
                  "type": "mobile",
                  "number": "555-555-5555"
                }
              ],
              "email": [
                {
                  "type": "work",
                  "email": "john.doe@gmail.com"
                },
                {
                  "type": "work",
                  "email": "john.doe@work.com"
                }
              ]
            }
          },
          {
            "id": 2,
            "person": {
              "addresses": [
                {
                  "type": "home",
                  "address": {
                    "city": "FL"
                  }
                }
              ],
              "phones": {
                "type": "mobile",
                "number": "555-555-5555"
              },
              "email": {
                "type": "work",
                "email": "jane.doe@gmail.com"
              }
            }
          }
        ],
        "output": [
          {
            "id": 1,
            "person.addresses": [
              {
                "address": {
                  "city": "FL"
                }
              }
            ],
            "person.phones": [
              {
                "type": "mobile",
                "number": "555-555-5555"
              }
            ],
            "person.email": [
              {
                "type": "work",
                "email": "john.doe@gmail.com"
              },
              {
                "type": "work",
                "email": "john.doe@work.com"
              }
            ]
          },
          {
            "id": 2,
            "person.addresses": [
              {
                "type": "home",
                "address": {
                  "city": "FL"
                }
              }
            ],
            "person.phones": [
              {
                "type": "mobile",
                "number": "555-555-5555"
              }
            ],
            "person.email": [
              {
                "type": "work",
                "email": "jane.doe@gmail.com"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 57133421
  },
  {
    "context": [
      "I am trying to join() a relatively big array (20k elements) of objects with a character ('\\n' in this particular case).",
      "when I try to '| join(\"\\n\")' at the end the runtime jump to 3+ minutes.",
      "jq automatically display carriage return ('\\n') if you scan an array (.[]), which mean that in this particular case I can just do this:",
      "[ .[] as $row | [ $headers[] as $h | $row[$h] | tostring | tonull ] | join(\"\\t\") ] | .[]",
      "And this solved my problem"
    ],
    "utterance": "Output each object in an array as a tab-separated string with rows separated by newlines, without explicitly using join(\"\\n\").",
    "expressions": [
      "(.[0] | keys) as $headers |\n    [\n        ($headers | join(\"\\t\")),\n        [ .[] as $row | [ $headers[] as $h | $row[$h] | tostring | tonull ] | join(\"\\t\") ] | .[]\n    ] | .[]"
    ],
    "identifier": 57314520
  },
  {
    "context": [
      "I want to get only AWS_ environments variables from the environment and output them into a JSON.",
      "jq -n env would show the whole env as JSON.",
      "jq -n 'env | with_entries(select(.key | test(\"AWS_\")))'"
    ],
    "utterance": "Select all environment variables whose names contain 'AWS_' and output them as JSON key-value pairs.",
    "expressions": [
      "jq -n 'env | with_entries(select(.key | test(\"AWS_\")))'",
      "jq -n 'env | with_entries(select(.key | test(\"^AWS_\")))'"
    ],
    "identifier": 57329775
  },
  {
    "identifier": 57330709
  },
  {
    "context": [
      "kubectl get configmap $configmap -o json | jq \".data[\\\"$filename\\\"] = \\\"$augfile\\\"\" | kubectl replace $configmap -f -",
      "jq: error: Invalid escape at line 2, column 1 (while parsing '\"\\\r\n\t\"') at <top-level>, line 129:",
      "it's almost always better to pass in the shell values using the jq command-line options --arg and/or --argjson, e.g. in your case (assuming your shell allows this style of quoting):",
      "jq --arg filename \"$filename\" --arg augfile \"$augfile\" '\n       .data[$filename] = $augfile'"
    ],
    "utterance": "Update the value of the data property named by a shell variable to the content of another shell variable, handling cases where the content may contain backslashes or special characters.",
    "expressions": [
      "jq --arg filename \"$filename\" --arg augfile \"$augfile\" '.data[$filename] = $augfile'"
    ],
    "identifier": 57317236
  },
  {
    "context": [
      "I need a csv with a line for each json record.",
      "expected result:\r\n\"35058\",\"1\",\"APP\",\"Apple\",\"0190199077621\"\r\n\"35078\",\"1\",\"APP\",\"Apple\",\"0190199062627\"\r\n\"28129\",\"1\",\"APP\",\"Apple\",\"0190198496492\"\r\n",
      "Looks like you want the following :\r\n\r\n    .Data[] | [.ID, .Marchio.ID , .Marchio.Codice, .Marchio.Descrizione , .Codifica.CodEan] | @csv"
    ],
    "utterance": "Export a flat CSV where each row contains the values of ID, Marchio.ID, Marchio.Codice, Marchio.Descrizione, and Codifica.CodEan for each element in the Data array",
    "expressions": [
      ".Data[] | [.ID, .Marchio.ID , .Marchio.Codice, .Marchio.Descrizione , .Codifica.CodEan] | @csv"
    ],
    "data": [
      {
        "input": {
          "Pagination": null,
          "Data": [
            {
              "ID": 35058,
              "Marchio": {
                "ID": 1,
                "Codice": "APP",
                "Descrizione": "Apple",
                "Immagine": "https://api.attiva.com/Articoli/LogoMarchio/APPLE.jpg/",
                "URL": "http://www.apple.com"
              },
              "Codifica": {
                "CodEan": "0190199077621",
                "CodCli": "a1234",
                "Descrizione": "IPAD AIR 10.5\" WI-FI 64GB GRIGIO SIDERALE",
                "Specifiche": "Display Retina Multi-Touch retroilluminato ",
                "SchedaTecnica": "scheda tecnica",
                "Confezione": "",
                "CodAtv": "APP4472P",
                "CodFor": "MUUJ2TY/A"
              }
            },
            {
              "ID": 35078,
              "Marchio": {
                "ID": 1,
                "Codice": "APP",
                "Descrizione": "Apple",
                "Immagine": "https://api.attiva.com/Articoli/LogoMarchio/APPLE.jpg/",
                "URL": "http://www.apple.com"
              },
              "Codifica": {
                "CodEan": "0190199062627",
                "CodCli": "",
                "Descrizione": "IPAD MINI WI-FI 64GB ARGENTO",
                "Specifiche": "Display Multi-Touch retroilluminato LED da 7,9",
                "SchedaTecnica": "---",
                "CodAtv": "APP4487P",
                "CodFor": "MUQX2TY/A"
              }
            },
            {
              "ID": 28129,
              "Marchio": {
                "ID": 1,
                "Codice": "APP",
                "Descrizione": "Apple",
                "Immagine": "https://api.attiva.com/Articoli/LogoMarchio/APPLE.jpg/",
                "URL": "http://www.apple.com"
              },
              "Codifica": {
                "CodEan": "0190198496492",
                "CodCli": "",
                "Descrizione": "CUSTODIA APPLE IN SILICONE PER IPHONE 8 / 7 PLUS - BLU NOTTE",
                "Specifiche": "Progettata da Apple",
                "DescrizioneEstesa": "---",
                "SchedaTecnica": "",
                "Confezione": "",
                "CodAtv": "APP3851A",
                "CodFor": "MQGY2ZM/A"
              }
            }
          ]
        },
        "output": [
          "\"35058\",\"1\",\"APP\",\"Apple\",\"0190199077621\"",
          "\"35078\",\"1\",\"APP\",\"Apple\",\"0190199062627\"",
          "\"28129\",\"1\",\"APP\",\"Apple\",\"0190198496492\""
        ]
      }
    ],
    "identifier": 57272471
  },
  {
    "context": [
      "Once i get the JSON reponse for all the targets i want to do a If condition to ensure only when number of targets > 4 and all of them are healthy, then do xyz...",
      "So say something like \r\n\r\n    if ( countoftarget >4 && alltargethasstate == healthy) then \r\n        echo \"*****\" \r\n    else \r\n        sleep 2 minutes and keep checking the loop",
      "One of the potential advantages of using jq here is that you can easily avoid multiple calls to aws.",
      "[.TargetHealthDescriptions[]\r\n| select(.TargetHealth.State == \"healthy\")]\r\n| . as $targets # in case you want to do something with them if the counting condition is satisfied\r\n| length | if . > 4 then \"found \\(.) targets\" else empty end"
    ],
    "utterance": "Determine if there are more than 4 targets and all targets have state equal to healthy, for conditional execution.",
    "expressions": [
      "[.TargetHealthDescriptions[] | select(.TargetHealth.State == \"healthy\")] | length as $n | if $n > 4 and ($n == (.TargetHealthDescriptions | length)) then \"All targets healthy\" else empty end"
    ],
    "data": [
      {
        "input": {
          "TargetHealthDescriptions": [
            {
              "Target": {
                "Id": "***",
                "Port": 80
              },
              "TargetHealth": {
                "State": "initial",
                "Reason": "Elb.RegistrationInProgress",
                "Description": "Target registration is in progress"
              }
            },
            {
              "Target": {
                "Id": "***",
                "Port": 80
              },
              "TargetHealth": {
                "State": "unhealthy",
                "Reason": "Target.Timeout",
                "Description": "Connection to target timed out"
              }
            },
            {
              "HealthCheckPort": "80",
              "Target": {
                "Id": "***",
                "Port": 80
              },
              "TargetHealth": {
                "State": "healthy"
              }
            },
            {
              "HealthCheckPort": "80",
              "Target": {
                "Id": "***",
                "Port": 80
              },
              "TargetHealth": {
                "State": "healthy"
              }
            },
            {
              "HealthCheckPort": "80",
              "Target": {
                "Id": "***",
                "Port": 80
              },
              "TargetHealth": {
                "State": "healthy"
              }
            },
            {
              "HealthCheckPort": "80",
              "Target": {
                "Id": "***",
                "Port": 80
              },
              "TargetHealth": {
                "State": "healthy"
              }
            },
            {
              "HealthCheckPort": "80",
              "Target": {
                "Id": "***",
                "Port": 80
              },
              "TargetHealth": {
                "State": "healthy"
              }
            }
          ]
        }
      }
    ],
    "identifier": 57313529
  },
  {
    "context": [
      "I want to filter the `modules` list to the object where the `path` list contains \"root\", then return the `outputs` object.",
      "I don't want to make an assumption that the object I'm interested in is the 0th element of the `modules` list, instead I want to filter the `modules` list where the `path` list contains an element \"root\".",
      "`.modules[] | select(.path == [\"root\"]).outputs`"
    ],
    "utterance": "Return the outputs object from the modules list where the path is exactly [\"root\"]",
    "expressions": [
      ".modules[] | select(.path == [\"root\"]).outputs"
    ],
    "data": [
      {
        "input": {
          "modules": [
            {
              "path": [
                "root"
              ],
              "outputs": {
                "a": "b",
                "c": "d"
              }
            },
            {
              "path": [
                "other1"
              ],
              "outputs": {
                "e": "f",
                "g": "h"
              }
            },
            {
              "path": [
                "other2"
              ],
              "outputs": {
                "i": "j",
                "k": "l"
              }
            }
          ]
        },
        "output": {
          "a": "b",
          "c": "d"
        }
      }
    ],
    "identifier": 57338096
  },
  {
    "context": [
      "I have a JSON file from a DynamoDB table which I want to convert to CSV.",
      "jq: error (at test.json:22): object ({\"SnsPublis...) cannot be csv-formatted, only array",
      "How can I convert this JSON to a CSV properly?",
      "def json2csv:\n  (.[0] | json2header) as $h\n  | ([$h[]|join(\".\")], (.[] | json2array($h))) \n  | @csv ;",
      "jq -rf json2csv.jq INPUT.json",
      "\"SnsPublishTime.S\",\"SESreportingMTA.S\",\"SESMessageType.S\",\"SESDestinationAddress.S\",\"SESMessageId.S\",\"SESbounceSummary.S\"\n\"2019-07-27T15:07:38.904Z\",\"dsn; a8-19.smtp-out.amazonses.com\",\"Bounce\",\"bounce@simulator.amazonses.com\",\"0100016c33f91857-600a8e44-c419-4a02-bfd6-7f6908f5969e-000000\",\"[{\"\"emailAddress\"\":\"\"bounce@simulator.amazonses.com\"\", \"\"action\"\":\"\"failed\"\", \"\"status\"\":\"\"5.1.1\"\", \"\"diagnosticCode\"\":\"\"smtp; 550 5.1.1 user unknown\"\"}]\"",
      "For the record, here is a generic JSON-to-CSV converter for converting any array of JSON objects to CSV (with headers)...",
      "def json2csv:\n  ( [.[] | json2headers] | unique) as $h\n  | ([$h[]|join(\"_\") ],\n     (.[]\n      | json2array($h)\n      | map( if type == \"array\" then map(tostring)|join(\"|\") else tostring end)))\n  | @csv ;"
    ],
    "utterance": "Convert an array of objects with nested structure and scalar leaf values to CSV, including nested keys as column headers using dot or underscore notation.",
    "expressions": [
      "def json2header:\n  [paths(scalars)];\n\ndef json2array($header):\n  json2header as $h\n  | if $h == $header or (($h|sort) == ($header|sort))\n    then [$header[] as $p | getpath($p)]\n    else \"headers do not match: expected followed by found paths:\" | debug\n    | ($header|map(join(\".\")) | debug)\n    | ($h|map(join(\".\")) | debug)\n    | \"headers do not match\" | error\n    end ;\n\ndef json2csv:\n  (.[0] | json2header) as $h\n  | ([$h[]|join(\".\")], (.[] | json2array($h))) \n  | @csv ;\n\njson2csv",
      "def json2headers:\n  def isscalar: type | . != \"array\" and . != \"object\";\n  def isflat: all(.[]; isscalar);\n  paths as $p\n  | getpath($p)\n  | if type == \"array\" and isflat then $p\n     elif isscalar and (($p[-1]|type) == \"string\") then $p\n     else empty end ;\n\ndef json2array($header):\n  def value($p):\n    try getpath($p) catch null\n    | if type == \"object\" then null else . end;\n  [$header[] as $p | value($p)];\n\ndef json2csv:\n  ( [.[] | json2headers] | unique) as $h\n  | ([$h[]|join(\"_\") ],\n     (.[]\n      | json2array($h)\n      | map( if type == \"array\" then map(tostring)|join(\"|\") else tostring end)))\n  | @csv ;"
    ],
    "data": [
      {
        "input": [
          {
            "SnsPublishTime": {
              "S": "2019-07-27T15:07:38.904Z"
            },
            "SESreportingMTA": {
              "S": "dsn; a8-19.smtp-out.amazonses.com"
            },
            "SESMessageType": {
              "S": "Bounce"
            },
            "SESDestinationAddress": {
              "S": "bounce@simulator.amazonses.com"
            },
            "SESMessageId": {
              "S": "0100016c33f91857-600a8e44-c419-4a02-bfd6-7f6908f5969e-000000"
            },
            "SESbounceSummary": {
              "S": "[{\"emailAddress\":\"bounce@simulator.amazonses.com\",\"action\":\"failed\",\"status\":\"5.1.1\",\"diagnosticCode\":\"smtp; 550 5.1.1 user unknown\"}]"
            }
          }
        ],
        "output": "\"SnsPublishTime.S\",\"SESreportingMTA.S\",\"SESMessageType.S\",\"SESDestinationAddress.S\",\"SESMessageId.S\",\"SESbounceSummary.S\"\n\"2019-07-27T15:07:38.904Z\",\"dsn; a8-19.smtp-out.amazonses.com\",\"Bounce\",\"bounce@simulator.amazonses.com\",\"0100016c33f91857-600a8e44-c419-4a02-bfd6-7f6908f5969e-000000\",\"[{\"emailAddress\":\"bounce@simulator.amazonses.com\",\"action\":\"failed\",\"status\":\"5.1.1\",\"diagnosticCode\":\"smtp; 550 5.1.1 user unknown\"}]\""
      }
    ],
    "identifier": 57242240
  },
  {
    "context": [
      "But I want a merged results including both m1 and m2 like below\n\"1 some m1\"\n\"2 some m1\"\n\"3 some m1\"\n\"3 some m2\"\n\"4 some m1\"",
      "Get both values; they will be `null` if they don&#39;t exist. Then just filter the nulls from the result.\n\n    <somejson.json jq '.m1, .m2 | select(. != null)'",
      "To always extract `m1`:\n\n    jq '.m1, if (.m2 != null) then .m2 else empty end' somejson.json"
    ],
    "utterance": "Extract m1 value from each object, and if m2 exists and is not null, also extract m2, outputting each value separately in a merged sequence.",
    "expressions": [
      ".m1, .m2 | select(. != null)",
      ".m1, if (.m2 != null) then .m2 else empty end"
    ],
    "data": [
      {
        "input": [
          {
            "m1": "1 some m1",
            "m2": null,
            "m3": "unwanted"
          },
          {
            "m1": "2 some m1",
            "m3": "unwanted"
          },
          {
            "m1": "3 some m1",
            "m2": "3 some m2",
            "m3": "unwanted"
          },
          {
            "m1": "4 some m1",
            "m3": "unwanted"
          }
        ],
        "output": [
          "1 some m1",
          "2 some m1",
          "3 some m1",
          "3 some m2",
          "4 some m1"
        ]
      }
    ],
    "identifier": 57357362
  },
  {
    "context": [
      "How can I flatten the inner array such that I can run queries similar to\n\njq '{ \"absolute\": .t, \"word\": .s[].\"$t\", \"relative\": .s[].t, }'\n\nso that I get results such as:\n\n{\n  \"absolute\": \"0\",\n  \"word\": \"pastas\",\n  \"relative\": null\n}\n{\n  \"absolute\": \"0\",\n  \"word\": \"299\",\n  \"relative\": \"1280\"\n}\n{\n  \"absolute\": \"0\",\n  \"word\": \"187\",\n  \"relative\": \"2780\"\n}\n\ninstead of all the combinations between the inner properties",
      "In this case, the iterator is `.s[]` and we want just one of them:\n```\n.s[] as $s\n| { \"absolute\": .t, \"word\": $s.\"$t\", \"relative\": $s.t }\n```",
      "Or, if you want to be a little DRYer:\n\n```\n{\"absolute\": .t} + (.s[] | {\"word\": .\"$t\", \"relative\": .t})\n```"
    ],
    "utterance": "Produce an object for each element of the 's' array containing the top-level 't' as 'absolute', the element's '$t' as 'word', and its 't' as 'relative', ensuring 'relative' is null if missing.",
    "expressions": [
      ".s[] as $s | { \"absolute\": .t, \"word\": $s.\"$t\", \"relative\": ($s.t // null) }",
      "{\"absolute\": .t} + (.s[] | {\"word\": .\"$t\", \"relative\": (.t // null)})"
    ],
    "data": [
      {
        "input": {
          "t": "0",
          "d": "12090",
          "w": "1",
          "s": [
            {
              "ac": "252",
              "$t": "pastas"
            },
            {
              "t": "1280",
              "ac": "226",
              "$t": "299"
            },
            {
              "t": "2780",
              "ac": "252",
              "$t": "187"
            }
          ]
        },
        "output": [
          {
            "absolute": "0",
            "word": "pastas",
            "relative": null
          },
          {
            "absolute": "0",
            "word": "299",
            "relative": "1280"
          },
          {
            "absolute": "0",
            "word": "187",
            "relative": "2780"
          }
        ]
      }
    ],
    "identifier": 57342052
  },
  {
    "context": [
      "I have a below JSON file and need to convert to CSV file with some values as headers and below that values should get populated. Below is the sample json",
      "Expected out as\n\n```\nname,count,response_time\nabcd, 123, 15.7\nxyzz, 456, 18.7\n```",
      "jq -r '\n  # name,count,response_time\n  .environments[].dimensions[]\n  | .name as $p_name\n  | .metrics\n  | [$p_name]\n    + map(select(.name == \"count\") | .values[0] )\n    + map(select(.name == \"response_time\") | .values[0] )\n  | @csv\n'",
      "jq -r '\n  # name,count,response_time\n  .environments[].dimensions[]\n  | .name as $p_name\n  | INDEX(.metrics[]; .name) as $dict\n  | [$p_name, $dict[\"count\"].values[0], $dict[\"response_time\"].values[0]]\n  | @csv\n'",
      ".environments[].dimensions\n| [\"name\", (.[0] | .metrics[] | .name)],     # first emit the headers\n  ( .[] | [.name, (.metrics[].values[0])] )  # ... and then the data rows\n| @csv"
    ],
    "utterance": "Create a CSV where each row contains the dimension's name, count, and response_time, and the first row has the headers 'name', 'count', 'response_time'.",
    "expressions": [
      ".environments[].dimensions[]\n| .name as $p_name\n| .metrics\n| [$p_name]\n  + map(select(.name == \"count\") | .values[0] )\n  + map(select(.name == \"response_time\") | .values[0] )\n| @csv",
      ".environments[].dimensions[]\n| .name as $p_name\n| INDEX(.metrics[]; .name) as $dict\n| [$p_name, $dict[\"count\"].values[0], $dict[\"response_time\"].values[0]]\n| @csv",
      ".environments[].dimensions\n| [\"name\", (.[0] | .metrics[] | .name)],\n  ( .[] | [.name, (.metrics[].values[0])] )\n| @csv"
    ],
    "data": [
      {
        "input": {
          "environments": [
            {
              "dimensions": [
                {
                  "metrics": [
                    {
                      "name": "count",
                      "values": [
                        "123"
                      ]
                    },
                    {
                      "name": "response_time",
                      "values": [
                        "15.7"
                      ]
                    }
                  ],
                  "name": "abcd"
                },
                {
                  "metrics": [
                    {
                      "name": "count",
                      "values": [
                        "456"
                      ]
                    },
                    {
                      "name": "response_time",
                      "values": [
                        "18.7"
                      ]
                    }
                  ],
                  "name": "xyzz"
                }
              ]
            }
          ]
        },
        "output": "name,count,response_time\nabcd,123,15.7\nxyzz,456,18.7"
      }
    ],
    "identifier": 57331913
  },
  {
    "context": [
      "I want to select the objects which has a \"snack\" key including its parent.",
      "This however, does not include the parent, which in this case is \"group\".",
      "So you\u2019d start with:\n\n    paths(objects) as $p\n    | select(getpath($p)|has(\"snack\"))\n    | $p",
      "More useful would be getpath( $p[:-1] )"
    ],
    "utterance": "Select the parent objects of all objects that contain the key 'snack'.",
    "expressions": [
      "paths(objects) as $p | select(getpath($p)|has(\"snack\")) | getpath($p[:-1])"
    ],
    "data": [
      {
        "input": {
          "team": {
            "money": 100
          },
          "group": {
            "money": 200,
            "snack": true
          }
        },
        "output": {
          "money": 200,
          "snack": true
        }
      }
    ],
    "identifier": 57367825
  },
  {
    "context": [
      "I have the following json file jsonsample.txt",
      "{\r\n  \"id\": \"v4cw72hf3\",\r\n  \"output\": {\r\n    \"url\": \"//srv01.cloudconvert.com/download/~ugl5vnrpfO\",\r\n    \"downloads\": 0\r\n  },\r\n}",
      "and I tried two ways to access the url field",
      "jq '[\"output\"].[\"url\"]' jsonsample.txt",
      "jq .output.url jsonsample.txt",
      "But the first one doesn't give me the desired results",
      "So you'd be safe with `.[\"output\"]|.[\"url\"]`",
      "one would expect \r\n\r\n `.[\"output\"][\"url\"]` \r\n\r\nto work, as indeed it does going back at least to jq 1.3.",
      "The restricted `.foo.bar` notation is also supported going back at least to jq 1.3.",
      "jq 1.4 added support for unrestricted dot-string notation wherein the key name can be any valid JSON string (i.e. with quotation marks), e.g. \r\n\r\n   `.\"foo with space\".\"bar with space\"`"
    ],
    "utterance": "Extract the value of the url key, which is inside the output object.",
    "expressions": [
      ".[\"output\"]|.[\"url\"]",
      ".[\"output\"][\"url\"]",
      ".output.url"
    ],
    "data": [
      {
        "input": {
          "id": "v4cw72hf3",
          "output": {
            "url": "//srv01.cloudconvert.com/download/~ugl5vnrpfO",
            "downloads": 0
          }
        },
        "output": "//srv01.cloudconvert.com/download/~ugl5vnrpfO"
      }
    ],
    "identifier": 57366872
  },
  {
    "context": [
      "I want to select the image information (as well as the sha256 digest) with certain tag. Example: I want to select only `tag == \"python-2-toolchain-latest\"`, so it prints this json (with json reformat)",
      "select($value.tag[0] ==  \"python-2-toolchain-latest\")\n| {digest: $k} + $value",
      "select(.value.tag | contains([\"python-2-toolchain-latest\"])) | { digest: .key } + .value",
      "Convert the input object into a list of { key, value } objects\n        | select(.value.tag | contains([\"python-2-toolchain-latest\"]))\n        | .value.digest = .key\n        | .value",
      ".\n| to_entries\n| .[]\n| select(.value.tag | contains([\"python-2-toolchain-latest\"]))\n| { digest: .key } + .value"
    ],
    "utterance": "Select all parent keys and their corresponding objects where the tag array contains \"python-2-toolchain-latest\", and output each as an object including a digest field set to the parent key.",
    "expressions": [
      "keys_unsorted[] as $k | .[$k] as $value | select($value.tag[0] ==  \"python-2-toolchain-latest\") | {digest: $k} + $value",
      ". | to_entries | .[] | select(.value.tag | contains([\"python-2-toolchain-latest\"])) | { digest: .key } + .value",
      "[to_entries[] | select(.value.tag | contains([\"python-2-toolchain-latest\"])) | .value.digest = .key | .value]"
    ],
    "data": [
      {
        "input": {
          "sha256:0085b5379bf1baeb4a430128782440fe636938aa739f6a5ecc4152a22f19b08b": {
            "imageSizeBytes": "596515805",
            "layerId": "",
            "mediaType": "application/vnd.docker.distribution.manifest.v2+json",
            "tag": [
              "python-3-toolchain-0.1.2"
            ],
            "timeCreatedMs": "1564631021992",
            "timeUploadedMs": "1564631067325"
          },
          "sha256:1ec7631f74a3d6d37bf9194c13854f33315260ae1f27347263dd0a8974ee82bb": {
            "imageSizeBytes": "513574770",
            "layerId": "",
            "mediaType": "application/vnd.docker.distribution.manifest.v2+json",
            "tag": [
              "python-2-toolchain-latest"
            ],
            "timeCreatedMs": "1535447023647",
            "timeUploadedMs": "1535447042373"
          }
        },
        "output": {
          "digest": "sha256:1ec7631f74a3d6d37bf9194c13854f33315260ae1f27347263dd0a8974ee82bb",
          "imageSizeBytes": "513574770",
          "layerId": "",
          "mediaType": "application/vnd.docker.distribution.manifest.v2+json",
          "tag": [
            "python-2-toolchain-latest"
          ],
          "timeCreatedMs": "1535447023647",
          "timeUploadedMs": "1535447042373"
        }
      }
    ],
    "identifier": 57311744
  },
  {
    "context": [
      "What i am trying to achieve is as below",
      "name:smith jones, name:jacob Mathew, name:Anita Rodrigues",
      "DOB:1992-03-26,  DOB:1993-03-26,  DOB:1994-03-26",
      "Enrollmentdate:2013-08-24,  Enrollmentdate:2014-10-02, Enrollmentdate:2015-02-19",
      "Since you want the key names as well as their values, then adapting your approach, you could use the following, in conjunction with the -r command-line option,  to produce CSV:",
      ".results | map(to_entries[] | select(.key==\"name\")), map(to_entries[] | select(.key==\"DOB\")), map(to_entries[] | select(.key==\"Enrollmentdate\")) | map(\"\\(.key):\\(.value)\" ) | @csv"
    ],
    "utterance": "Output each entry's 'name', 'DOB', and 'Enrollmentdate' fields as key:value pairs joined by commas for each field type.",
    "expressions": [
      ".results | map(to_entries[] | select(.key==\"name\")), map(to_entries[] | select(.key==\"DOB\")), map(to_entries[] | select(.key==\"Enrollmentdate\")) | map(\"\\(.key):\\(.value)\") | @csv"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "name": "smith Jones",
              "DOB": "1992-03-26",
              "Enrollmentdate": "2013-08-24"
            },
            {
              "name": "Jacob Mathew",
              "DOB": "1993-03-26",
              "Enrollmentdate": "2014-10-02"
            },
            {
              "name": "Anita Rodrigues",
              "DOB": "1994-03-26",
              "Enrollmentdate": "2015-02-19"
            }
          ]
        },
        "output": [
          "\"name:smith Jones\",\"name:Jacob Mathew\",\"name:Anita Rodrigues\"",
          "\"DOB:1992-03-26\",\"DOB:1993-03-26\",\"DOB:1994-03-26\"",
          "\"Enrollmentdate:2013-08-24\",\"Enrollmentdate:2014-10-02\",\"Enrollmentdate:2015-02-19\""
        ]
      }
    ],
    "identifier": 57369853
  },
  {
    "context": [
      "Is there a way to use a combination of Batch and jq in order to properly format this JSON as one large nested json, rather than a json containing several string formatted jsons?",
      "I have successfully parsed each thing individually using singular jq commands such as \r\n` myjson.json | jq . | jq .[].Timeline fromjson `",
      "The simplest in your case would be to use `walk/1`:\r\n```\r\nwalk( if type == \"string\" then fromjson? // . else . end)\r\n```",
      "Sometimes it happens that applying `fromjson` just once is not enough.  In such cases, the following should be sufficient as it will cause the above procedure to be applied until quiescence:\r\n```\r\ndef until_quiescence(f):\r\n  (f as $x | if ($x == .) then . else ($x | until_quiescence(f)) end);\r\n\r\nuntil_quiescence(walk( if type == \"string\" then fromjson? // . else . end) )\r\n\r\n```",
      "This can also be done with recursive descent operator:\r\n```jq\r\n(..|strings) |= (fromjson? //.)\r\n```",
      "But it will also transform strings like \"123\" to numbers.",
      "To preserve numeric strings use this one:\r\n```jq\r\n(..|strings|tonumber? //.|strings) |= (fromjson? //.)\r\n```"
    ],
    "utterance": "Parse all stringified objects within an array of records into nested objects, without manually specifying field names or parsing each field individually.",
    "expressions": [
      "walk(if type == \"string\" then fromjson? // . else . end)",
      "def until_quiescence(f): (f as $x | if ($x == .) then . else ($x | until_quiescence(f)) end); until_quiescence(walk(if type == \"string\" then fromjson? // . else . end))",
      "(..|strings) |= (fromjson? // .)",
      "(..|strings|tonumber? //.|strings) |= (fromjson? // .)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "xxxxxxxxxxx",
            "percentage": "\"80\"",
            "Status": "{\"index\":1,\"post_id\":null,\"changed_at\":\"2019-07-29T14:44:50.305Z\"}",
            "Timeline": "{\"from\":\"2019-07-03\",\"to\":\"2019-07-25\",\"changed_at\":\"2019-07-29T14:55:39.487Z\"}",
            "Interview Done": "{\"date\":\"2019-07-03\",\"changed_at\":\"2019-07-23T19:56:01.004Z\"}",
            "Credentials Done": "{\"date\":\"2019-07-02\",\"changed_at\":\"2019-07-23T19:57:39.021Z\"}",
            "Skills Done": "{\"date\":\"2019-07-24\",\"changed_at\":\"2019-07-23T19:55:10.847Z\"}",
            "orientation Date": "{\"date\":\"2019-07-25\",\"changed_at\":\"2019-07-23T19:55:07.670Z\"}",
            "Hire Date": null
          },
          {
            "name": "yyyyyyyyyyyy",
            "percentage": null,
            "Status": "{\"index\":1,\"post_id\":null,\"changed_at\":\"2019-07-26T22:57:31.250Z\"}",
            "Timeline": "{\"from\":\"2019-07-17\",\"to\":\"2019-07-26\",\"changed_at\":\"2019-07-23T20:13:58.253Z\"}",
            "Interview Done": "{\"date\":\"2019-07-17\",\"changed_at\":\"2019-07-23T20:13:03.218Z\"}",
            "Credentials Done": "{\"date\":\"2019-07-24\",\"changed_at\":\"2019-07-25T16:12:40.484Z\"}",
            "Skills Done": "{\"date\":\"2019-07-17\",\"changed_at\":\"2019-07-23T20:13:29.884Z\"}",
            "orientation Date": "{\"date\":\"2019-07-25\",\"changed_at\":\"2019-07-23T20:11:52.848Z\"}",
            "Hire Date": null
          }
        ],
        "output": [
          {
            "name": "xxxxxxxxxxx",
            "percentage": "80",
            "Status": {
              "index": 1,
              "post_id": null,
              "changed_at": "2019-07-29T14:44:50.305Z"
            },
            "Timeline": {
              "from": "2019-07-03",
              "to": "2019-07-25",
              "changed_at": "2019-07-29T14:55:39.487Z"
            },
            "Interview Done": {
              "date": "2019-07-03",
              "changed_at": "2019-07-23T19:56:01.004Z"
            },
            "Credentials Done": {
              "date": "2019-07-02",
              "changed_at": "2019-07-23T19:57:39.021Z"
            },
            "Skills Done": {
              "date": "2019-07-24",
              "changed_at": "2019-07-23T19:55:10.847Z"
            },
            "orientation Date": {
              "date": "2019-07-25",
              "changed_at": "2019-07-23T19:55:07.670Z"
            },
            "Hire Date": null
          },
          {
            "name": "yyyyyyyyyyyy",
            "percentage": null,
            "Status": {
              "index": 1,
              "post_id": null,
              "changed_at": "2019-07-26T22:57:31.250Z"
            },
            "Timeline": {
              "from": "2019-07-17",
              "to": "2019-07-26",
              "changed_at": "2019-07-23T20:13:58.253Z"
            },
            "Interview Done": {
              "date": "2019-07-17",
              "changed_at": "2019-07-23T20:13:03.218Z"
            },
            "Credentials Done": {
              "date": "2019-07-24",
              "changed_at": "2019-07-25T16:12:40.484Z"
            },
            "Skills Done": {
              "date": "2019-07-17",
              "changed_at": "2019-07-23T20:13:29.884Z"
            },
            "orientation Date": {
              "date": "2019-07-25",
              "changed_at": "2019-07-23T20:11:52.848Z"
            },
            "Hire Date": null
          }
        ]
      }
    ],
    "identifier": 57363439
  }
]