[
  {
    "context": [
      "I have a string that is a json (that is stored in `MESSAGE`):\r\n\r\n    {\"folder\":\"blah\", \"file\":\"halb\"}\r\n\r\nand I want to print in echo `blah/halb`.",
      "Simpler: `jq -r '.photo.folder+ \"/\"+ .photo.file'`",
      "use the `add` function for string concatenation:\r\n\r\n    jq -r '[.photo.folder, \"/\", .photo.file] | add' << END\n    {\"photo\": {\"folder\":\"blah\", \"file\":\"halb\"}}\n    END\n\nblah/halb"
    ],
    "utterance": "Print the folder and file fields from the object, separated by a slash.",
    "expressions": [
      ".photo.folder + \"/\" + .photo.file",
      "[.photo.folder, \"/\", .photo.file] | add"
    ],
    "data": [
      {
        "input": {
          "photo": {
            "folder": "blah",
            "file": "halb"
          }
        },
        "output": "blah/halb"
      }
    ],
    "identifier": 29561830
  },
  {
    "context": [
      "If I have an object with two arrays containing unique values in it",
      "{'all':['A','B','C','ABC'],'some':['B','C']}",
      "How can I find `.all - .some`?",
      "In this case I am looking for `['A','ABC']`",
      "echo -n '{\"all\":[\"A\",\"B\",\"C\",\"ABC\"],\"some\":[\"B\",\"C\"]}' | jq '.all-.some'",
      "yields",
      "[\n  \"A\",\n  \"ABC\"\n]"
    ],
    "utterance": "Find elements in the array 'all' that are not present in the array 'some' within an object.",
    "expressions": [
      ".all - .some",
      ". as $d | .all | del(.[ indices($d.some[])[] ])"
    ],
    "data": [
      {
        "input": {
          "all": [
            "A",
            "B",
            "C",
            "ABC"
          ],
          "some": [
            "B",
            "C"
          ]
        },
        "output": [
          "A",
          "ABC"
        ]
      }
    ],
    "identifier": 29396154
  },
  {
    "context": [
      "I have a json file like below :",
      "[   ",
      "    {\"foo\": 42, \"bar\": \"less interesting data\"},",
      "    {\"foo\": 50, \"bar\": \"big data\"}",
      "]",
      "I'd like to use jq to convert its content to the following :",
      "[   ",
      "    {\"name\": 42, \"value\": \"less interesting data\"},",
      "    {\"name\": 50, \"value\": \"big data\"}",
      "]",
      "What you are looking for is:",
      "jq '[.[] | {name:.foo, value:.bar}]'",
      "Use [map](http://stedolan.github.io/jq/manual/#mapx) instead.",
      "map({ name: .foo, value: .bar })"
    ],
    "utterance": "Convert an array of objects by renaming the field 'foo' to 'name' and 'bar' to 'value' for each item.",
    "expressions": [
      "[.[] | {name:.foo, value:.bar}]",
      "map({ name: .foo, value: .bar })"
    ],
    "data": [
      {
        "input": [
          {
            "foo": 42,
            "bar": "less interesting data"
          },
          {
            "foo": 50,
            "bar": "big data"
          }
        ],
        "output": [
          {
            "name": 42,
            "value": "less interesting data"
          },
          {
            "name": 50,
            "value": "big data"
          }
        ]
      }
    ],
    "identifier": 29590304
  },
  {
    "context": [
      "I want to use `jq` to put a stream of json objects into a json array, for example, from \r\n\r\n    {\"a\":1}\r\n    {\"b\":2}\r\n\r\nto\r\n\r\n    [{\"a\":1},\r\n    {\"b\":2}]",
      "Slurp it up with the `-s` option.",
      "$ jq -s '.' <<< '{ \"a\": 1 } { \"b\": 2 }'",
      "As another option, reading the values using `inputs` is a much more flexible alternative.  You'll usually want to use this in conjunction with the `-n` option to prevent the first value from being consumed prematurely.",
      "$ jq -n '[inputs]' <<< '{ \"a\": 1 } { \"b\": 2 }'"
    ],
    "utterance": "Combine multiple separate objects into a single array.",
    "expressions": [
      ".",
      "// with -s (slurp) option",
      "[inputs]",
      "// with -n (null input) option"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1
          },
          {
            "b": 2
          }
        ],
        "output": [
          {
            "a": 1
          },
          {
            "b": 2
          }
        ]
      }
    ],
    "identifier": 29404575
  },
  {
    "context": [
      "the json has changed and a field is split in 2 fields: `file_path` is now split into `folder` and `file`. The script was reading the `file_path`, now the `folder` may not be present, so for creating the path of the file I have to verify if the field is there.",
      "echo \"$MESSAGE\" | jq -r '[ .folder, .file ] | join(\"/\")'",
      "if echo \"$MESSAGE\" | jq -e 'has(\"folder\")' > /dev/null; then\n    echo \"$MESSAGE\" | jq -r '.folder + \"/\" + .file'\nelse\n    echo \"$MESSAGE\" | jq -r .file\nfi"
    ],
    "utterance": "Concatenate the folder and file fields with a slash if folder exists; otherwise, return only the file field.",
    "expressions": [
      "[ .folder, .file ] | join(\"/\")",
      "if echo \"$MESSAGE\" | jq -e 'has(\"folder\")' > /dev/null; then\n    echo \"$MESSAGE\" | jq -r '.folder + \"/\" + .file'\nelse\n    echo \"$MESSAGE\" | jq -r .file\nfi"
    ],
    "data": [
      {
        "input": {
          "folder": "FLDR",
          "file": "fl"
        },
        "output": "FLDR/fl"
      },
      {
        "input": {
          "file": "fl"
        },
        "output": "null/fl"
      }
    ],
    "identifier": 29563145
  },
  {
    "context": [
      "How, using jq, do I select only the arrays which contain an element with \"first source\" as the name value, but which don't contain \"second_source\" as the name value of any element?",
      "You can use this filter:",
      "select(\n    (map(.name == \"first_source\") | any) and\n    (map(.name != \"second_source\") | all)\n)"
    ],
    "utterance": "Return all arrays that have at least one element with name equal to \"first_source\" and no elements with name equal to \"second_source\".",
    "expressions": [
      "select((map(.name == \"first_source\") | any) and (map(.name != \"second_source\") | all))"
    ],
    "data": [
      {
        "input": [
          [
            {
              "name": "first_source",
              "id": "abcdef"
            },
            {
              "name": "second_source",
              "id": "ghijkl"
            },
            {
              "name": "third_source",
              "id": "opqrst"
            }
          ],
          [
            {
              "name": "first_source",
              "id": "aaaaaa"
            },
            {
              "name": "third_source",
              "id": "bbbbbb"
            }
          ]
        ],
        "output": [
          [
            {
              "name": "first_source",
              "id": "aaaaaa"
            },
            {
              "name": "third_source",
              "id": "bbbbbb"
            }
          ]
        ]
      }
    ],
    "identifier": 29429107
  },
  {
    "context": [
      "I want to extract from each line two of them, WebsiteName and TestID, so I can check if WebsiteName matches the one I'm interested in, get the TestID out and pass this to a second curl statement to delete the test.",
      "If I'm getting your question right, it sounds like what you want is to, for each element, select those where `.WebsiteName == \"needle\"`, and then get `.TestID` from it. You can do just that:",
      "`.[] | select(.WebsiteName == \"needle\") | .TestID`",
      "If you want an array as the result, you can wrap the above script in square brackets."
    ],
    "utterance": "Find the TestID value for the entry where WebsiteName equals 'SomeSite1'.",
    "expressions": [
      ".[] | select(.WebsiteName == \"SomeSite1\") | .TestID",
      "[.[] | select(.WebsiteName == \"SomeSite1\") | .TestID]"
    ],
    "data": [
      {
        "input": [
          {
            "TestID": 123,
            "WebsiteName": "SomeSite1"
          },
          {
            "TestID": 1234,
            "WebsiteName": "SomeSite2"
          },
          {
            "TestID": 555,
            "WebsiteName": "foo*ba@r blah[54]quux{4,5,6}"
          }
        ],
        "output": 123
      }
    ],
    "identifier": 29628089
  },
  {
    "context": [
      "Given an input json string of keys from an array, return an object with only the entries that had keys in the original object and in the input array.",
      "For the input object {\"key1\":1, \"key2\":2, \"key3\":3} I would like to drop all keys that are not in the set of desired keys [\"key1\",\"key3\",\"key4\"]",
      "with_entries( select( .key as $k | $keys | index($k) ) )",
      "with_entries(select(.key | IN($keys[])))"
    ],
    "utterance": "Return an object containing only the entries whose keys are present in both the original object and a specified array of desired keys.",
    "expressions": [
      "with_entries( select( .key as $k | $keys | index($k) ) )",
      "with_entries(select(.key | IN($keys[])))",
      "with_entries(\n    select(\n        .key as $k | any($keys | fromjson[]; . == $k)\n    )\n)",
      "with_entries(\n      select(\n          .key == ($desired_keys[])\n      )\n   )"
    ],
    "data": [
      {
        "input": {
          "object": {
            "key1": 1,
            "key2": 2,
            "key3": 3
          },
          "keys": [
            "key1",
            "key3",
            "key4"
          ]
        },
        "output": {
          "key1": 1,
          "key3": 3
        }
      }
    ],
    "identifier": 29518137
  },
  {
    "context": [
      "At the output I exect to see two results `\"Google\"` and `\"Laura\"`",
      "Can someone please help to me to get below result:\r\n\r\n    \"Google\"\r\n    \"Laura\"",
      "Use brackets around the second part of the expression, and shorthand key filter syntax as in:\r\n\r\n    jq \".name, (.employees|map(select(.division==\\\"HR\\\"))[0].name)\" JSON.txt "
    ],
    "utterance": "Extract the root object name and the name of the first employee whose division is HR.",
    "expressions": [
      ".name, (.employees | map(select(.division==\"HR\"))[0].name)"
    ],
    "data": [
      {
        "input": {
          "name": "Google",
          "location": {
            "street": "1600 Amphitheatre Parkway",
            "city": "Mountain View",
            "state": "California",
            "country": "US"
          },
          "employees": [
            {
              "name": "Michael",
              "division": "Engineering"
            },
            {
              "name": "Laura",
              "division": "HR"
            },
            {
              "name": "Elise",
              "division": "Marketing"
            }
          ]
        },
        "output": [
          "Google",
          "Laura"
        ]
      }
    ],
    "identifier": 29745740
  },
  {
    "context": [
      "1.  Update RollbackPoint to \"1012\" where Number = 1015",
      "2.  Update value to \"AWS\" where name = \"accountType\" under Parameters, where Number = 1012",
      ".Actions |= map(\n    (select(.Number == 1015) |\n        .RollbackPoint = \"1012\"\n    ) //\n    (select(.Number == 1012) |\n        .Parameters |= map((select(.Name == \"accountType\") | .Value = \"AWS\") // .)\n    ) //\n    .\n)",
      ".Actions[] |= (\n      if .Number == 1015 then .RollbackPoint = \"1012\" else . end\n    | if .Number == 1012 then .Parameters[] |= (\n         if .Name == \"accountType\" then .Value = \"AWS\" else . end\n      ) else . end\n )"
    ],
    "utterance": "Update RollbackPoint to \"1012\" for items where Number equals 1015, and update the Value of Parameters where Name is \"accountType\" to \"AWS\" for items where Number equals 1012",
    "expressions": [
      ".Actions |= map(\n    (select(.Number == 1015) |\n        .RollbackPoint = \"1012\"\n    ) //\n    (select(.Number == 1012) |\n        .Parameters |= map((select(.Name == \"accountType\") | .Value = \"AWS\") // .)\n    ) //\n    .\n)",
      ".Actions[] |= (\n      if .Number == 1015 then .RollbackPoint = \"1012\" else . end\n    | if .Number == 1012 then .Parameters[] |= (\n         if .Name == \"accountType\" then .Value = \"AWS\" else . end\n      ) else . end\n )"
    ],
    "data": [
      {
        "input": {
          "Actions": [
            {
              "Number": 1012,
              "RollbackPoint": "xxx_1012_RollbackPoint_xxx",
              "Parameters": [
                {
                  "Name": "accountType",
                  "Value": "xxx_1012_accountType_xxx"
                },
                {
                  "Name": "userPassword",
                  "Value": "xxx_1012_userPassword_xxx"
                }
              ]
            },
            {
              "Number": 1015,
              "RollbackPoint": "xxx_1015_RollbackPoint_xxx",
              "Parameters": [
                {
                  "Name": "accountType",
                  "Value": "xxx_1015_accountType_xxx"
                },
                {
                  "Name": "skipExport",
                  "Value": "xxx_1015_skipExport_xxx"
                }
              ]
            }
          ]
        },
        "output": {
          "Actions": [
            {
              "Number": 1012,
              "RollbackPoint": "xxx_1012_RollbackPoint_xxx",
              "Parameters": [
                {
                  "Name": "accountType",
                  "Value": "AWS"
                },
                {
                  "Name": "userPassword",
                  "Value": "xxx_1012_userPassword_xxx"
                }
              ]
            },
            {
              "Number": 1015,
              "RollbackPoint": "1012",
              "Parameters": [
                {
                  "Name": "accountType",
                  "Value": "xxx_1015_accountType_xxx"
                },
                {
                  "Name": "skipExport",
                  "Value": "xxx_1015_skipExport_xxx"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 29592224
  },
  {
    "identifier": 29815940
  },
  {
    "context": [
      "Group the items by the key `bid` (and maybe `title`) and aggregate the authors and tags.",
      "group_by(.bid) |\n    map({\n        bid:     .[0].bid,\n        title:   .[0].title,\n        authors: map(.aid),\n        tags:    map(.tags)\n    })",
      "Here is the output :\n\n    [ \n      { \n        id: 5,\n        authors: [ 4, 23 ],\n        tags: 3,\n        title: 'Jacques le fataliste et son ma\u00eetre' \n      } \n    ]"
    ],
    "utterance": "Group objects by book id, and for each group, produce an object with book id, title, and arrays of author ids and tag ids.",
    "expressions": [
      "group_by(.bid) |\n  map({\n    id: .[0].bid,\n    title: .[0].title,\n    authors: map(.aid),\n    tags: map(.tags)\n  })",
      "group_by(.bid) |\n  map({\n    bid: .[0].bid,\n    title: .[0].title,\n    authors: map(.aid),\n    tags: map(.tags)\n  })"
    ],
    "data": [
      {
        "input": [
          {
            "bid": 5,
            "aid": 4,
            "tags": 3,
            "title": "Jacques le fataliste et son ma\u00eetre"
          },
          {
            "bid": 5,
            "aid": 23,
            "tags": 8,
            "title": "Jacques le fataliste et son ma\u00eetre"
          }
        ],
        "output": [
          {
            "id": 5,
            "title": "Jacques le fataliste et son ma\u00eetre",
            "authors": [
              4,
              23
            ],
            "tags": [
              3,
              8
            ]
          }
        ]
      }
    ],
    "identifier": 29702210
  },
  {
    "context": [
      "I have an array of json objects and I would like to extract a subset of the array such that the `.name` field matches a set of input strings.",
      "jq -n '[\"a\",\"b\",\"c\",\"d\",\"e\"] | map({name:.,foo:\"bar\"})' \\\n  | jq 'map(select(.name==\"a\" or .name==\"c\"))'",
      "Move everything into the `select` condition.  You don't need to do two separate calls to jq.",
      "$ echo '[\"a\",\"b\",\"c\",\"d\",\"e\"]' | jq --arg names 'a c'\n    'map(select(. == ($names | split(\" \")[])) | { name: ., foo: \"bar\" })'",
      "here is a less perl-esqe solution that uses **--argjson** and **inside**",
      "$ echo '[\"a\",\"b\",\"c\",\"d\",\"e\"]' | jq --argjson wanted '[\"a\",\"c\"]' '\n  .[]                          # break array into elements\n| if ([.]|inside($wanted))     # if element is in wanted\n  then {name: ., foo:\"bar\"}    # generate desired output\n  else empty                   # otherwise generate nothing\n  end\n'"
    ],
    "utterance": "Select all objects in an array whose name field matches any value from a specified set of strings, such as 'a' or 'c'.",
    "expressions": [
      "map(select(.name==\"a\" or .name==\"c\"))",
      "map(select(. == ($names | split(\" \")[])) | { name: ., foo: \"bar\" })",
      ".[] | if ([.]|inside($wanted)) then {name: ., foo:\"bar\"} else empty end"
    ],
    "data": [
      {
        "input": [
          {
            "name": "a",
            "foo": "bar"
          },
          {
            "name": "b",
            "foo": "bar"
          },
          {
            "name": "c",
            "foo": "bar"
          },
          {
            "name": "d",
            "foo": "bar"
          },
          {
            "name": "e",
            "foo": "bar"
          }
        ],
        "output": [
          {
            "name": "a",
            "foo": "bar"
          },
          {
            "name": "c",
            "foo": "bar"
          }
        ]
      }
    ],
    "identifier": 29659436
  },
  {
    "context": [
      "Is there a way to get all unique key names, without invoking a unique sort outside `jq`?",
      "$ jq -n '[inputs | keys[]] | unique | sort' input.json",
      "$ jq -n 'reduce (inputs | keys[]) as $k ({}; .[$k] = null) | keys' input.json",
      "$ jq -n 'foreach (inputs | keys[]) as $k ({}; .[$k]+=1; if .[$k]==1 then $k else empty end)' input.json"
    ],
    "utterance": "Get all unique key names occurring in an input stream of objects, without using external tools.",
    "expressions": [
      "[inputs | keys[]] | unique",
      "reduce (inputs | keys[]) as $k ({}; .[$k] = null) | keys",
      "foreach (inputs | keys[]) as $k ({}; .[$k]+=1; if .[$k]==1 then $k else empty end)"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1,
            "b": 2,
            "c": 3
          },
          {
            "a": 4,
            "b": 5,
            "d": 6
          }
        ],
        "output": [
          "a",
          "b",
          "c",
          "d"
        ]
      }
    ],
    "identifier": 29822622
  },
  {
    "context": [
      "I would like to do some filtering on this. For example, when i search for first_name, mike1, I should get the header and the matching request inside request. Also the matching result inside the Response message. So, the output is expected as follows for the search string mike1.",
      "Basically, i want to filter out unmatched request inside the requests array and unmatched result inside the result array.",
      "jq --arg key first_name \\\r\n   --arg value mike1 \\\r\n   'select(.message.response.resultsList.result[]?[$key]==$value) | .message' \\\r\n   <in.json"
    ],
    "utterance": "Filter documents so that only objects with requests or results containing first_name equal to mike1 are included, and within those objects, only keep the matching requests or results.",
    "expressions": [
      "map(select((.requests? // []) | map(.first_name == \"mike1\") | any or (.message?.response?.resultsList?.result? // []) | map(.first_name == \"mike1\") | any)\n  | .requests |= (map(select(.first_name == \"mike1\")))\n  | if .message? then .message.response.resultsList.result |= (map(select(.first_name == \"mike1\"))) else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "header": {
              "user": "baskar"
            },
            "requests": [
              {
                "first_name": "mike",
                "last_name": "mat"
              },
              {
                "first_name": "mike1",
                "last_name": "mat"
              }
            ],
            "check": [
              "Y"
            ]
          },
          {
            "header": {
              "user": "baskar"
            },
            "message": {
              "header": {
                "user": "baskar"
              },
              "response": {
                "resultsList": {
                  "result": [
                    {
                      "first_name": "mike1",
                      "last_name": "mat"
                    }
                  ]
                },
                "errorMsg": null
              }
            }
          }
        ],
        "output": [
          {
            "header": {
              "user": "baskar"
            },
            "requests": [
              {
                "first_name": "mike1",
                "last_name": "mat"
              }
            ],
            "check": [
              "Y"
            ]
          },
          {
            "header": {
              "user": "baskar"
            },
            "message": {
              "header": {
                "user": "baskar"
              },
              "response": {
                "resultsList": {
                  "result": [
                    {
                      "first_name": "mike1",
                      "last_name": "mat"
                    }
                  ]
                },
                "errorMsg": null
              }
            }
          }
        ]
      }
    ],
    "identifier": 29761327
  },
  {
    "context": [
      "I want to change `baz`'s accompanying format to 'csv':",
      "I have found that this works:",
      "jq 'map(if .id==\"baz\" then .format=\"csv\" else . end)' my.json",
      "A complex assignment is what you're looking for:",
      "jq '(.[] | select(.id == \"baz\") | .format) |= \"csv\"' my.json",
      "Edit: using `map`:",
      "jq 'map((select(.id == \"baz\") | .format) |= \"csv\")' my.json"
    ],
    "utterance": "Update the format value to 'csv' for the object whose id is 'baz' in an array of objects.",
    "expressions": [
      "jq '(.[] | select(.id == \"baz\") | .format) |= \"csv\"'",
      "jq 'map((select(.id == \"baz\") | .format) |= \"csv\")'",
      "jq 'map(if .id==\"baz\" then .format=\"csv\" else . end)'"
    ],
    "data": [
      {
        "input": [
          {
            "format": "geojson",
            "id": "foo"
          },
          {
            "format": "geojson",
            "id": "bar"
          },
          {
            "format": "zip",
            "id": "baz"
          }
        ],
        "output": [
          {
            "format": "geojson",
            "id": "foo"
          },
          {
            "format": "geojson",
            "id": "bar"
          },
          {
            "format": "csv",
            "id": "baz"
          }
        ]
      }
    ],
    "identifier": 29772676
  },
  {
    "context": [
      "I'd like to extract a subset of the key/values from the nested requests based on the condition, whilst keeping other properties from the outer object intact, producing something like:  When i search for first_name='mike'",
      "But, it gives the subset of the matched requests but not returning header and check element.",
      "You need to think of it in terms of updating the requests array by filtering it.",
      "This should work:",
      ".requests |= map(select(.first_name == \"mike\"))"
    ],
    "utterance": "Filter the requests array, keeping only elements where first_name equals 'mike', while preserving all other properties of the object.",
    "expressions": [
      ".requests |= map(select(.first_name == \"mike\"))"
    ],
    "data": [
      {
        "input": {
          "header": {
            "user": "baskar"
          },
          "requests": [
            {
              "first_name": "mike",
              "last_name": "mat"
            },
            {
              "first_name": "mike1",
              "last_name": "mat"
            }
          ],
          "check": [
            "Y"
          ]
        },
        "output": {
          "header": {
            "user": "baskar"
          },
          "requests": [
            {
              "first_name": "mike",
              "last_name": "mat"
            }
          ],
          "check": [
            "Y"
          ]
        }
      }
    ],
    "identifier": 29834097
  },
  {
    "context": [
      "I want to convert this JSON into csv file with company name and employee name.",
      "\"Google\",\"Michael\"\n\"Google\",\"Laura\"\n\"Google\",\"Elise\"\n\"Microsoft\",\"Brett\"\n\"Microsoft\",\"David\"\n\"Amazon\",\"Watson\"",
      "Can someone guide me to write the script without hardcoding the index values?",
      "Script should be able generate output for any number `results` and each cotaining information of any number of companies.",
      "You need to flatten down the results first to rows of company and employee names.  Then with that, you can convert to csv rows.",
      "map(.results | map({ cn: .name, en: .employees[].name } | [ .cn, .en ])) | add[] | @csv",
      "Since you have a stream of inputs, you'll have to slurp (`-s`) it in.  Since you want to output csv, you'll want to use raw output (`-r`)."
    ],
    "utterance": "Produce a two-column CSV listing each company name and each employee name for all companies and employees in the data, without hardcoding any array indices.",
    "expressions": [
      "map(.results | map({ cn: .name, en: .employees[].name } | [ .cn, .en ])) | add[] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "results": [
              {
                "name": "Google",
                "employees": [
                  {
                    "name": "Michael",
                    "division": "Engineering"
                  },
                  {
                    "name": "Laura",
                    "division": "HR"
                  },
                  {
                    "name": "Elise",
                    "division": "Marketing"
                  }
                ]
              },
              {
                "name": "Microsoft",
                "employees": [
                  {
                    "name": "Brett",
                    "division": "Engineering"
                  },
                  {
                    "name": "David",
                    "division": "HR"
                  }
                ]
              }
            ]
          },
          {
            "results": [
              {
                "name": "Amazon",
                "employees": [
                  {
                    "name": "Watson",
                    "division": "Marketing"
                  }
                ]
              }
            ]
          }
        ],
        "output": [
          "\"Google\",\"Michael\"",
          "\"Google\",\"Laura\"",
          "\"Google\",\"Elise\"",
          "\"Microsoft\",\"Brett\"",
          "\"Microsoft\",\"David\"",
          "\"Amazon\",\"Watson\""
        ]
      }
    ],
    "identifier": 29764836
  },
  {
    "context": [
      "Here, the orderid is been hardcoded to 2260. But my requirement is to make it parameter driven.",
      "So I store the param to a variable called ORDER_ID like, ORDER_ID=2260",
      "and then using $ORDER_ID, but it doesnt work.",
      "One approach which will work is to use the `--argjson` option, use single quotes for the entire jq filter and double quotes for strings literals within the filter.",
      "jq --argjson ORDER_ID \"$ORDER_ID\" '\nif (.requests|length)!=0 then .requests |= map(select(.orderId == $ORDER_ID)) else \"NO\" end\n'"
    ],
    "utterance": "Filter objects where .requests contains items with orderId equal to a shell variable ORDER_ID, replacing hardcoded value with the parameter.",
    "expressions": [
      "jq --argjson ORDER_ID \"$ORDER_ID\" 'if (.requests|length)!=0 then .requests |= map(select(.orderId == $ORDER_ID)) else \"NO\" end'"
    ],
    "data": [
      {
        "input": {
          "requests": [
            {
              "orderId": 2260
            }
          ]
        },
        "output": {
          "requests": [
            {
              "orderId": 2260
            }
          ]
        }
      }
    ],
    "identifier": 29926814
  },
  {
    "context": [
      "Can you get to this:\r\n\r\n    [ {\"name\": \"john\", \"age\": 20, \"gender\": \"male\"},\r\n      {\"name\": \"jane\", \"age\": 30, \"gender\": \"female\"},\r\n      {\"name\": \"bob\", \"age\": 25, \"gender\": \"male\"} ]\r\n\r\nusing only jq?",
      "Is it possible to dynamically extract the headers and then combine them with the values with a jq one-liner?",
      "jq -Rs 'split(\"\\n\")|map(split(\",\")|to_entries)|.[0] as $header|.[1:]|map(reduce .[] as $item ({};.[ $header[$item.key].value ]=$item.value))'",
      "jq -R 'split(\",\") as $h|reduce inputs as $in ([]; . += [$in|split(\",\")|. as $a|reduce range(0,length) as $i ({};.[ $h[$i] ]=$a[$i])])'",
      "[inputs]|map(select(test(\"^[\\\\s]*$\");\"\")|not)|split(\",\")|map(sub(\"^\\\\ +\";\"\")))|.[0] as $headers|.[1:][]|map(fromjson? //.)|with_entries(.key=$headers[.key])"
    ],
    "utterance": "Convert CSV data where the first row is headers and subsequent rows are values into an array of objects by dynamically extracting headers and pairing them with each value row, with no hardcoded keys.",
    "expressions": [
      "split(\"\\n\") | map( split(\",\") | to_entries ) | .[0] as $header | .[1:] | map( reduce .[] as $item ( {}; .[$header[$item.key].value] = $item.value ) )",
      "split(\",\") as $h|reduce inputs as $in ([]; . += [$in|split(\",\")|. as $a|reduce range(0,length) as $i ({};.[ $h[$i] ]=$a[$i])])",
      "[inputs]|map(select(test(\"^[\\s]*$\");\"\")|not)|split(\",\")|map(sub(\"^\\ +\";\"\")))|.[0] as $headers|.[1:][]|map(fromjson? //.)|with_entries(.key=$headers[.key])"
    ],
    "data": [
      {
        "input": "name, age, gender\njohn, 20, male\njane, 30, female\nbob, 25, male",
        "output": [
          {
            "name": "john",
            "age": 20,
            "gender": "male"
          },
          {
            "name": "jane",
            "age": 30,
            "gender": "female"
          },
          {
            "name": "bob",
            "age": 25,
            "gender": "male"
          }
        ]
      }
    ],
    "identifier": 29663187
  },
  {
    "context": [
      "and I want to extract out the source and dest sections, but as one object.",
      "As a more advanced stage, I would like to be able to get just part of this (the IP addresses) without the other data, but still as an object",
      "jq '{ \"dest\": { \"ip\": .dest.ip },  \"source\": { \"ip\": .source.ip } }'",
      "which outputs:\n\n    {\n      \"dest\": {\n        \"ip\": \"192.168.2.2\"\n      },\n      \"source\": {\n        \"ip\": \"10.1.5.1\"\n      }\n    }"
    ],
    "utterance": "Extract only the ip addresses from the source and dest sections, each as an object under their respective keys.",
    "expressions": [
      "{ \"dest\": { \"ip\": .dest.ip },  \"source\": { \"ip\": .source.ip } }"
    ],
    "data": [
      {
        "input": {
          "reason": "TCP FINs",
          "bytes": "1759",
          "duration": "0:00:00",
          "dest": {
            "interface": "inside",
            "ip": "192.168.2.2",
            "port": "88"
          },
          "source": {
            "interface": "outside",
            "ip": "10.1.5.1",
            "port": "60470"
          },
          "connection-id": "400508768",
          "proto": "TCP",
          "hostname": "192.168.1.1",
          "timestamp": "Apr 28 13:00:01",
          "event.tags": [
            "cisco",
            "ASA-6-302014"
          ]
        },
        "output": {
          "dest": {
            "ip": "192.168.2.2"
          },
          "source": {
            "ip": "10.1.5.1"
          }
        }
      }
    ],
    "identifier": 29929025
  },
  {
    "context": [
      "How can I add the header (in this case `message,name`) at the top? (I know it's possible manually, but how to do it within `jq`?)",
      "\"Just add the header text in an array in front of the values.\n\n    [\"Commit Message\",\"Committer Name\"], (.[].commit | [.message,.committer.name]) | @csv\"",
      "`map({message: .commit.message, name: .commit.committer.name}) | (.[0] | to_entries | map(.key)), (.[] | [.[]]) | @csv`"
    ],
    "utterance": "Output an array of commit message and committer name as CSV, with a header row at the top.",
    "expressions": [
      "[\"Commit Message\",\"Committer Name\"], (.[].commit | [.message,.committer.name]) | @csv",
      "map({message: .commit.message, name: .commit.committer.name}) | (.[0] | to_entries | map(.key)), (.[] | [.[]]) | @csv"
    ],
    "identifier": 30015555
  },
  {
    "context": [
      "Looks like else is mandatory here. I dont want to do anything inside the else block. Is there anyway, I can ignore else or just print some whitespce inside else.",
      "Since you&#39;re not making any further changes to the object, just use the &quot;identity&quot; filter `.`.",
      "if (.requests | length) then ... else . end",
      "You may want to use the idiom:\r\n\r\n    if CONDITION then WHATEVER else empty end",
      "select(CONDITION) | WHATEVER",
      "After the release of jq 1.6, a change was made so that &quot;if without else&quot; has the semantics of &quot;if _ then _ else . end&quot;, that is:\r\n\r\n   `if P then Q end` === `if P then Q else . end`"
    ],
    "utterance": "Conditionally filter and update an object if a node exists, and leave the object unchanged otherwise, without unwanted output values.",
    "expressions": [
      "if (.requests | length) != 0 then .requests |= map(select(.id == \"123\")) elif (.result | length ) != 0 then .result |= map(select(.id== \"123\")) else . end",
      ".requests |= map(select(.id == \"123\")) | .result |= map(select(.id== \"123\"))",
      "if CONDITION then WHATEVER else empty end",
      "select(CONDITION) | WHATEVER",
      "if P then Q end"
    ],
    "identifier": 29949184
  },
  {
    "context": [
      "cat Filename.json | jq --raw-output '._data.data[] | [.Date, .Object, .ID, .Name ] | @csv' > /home/Filename.csv",
      "jq: error: Cannot iterate over null",
      "cat Filename.json | sed 1d | sed 's/},/}/' | jq --raw-output '. | [.Date, .Object, .ID, .Name ] | @csv'"
    ],
    "utterance": "Extract the Date, Object, ID, and Name fields from each entry in the _data.data array and convert them to CSV rows.",
    "expressions": [
      "._data.data[] | [.Date, .Object, .ID, .Name ] | @csv"
    ],
    "identifier": 30113355
  },
  {
    "context": [
      "but what if I only want to get the values with type is 3 meaning the output will only show target2.com and target3.com",
      "$ jq -r '.test[] | select(.type == \"3\").Web' file.json",
      "This passes the `.test[]` nodes to `select`, which filters its input using the `.type == \"3\"` selector. Then it selects `.Web` from the filtered list."
    ],
    "utterance": "Extract the Web properties of all objects in the test array where type equals 3.",
    "expressions": [
      ".test[] | select(.type == \"3\").Web"
    ],
    "data": [
      {
        "input": {
          "name": "value",
          "website": "https://google.com",
          "type": "money",
          "some": "0",
          "something_else": "0",
          "something_new": "0",
          "test": [
            {
              "Web": "target1.com",
              "type": "2"
            },
            {
              "Web": "target2.com",
              "type": "3"
            },
            {
              "Web": "target3.com",
              "type": "3"
            },
            {
              "Web": "target3.com",
              "type": "3"
            }
          ]
        },
        "output": [
          "target2.com",
          "target3.com",
          "target3.com"
        ]
      }
    ],
    "identifier": 30039157
  },
  {
    "context": [
      "I would like to reduce it to print, on a single line, from each `snapshot` the values of the  `end_time_in_millis` and `snapshot` property separate by a space:",
      "Use this filter:",
      ".snapshots[] | \"\\(.end_time_in_millis) \\(.snapshot)\"",
      "This builds up a string for each of the snapshots consisting of the end time and the snapshot name."
    ],
    "utterance": "For each object, output the end_time_in_millis and snapshot name separated by a space, one per line.",
    "expressions": [
      ".snapshots[] | \"\\(.end_time_in_millis) \\(.snapshot)\""
    ],
    "data": [
      {
        "input": {
          "snapshots": [
            {
              "shards": {
                "successful": 1,
                "failed": 0,
                "total": 1
              },
              "failures": [],
              "snapshot": "snapshot_1",
              "indices": [
                "myindex1"
              ],
              "state": "SUCCESS",
              "start_time": "2015-04-21T09:45:47.041Z",
              "start_time_in_millis": 1429609547041,
              "end_time": "2015-04-21T09:49:50.767Z",
              "end_time_in_millis": 1429609790767,
              "duration_in_millis": 243726
            },
            {
              "shards": {
                "successful": 1,
                "failed": 0,
                "total": 1
              },
              "failures": [],
              "snapshot": "snapshot_2",
              "indices": [
                "myindex1"
              ],
              "state": "SUCCESS",
              "start_time": "2015-04-22T05:36:02.333Z",
              "start_time_in_millis": 1429680962333,
              "end_time": "2015-04-22T05:39:29.896Z",
              "end_time_in_millis": 1429681169896,
              "duration_in_millis": 207563
            }
          ]
        },
        "output": "1429609790767 snapshot_1\n1429681169896 snapshot_2"
      }
    ],
    "identifier": 29982897
  },
  {
    "context": [
      "And I would like to have a tab separated file format:\r\n\r\n    Person   12   15\r\n    Person   13   16",
      "Just make sure you use the raw output `-r` option.",
      "[ .a, .birthDay, .deathDay ] | join(\"\\t\")",
      "Recent versions of jq (e.g. 1.5rc1 ... ) include a filter named `@tsv`."
    ],
    "utterance": "Print the fields a, birthDay, and deathDay separated by tabs.",
    "expressions": [
      "[.a, .birthDay, .deathDay] | join(\"\t\")",
      "[.a, .birthDay, .deathDay] | @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "a": "Person",
            "birthDay": "12",
            "deathDay": "15"
          },
          {
            "a": "Person",
            "birthDay": "13",
            "deathDay": "16"
          }
        ],
        "output": "Person\t12\t15\nPerson\t13\t16"
      }
    ],
    "identifier": 30222305
  },
  {
    "context": [
      "what would be the best way to select the value of any of these keys by providing the name of the key as a variable?",
      "\"a_key\" as $key | .$key",
      "\"a_key\" as $key | .[$key]"
    ],
    "utterance": "Select the value of a key whose name is provided as a variable with the value 'a_key'.",
    "expressions": [
      "\"a_key\" as $key | .[$key]"
    ],
    "data": [
      {
        "input": {
          "a_key": 2,
          "another_key": 100,
          "one_more_key": -4.2
        },
        "output": 2
      }
    ],
    "identifier": 30330037
  },
  {
    "context": [
      "I want to insert this data to the database with the following columns:\r\n\r\nage_group | vehicle | measurements",
      "How Can I extract the info from the json object to a text file as required using jq?",
      "jq 'to_entries | map(.key as $mykey | .value | to_entries | map([$mykey, .key, .value])) | add ' test.json ",
      "Edit:how to get the inner keys as required below?\r\n\r\n    age_group | vehicle  | Dimension",
      "jq 'to_entries | map(.key as $mykey | .value | to_entries | map(.key as $mykey2 | .value | to_entries | map([$mykey, $mykey2, .key]))) | add | add ' test.json"
    ],
    "utterance": "Produce rows combining top-level group, vehicle, and each dimension as separate columns.",
    "expressions": [
      "to_entries | map(.key as $mykey | .value | to_entries | map([$mykey, .key, .value])) | add",
      "to_entries | map(.key as $mykey | .value | to_entries | map(.key as $mykey2 | .value | to_entries | map([$mykey, $mykey2, .key]))) | add | add"
    ],
    "data": [
      {
        "input": {
          "adults": {
            "car": {
              "length": [
                20,
                25
              ],
              "width": [
                225,
                40
              ]
            },
            "tractor": {
              "length": [
                20,
                23
              ],
              "width": [
                223,
                40
              ]
            }
          },
          "children": {
            "cycle": {
              "length": [
                20,
                21
              ],
              "width": [
                221,
                40
              ]
            }
          }
        },
        "output": [
          [
            "adults",
            "car",
            "length"
          ],
          [
            "adults",
            "car",
            "width"
          ],
          [
            "adults",
            "tractor",
            "length"
          ],
          [
            "adults",
            "tractor",
            "width"
          ],
          [
            "children",
            "cycle",
            "length"
          ],
          [
            "children",
            "cycle",
            "width"
          ]
        ]
      }
    ],
    "identifier": 30163016
  },
  {
    "context": [
      "Here\u0019s a working command to get `config-var1` from index `0`. ",
      "$ jq -r '.[\"protocol-config\"][0][\"config-var1\"]' < json",
      "Now we can try to abstract out the arguments, testing to make sure it still works:",
      "$ jq -r --arg i \"0\" --arg var \"config-var1\" \\\n    '.[\"protocol-config\"][$i|tonumber][$var]' < json",
      "jq -r --arg i \"$i\" --arg var \"config-$val\" \\\n    '.[\"protocol-config\"][$i|tonumber][$var]' < \"$file\""
    ],
    "utterance": "Retrieve the value of a field with a dash in its name (such as config-var1) from the protocol-config object at a specified index, where field and index are passed as arguments.",
    "expressions": [
      ".[\"protocol-config\"][$i|tonumber][$var]"
    ],
    "data": [
      {
        "input": {
          "protocol-config": [
            {
              "protocol": "p1",
              "config-var1": "vc1",
              "config-var2": "vc2"
            },
            {
              "protocol": "p2",
              "config-var1": "vc3",
              "config-var2": "vc4"
            }
          ]
        },
        "output": "vc1"
      }
    ],
    "identifier": 30314137
  },
  {
    "context": [
      "We are able to `jq --sort-keys` (http://stedolan.github.io/jq/) to sort all of the keys, but I'm struggling to find out how to use the `sort_by` function to then sort certain specific elements by the value of certain keys (so, in the example above, sorting by `properties.name` for example. Any ideas?",
      "Basically, it looks like this:\n\n```sh\njq \\\n  '.components.rows|=sort_by(.id)|.components.rows[].properties|=sort_by(.name)' \\\n  file.json > out.json\n```",
      "Select the right object,  \nwalk into arrays if needed,  \nthen `sort_by` a single value. \n\nI was trying `sort_by(.components.rows.id)` which failed.\n\n`|=` instead of `|` passes the values along instead of stripping them."
    ],
    "utterance": "Sort the objects in the 'components.rows' array by 'id', then sort each object's 'properties' array by 'name'.",
    "expressions": [
      ".components.rows|=sort_by(.id)|.components.rows[].properties|=sort_by(.name)"
    ],
    "data": [
      {
        "input": {
          "components": {
            "rows": [
              {
                "id": "CHARTS",
                "name": "Charts",
                "parent": "UnIqEiD",
                "properties": [
                  {
                    "name": "Group",
                    "type": "Label",
                    "value": "Charts"
                  }
                ],
                "type": "Label",
                "typeDesc": "<i>Group</i>"
              },
              {
                "id": "kjalajsdjf",
                "meta_cdwSupport": "true",
                "parent": "CHARTS",
                "properties": [
                  {
                    "name": "name",
                    "type": "Id",
                    "value": "Value1"
                  },
                  {
                    "name": "title",
                    "type": "String",
                    "value": "Value2"
                  },
                  {
                    "name": "listeners",
                    "type": "Listeners",
                    "value": "[]"
                  }
                ]
              }
            ]
          }
        }
      }
    ],
    "identifier": 30331504
  },
  {
    "context": [
      "sometimes, I have stuff like this (when logging http responses):",
      "{\r\n  \"foo\": \"bar\",\r\n  \"fi\": \"bo\",\r\n  \"stream\": \"{\\n  \\\"json\\\": \\\"asAString\\\"\\n}\"\r\n}",
      "would like to end up with something like this:",
      "{\r\n  \"foo\": \"bar\",\r\n  \"fi\": \"bo\",\r\n  \"stream\": {\r\n    \"json\": \"asAString\"\r\n  }\r\n}",
      "You need to parse the string if that's what you want.",
      ".stream |= fromjson"
    ],
    "utterance": "Transform an object where the 'stream' field is a string representing a JSON object, so that 'stream' becomes a parsed object instead of a string.",
    "expressions": [
      ".stream |= fromjson"
    ],
    "data": [
      {
        "input": {
          "foo": "bar",
          "fi": "bo",
          "stream": "{\n  \"json\": \"asAString\"\n}"
        },
        "output": {
          "foo": "bar",
          "fi": "bo",
          "stream": {
            "json": "asAString"
          }
        }
      }
    ],
    "identifier": 30378134
  },
  {
    "context": [
      "\"echo \\\"$emails\\\" | ./jq '.total_rows'\"",
      "\"total_rows=\\\"$emails\\\" | ./jq '.total_rows'\"",
      "\"You have to use the right quotation, like this:\\n    total_rows=`echo \\\"$emails\\\" | ./jq '.total_rows'`\"",
      "\"it is better to use $() for command substitution. ... So what you can do is:\\n    total_rows=$(echo \\\"$emails\\\" | ./jq '.total_rows')\""
    ],
    "utterance": "Extract the value of the total_rows field from the input and assign it to a shell variable.",
    "expressions": [
      ".total_rows"
    ],
    "identifier": 30528518
  },
  {
    "context": [
      "What I would like to get is:",
      "<OrderCreateResponse xmlns=\"http://api.example.com/schema/checkout/1.0\">",
      "Or at least the well-formed xml in any raw form (from that point I can use xmllint).",
      "You can ignore this restriction by using the raw output option (`-r`).  This will return the value of the string.",
      "    $ tail system.log | jq -r '.rom_response_body'"
    ],
    "utterance": "Extract the raw value of the rom_response_body field containing XML, with all escaping and JSON formatting removed.",
    "expressions": [
      ".rom_response_body",
      ".rom_response_body | @text"
    ],
    "data": [
      {
        "input": {
          "rom_response_body": "<?xml version=\\\"1.0\\\" encoding=\\\"UTF-8\\\"?>\n<OrderCreateResponse xmlns=\\\"http://api.example.com/schema/checkout/1.0\\\">\n   <ResponseStatus>Success</ResponseStatus>\n   <ResponseDescription>CustomerOrderId = 0005410600539 , OrderUUID = 57c27a87-2f2e-41d1-bc20-afef511b91aa</ResponseDescription>\n</OrderCreateResponse>"
        },
        "output": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<OrderCreateResponse xmlns=\"http://api.example.com/schema/checkout/1.0\">\n   <ResponseStatus>Success</ResponseStatus>\n   <ResponseDescription>CustomerOrderId = 0005410600539 , OrderUUID = 57c27a87-2f2e-41d1-bc20-afef511b91aa</ResponseDescription>\n</OrderCreateResponse>"
      }
    ],
    "identifier": 30463264
  },
  {
    "context": [
      "And would like to convert it into this CSV format with jq:\r\n\r\n    unique,time,id,x,y,z\r\n    1924,\"2015-01-25T00:00:01.683\",99,1,2,4\r\n    1924,\"2015-01-25T00:00:01.683\",100,8,9,9\r\n\r\n(and so on)",
      "First step would be to flatten down the results to rows.\r\n\r\n    [{ unique } + (.coordinates[] | { time } + .xyz[])]\r\n\r\nThis would yield an array of objects per row:",
      "Then it's just a matter of converting this to csv rows.\r\n\r\n    [\"unique\",\"time\",\"id\",\"x\",\"y\",\"z\"] as $fields | $fields, (.[] | [.[$fields[]]]) | @csv"
    ],
    "utterance": "Output all rows as CSV with columns unique, time, id, x, y, z, with one row for every xyz entry in every coordinates entry, and include the correct unique and time per row.",
    "expressions": [
      "[{ unique } + (.coordinates[] | { time } + .xyz[])] | [\"unique\",\"time\",\"id\",\"x\",\"y\",\"z\"] as $fields | $fields, (.[] | [.[$fields[]]]) | @csv"
    ],
    "data": [
      {
        "input": {
          "unique": 1924,
          "coordinates": [
            {
              "time": "2015-01-25T00:00:01.683",
              "xyz": [
                {
                  "z": 4,
                  "y": 2,
                  "x": 1,
                  "id": 99
                },
                {
                  "z": 9,
                  "y": 9,
                  "x": 8,
                  "id": 100
                },
                {
                  "z": 9,
                  "y": 6,
                  "x": 10,
                  "id": 101
                }
              ]
            },
            {
              "time": "2015-01-25T00:00:02.790",
              "xyz": [
                {
                  "z": 0,
                  "y": 3,
                  "x": 7,
                  "id": 99
                },
                {
                  "z": 4,
                  "y": 6,
                  "x": 2,
                  "id": 100
                },
                {
                  "z": 2,
                  "y": 9,
                  "x": 51,
                  "id": 101
                }
              ]
            }
          ]
        },
        "output": "unique,time,id,x,y,z\n1924,\"2015-01-25T00:00:01.683\",99,1,2,4\n1924,\"2015-01-25T00:00:01.683\",100,8,9,9\n1924,\"2015-01-25T00:00:01.683\",101,10,6,9\n1924,\"2015-01-25T00:00:02.790\",99,7,3,0\n1924,\"2015-01-25T00:00:02.790\",100,2,6,4\n1924,\"2015-01-25T00:00:02.790\",101,51,9,2"
      }
    ],
    "identifier": 30379445
  },
  {
    "context": [
      "But all that does is pass the JSON in as a string.  Without quotes `\"` around the `$FINAL_JSON` I get this error:",
      "I'm sticking with `--argfile` here since it parses the file's contents as JSON; using `--arg` wouldn't have that effect.",
      "However, you can also use `--arg`, and apply the `fromjson` filter to parse as JSON:",
      "payload=$(jq -n --arg attach \"$final_json\" '{ \"attachments\":$attach|fromjson }')"
    ],
    "utterance": "Construct a new object with an 'attachments' field set to the parsed contents of a bash variable containing valid JSON.",
    "expressions": [
      "jq -n --argfile attach <(printf '%s\\n' \"$final_json\") '{ \"attachments\":$attach }'",
      "jq -n --arg attach \"$final_json\" '{ \"attachments\":$attach|fromjson }'"
    ],
    "identifier": 30599619
  },
  {
    "context": [
      "Given this file\n\n    {\n      \"[global]\": {\n        \"current\": \"\",\n        \"hash\": \"\"\n      }\n    }\n\nI would like this output:\n\n    {\n      \"[global]\": {\n        \"current\": \"alpha\",\n        \"hash\": \"bravo\"\n      }\n    }",
      "jq '.\"[global]\".current=\"alpha\" | .\"[global]\".hash=\"bravo\"' example.json",
      "However I would rather not have to repeat the `.\"[global]\"` part.",
      ".\"[global]\" *= { current: \"alpha\", hash: \"bravo\" }",
      ".\"[global]\" += {current: \"alpha\", hash:\"bravo\"}"
    ],
    "utterance": "Update the keys 'current' and 'hash' inside the '[global]' object to the values 'alpha' and 'bravo'.",
    "expressions": [
      ".\"[global]\" *= { current: \"alpha\", hash: \"bravo\" }",
      ".\"[global]\" += {current: \"alpha\", hash:\"bravo\"}"
    ],
    "data": [
      {
        "input": {
          "[global]": {
            "current": "",
            "hash": ""
          }
        },
        "output": {
          "[global]": {
            "current": "alpha",
            "hash": "bravo"
          }
        }
      }
    ],
    "identifier": 30564976
  },
  {
    "context": [
      "I have a series of `[timestamp, count]` pairs in an array and a want to compute the cumulative sum at each timestamp using `jq`.",
      "Here a sample data set:\r\n\r\n    [\r\n      [1431047957699, 1],\r\n      [1431047958269, 1],\r\n      [1431047958901, 1],\r\n      [1431047959147, -1],\r\n      [1431047960164, 1]\r\n    ]\r\n\r\nAnd the expected result:\r\n\r\n    [1431047957699, 1],\r\n    [1431047958269, 2],\r\n    [1431047958901, 3],\r\n    [1431047959147, 2],\r\n    [1431047960164, 3]",
      "Take a functional approach to this and create an update function that will create the updated values with the cumulative sum.",
      "def accumulate(acc):\r\n    select(length > 0) |\r\n    (.[0][1] + acc) as $next |\r\n    (.[0] | .[1] = $next), (.[1:] | accumulate($next))\r\n;\r\n[accumulate(0)]",
      "The following is quite general (e.g. it can be used with an array of objects):",
      "def accumulate(f):\r\n  reduce .[1:][] as $row\r\n    ([.[0]];\r\n     . as $x\r\n     | $x + [ $row | (f = ($x | .[length-1] | f) + ($row|f)  ) ] );\r\n\naccumulate(.[1])",
      "If you are using a sufficiently recent version of jq, then \"$x | .[length-1]\" can be simplified to \"$x[-1]\".",
      "Solution using foreach",
      "def accumulates(f):\r\n  foreach .[] as $row\r\n    (0;\r\n     . + ($row | f) ;\r\n     . as $x | $row | (f = $x));",
      "Usage: \n\nFor a stream: `accumulates(.[0])`\n\nFor an array: `[accumulates(.[0])`"
    ],
    "utterance": "Compute the running total of the count values at each timestamp in an array of [timestamp, count] pairs, so that each pair's count is replaced by the cumulative sum up to that point.",
    "expressions": [
      "def accumulate(acc): select(length > 0) | (.[0][1] + acc) as $next | (.[0] | .[1] = $next), (.[1:] | accumulate($next)); [accumulate(0)]",
      "def accumulate(f): reduce .[1:][] as $row ([.[0]]; . as $x | $x + [ $row | (f = ($x | .[length-1] | f) + ($row|f) ) ] ); accumulate(.[1])",
      "def accumulates(f): foreach .[] as $row (0; . + ($row | f) ; . as $x | $row | (f = $x)); [accumulates(.[0])]"
    ],
    "data": [
      {
        "input": [
          [
            1431047957699,
            1
          ],
          [
            1431047958269,
            1
          ],
          [
            1431047958901,
            1
          ],
          [
            1431047959147,
            -1
          ],
          [
            1431047960164,
            1
          ]
        ],
        "output": [
          [
            1431047957699,
            1
          ],
          [
            1431047958269,
            2
          ],
          [
            1431047958901,
            3
          ],
          [
            1431047959147,
            2
          ],
          [
            1431047960164,
            3
          ]
        ]
      }
    ],
    "identifier": 30172253
  },
  {
    "context": [
      "I am trying to add a accumulating count string to each object in a stream with `jq` to get the following output",
      "{\"count\":\"Num_000\"}\n{\"count\":\"Num_001\"}\n{\"count\":\"Num_002\"}\n{\"count\":\"Num_003\"}\n{\"count\":\"Num_004\"}\n{\"count\":\"Num_005\"}\n{\"count\":\"Num_006\"}\n{\"count\":\"Num_007\"}\n{\"count\":\"Num_008\"}\n{\"count\":\"Num_009\"}",
      "Using a recent version of jq (i.e. with foreach and inputs), e.g jq 1.5rc1, the task can be performed efficiently and quite elegantly along the following lines:",
      "yes 1 | head -n10 |\\\n jq -c -n 'foreach inputs as $line (0; .+1; {\"count\": \"Num_\\(.)\"})'"
    ],
    "utterance": "Enumerate each object in a stream and add a 'count' field formatted as Num_###, with zero-padded numbers starting from 000.",
    "expressions": [
      "foreach inputs as $line (0; .+1; {\"count\": (\"Num_\" + (printf \"%03d\" .))})",
      "foreach inputs as $line (0; .+1; {\"count\": \"Num_\\(.)\"})"
    ],
    "data": [
      {
        "input": [
          {},
          {},
          {},
          {},
          {},
          {},
          {},
          {},
          {},
          {}
        ],
        "output": [
          {
            "count": "Num_000"
          },
          {
            "count": "Num_001"
          },
          {
            "count": "Num_002"
          },
          {
            "count": "Num_003"
          },
          {
            "count": "Num_004"
          },
          {
            "count": "Num_005"
          },
          {
            "count": "Num_006"
          },
          {
            "count": "Num_007"
          },
          {
            "count": "Num_008"
          },
          {
            "count": "Num_009"
          }
        ]
      }
    ],
    "identifier": 30584256
  },
  {
    "context": [
      "I want to pass the entity key as variable , tried the below ones ,but none seems to work-",
      "When trying to use extra parameters in your filters, use the `--arg` option to pass them in.  Don&#39;t rely on the shell to insert it into your filter string, keep that separate.",
      "jq --arg key \"$enkey\" '.[] |\n  .environmentStatuses[].deploymentResult |\n  select(.key.entityKey.key == $key) |\n  .lifeCycleState' ~/Desktop/results.json"
    ],
    "utterance": "Filter for deploymentResult objects where .key.entityKey.key matches a provided variable and return .lifeCycleState.",
    "expressions": [
      "jq --arg key \"$enkey\" '.[] | .environmentStatuses[].deploymentResult | select(.key.entityKey.key == $key) | .lifeCycleState' ~/Desktop/results.json"
    ],
    "identifier": 30769667
  },
  {
    "context": [
      "Using the JSON input above, how do you use jq to produce the following output?:",
      "{\r\n  \"OwnerId\": \"000000000000\",\r\n  \"InstanceId\": \"i-v33333333\",\r\n  \"ImageId\": \"ami-44444444\",\r\n  \"PrivateIpAddress\": \"10.0.0.0\",\r\n  \"Platform\": \"windows\"\r\n}",
      "You can use a variable to store the `OwnerID` as in:",
      ".Reservations[] | .OwnerId as $OwnerId | ( .Instances[] | { \"OwnerId\": $OwnerId, InstanceId, ImageId, PrivateIpAddress, Platform} )"
    ],
    "utterance": "Combine properties from parent and nested objects to output a flat object with OwnerId from the parent and InstanceId, ImageId, PrivateIpAddress, and Platform from each entry in the nested array.",
    "expressions": [
      ".Reservations[] | .OwnerId as $OwnerId | ( .Instances[] | { \"OwnerId\": $OwnerId, InstanceId, ImageId, PrivateIpAddress, Platform} )"
    ],
    "data": [
      {
        "input": {
          "Reservations": [
            {
              "OwnerId": "000000000000",
              "ReservationId": "r-22222222",
              "Groups": [],
              "RequesterId": "111111111111",
              "Instances": [
                {
                  "Monitoring": {
                    "State": "enabled"
                  },
                  "PublicDnsName": null,
                  "State": {
                    "Code": 16,
                    "Name": "running"
                  },
                  "EbsOptimized": false,
                  "LaunchTime": "2015-04-10T00:02:02.000Z",
                  "Platform": "windows",
                  "PrivateIpAddress": "10.0.0.0",
                  "ProductCodes": [
                    {
                      "ProductCodeId": "0000000000000000000000000",
                      "ProductCodeType": "marketplace"
                    }
                  ],
                  "VpcId": "vpc-2222222",
                  "StateTransitionReason": null,
                  "InstanceId": "i-v33333333",
                  "ImageId": "ami-44444444",
                  "PrivateDnsName": "ip-10-0-0-0.aws.foobarcloud.com",
                  "KeyName": "bar-servicemesh",
                  "SecurityGroups": [
                    {
                      "GroupName": "bar-wildcard-dns-intranet-InstanceSecurityGroup-VN0DFQ13QCDY",
                      "GroupId": "sg-55555555"
                    }
                  ],
                  "ClientToken": "11111111-2222-3333-4444-555555555555_subnet-66666666_1",
                  "SubnetId": "subnet-66666666",
                  "InstanceType": "t2.medium",
                  "NetworkInterfaces": [
                    {
                      "Status": "in-use",
                      "MacAddress": "00:00:00:00:00:77",
                      "SourceDestCheck": true,
                      "VpcId": "vpc-66666666",
                      "Description": null,
                      "NetworkInterfaceId": "eni-11111111"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": {
          "OwnerId": "000000000000",
          "InstanceId": "i-v33333333",
          "ImageId": "ami-44444444",
          "PrivateIpAddress": "10.0.0.0",
          "Platform": "windows"
        }
      }
    ],
    "identifier": 30601278
  },
  {
    "context": [
      "How do I get output that looks something like this:\r\n\r\n    Test1    Dev1    3.4.25\r\n    Test2    Dev2    3.4.22\r\n",
      ".Collections[] | { InstanceIdentifier, Version } + (.OptionGroups[] | { OptionGroupName })",
      "[ .OptionGroupName, .InstanceIdentifier, .Version ] | join(\"\\t\")"
    ],
    "utterance": "Produce output with OptionGroupName, InstanceIdentifier, and Version as tab-separated values in each row.",
    "expressions": [
      ".Collections[] | { InstanceIdentifier, Version } + (.OptionGroups[] | { OptionGroupName }) | [ .OptionGroupName, .InstanceIdentifier, .Version ] | join(\"\\t\")"
    ],
    "data": [
      {
        "input": {
          "Collections": [
            {
              "OptionGroups": [
                {
                  "OptionGroupName": "Test1",
                  "Status": "in-sync"
                }
              ],
              "Version": "3.4.25",
              "InstanceIdentifier": "Dev1"
            },
            {
              "OptionGroups": [
                {
                  "OptionGroupName": "Test2",
                  "Status": "in-sync"
                }
              ],
              "Version": "3.4.22",
              "InstanceIdentifier": "Dev2"
            }
          ]
        },
        "output": [
          "Test1\tDev1\t3.4.25",
          "Test2\tDev2\t3.4.22"
        ]
      }
    ],
    "identifier": 30768196
  },
  {
    "context": [
      "How can I use `jq` to convert the JSON to:",
      "With a help of a function, you can do this recursively.",
      "def update_dependencies:\n    { dep: \"\\(.organization):\\(.name):\\(.version)\" }\n    +\n    with_entries(select(.key == \"dependencies\") | .value |= map(update_dependencies))\n    ;\n.projects |= map(\n    .configurations |= map(\n        .dependencies |= map(update_dependencies)\n    )\n)"
    ],
    "utterance": "Combine the organization, name, and version of each dependency into a single string field called 'dep', recursively replacing all dependency objects with this format while retaining nested dependencies.",
    "expressions": [
      "def update_dependencies:\n    { dep: \"\\(.organization):\\(.name):\\(.version)\" }\n    +\n    with_entries(select(.key == \"dependencies\") | .value |= map(update_dependencies))\n    ;\n.projects |= map(\n    .configurations |= map(\n        .dependencies |= map(update_dependencies)\n    )\n)"
    ],
    "data": [
      {
        "input": {
          "name": "my-project",
          "projects": [
            {
              "project": "core",
              "configurations": [
                {
                  "configuration": "compile",
                  "dependencies": [
                    {
                      "organization": "a11",
                      "name": "b11",
                      "version": "1.1"
                    },
                    {
                      "organization": "a22",
                      "name": "b22",
                      "version": "2.2",
                      "dependencies": [
                        {
                          "organization": "a33",
                          "name": "b33",
                          "version": "3.3"
                        }
                      ]
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": {
          "name": "my-project",
          "projects": [
            {
              "project": "core",
              "configurations": [
                {
                  "configuration": "compile",
                  "dependencies": [
                    {
                      "dep": "a11:b11:1.1"
                    },
                    {
                      "dep": "a22:b22:2.2",
                      "dependencies": [
                        {
                          "dep": "a33:b33:3.3"
                        }
                      ]
                    }
                  ]
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 30932872
  },
  {
    "context": [
      "which I would like to transform to\n\n    {\"2015-06-06\": {\"Trial + Confirm\": 1, \"Follow Up\": 4, \"Hold\": 3, \"Trial\": 2}}",
      "This should work:\n\n    group_by(.date) | map({\n        key: .[0].date,\n        value: map({\n            key: .trial_status,\n            value: .count\n        }) | from_entries\n    }) | from_entries",
      "You just need to generate the key/value pairs that will make up the object.",
      "consider using `reduce` like so:\n`\n  reduce .[] as $o\n    ({}; . + {($o.date): (.[$o.date] + {($o.trial_status): $o.count} )})\n`",
      "Thanks to jq's null semantics, this can be simplified and shortened to:\n`\n  reduce .[] as $o\n    ({}; .[$o.date] += { ($o.trial_status): $o.count } )\n`",
      "Here is a solution using [reduce], [destructuring variable binding] and [setpath]\n\n    reduce .[] as {count:$c, trial_status:$s, date:$d} (\n      {}\n    ; setpath([$d, $s]; $c)\n    )",
      "produces\n\n    {\n      \"2015-06-06\": {\n        \"Follow up\": 4,\n        \"Hold\": 3,\n        \"Trial\": 2,\n        \"Trial + Confirm\": 1\n      }\n    }"
    ],
    "utterance": "Transform an array of objects with 'date', 'trial_status', and 'count' fields into a nested object keyed by date, where each date maps to an object of trial_status to count.",
    "expressions": [
      "group_by(.date) | map({ key: .[0].date, value: map({key: .trial_status, value: .count}) | from_entries }) | from_entries",
      "group_by(.date) | map({ (.[0].date): map({ (.trial_status): .count }) | add }) | add",
      "reduce .[] as $o ({}; . + {($o.date): (.[$o.date] + {($o.trial_status): $o.count} )})",
      "reduce .[] as $o ({}; .[$o.date] += { ($o.trial_status): $o.count })",
      "reduce .[] as {count:$c, trial_status:$s, date:$d} ({}; setpath([$d, $s]; $c))"
    ],
    "data": [
      {
        "input": [
          {
            "count": 4,
            "trial_status": "Follow up",
            "date": "2015-06-06"
          },
          {
            "count": 3,
            "trial_status": "Hold",
            "date": "2015-06-06"
          },
          {
            "count": 2,
            "trial_status": "Trial",
            "date": "2015-06-06"
          },
          {
            "count": 1,
            "trial_status": "Trial + Confirm",
            "date": "2015-06-06"
          }
        ],
        "output": {
          "2015-06-06": {
            "Follow up": 4,
            "Hold": 3,
            "Trial": 2,
            "Trial + Confirm": 1
          }
        }
      }
    ],
    "identifier": 30691088
  },
  {
    "context": [
      "Here\u0019s a JSON sample--how would I use `jq` to set `\"local\": false`, while preserving the rest of the JSON?",
      "Since you are setting a property to a constant value, use the `=` operator.",
      ".shipping.local = false",
      "Just note that when setting a value to a property, it doesn't necessarily have to exist. You can add new values easily this way.",
      ".shipping.local = false | .shipping.canada = false | .shipping.mexico = true"
    ],
    "utterance": "Set the value of the field shipping.local to false while preserving all other data.",
    "expressions": [
      ".shipping.local = false"
    ],
    "data": [
      {
        "input": {
          "shipping": {
            "local": true,
            "us": true,
            "us_rate": {
              "amount": "0.00",
              "currency": "USD",
              "symbol": "$"
            }
          }
        },
        "output": {
          "shipping": {
            "local": false,
            "us": true,
            "us_rate": {
              "amount": "0.00",
              "currency": "USD",
              "symbol": "$"
            }
          }
        }
      }
    ],
    "identifier": 31034746
  },
  {
    "context": [
      "cat 1.txt | jq '.Addresses | .[] | select (.PublicIp==$ip) |    .InstanceId'",
      "You're using single quotes around your jq program, which is causing the shell variable to not be interpolated.",
      "jq provides a command-line argument to this effect, `--arg`, intended to lift shell variables into jq variables.",
      "Your jq invocation would therefore look like this:",
      "`jq --arg ip \"$ip\" '.Addresses[] | select(.PublicIp == $ip) | .InstanceId'`",
      "the right format is:\n    \n    cat 1.txt | jq \".Addresses | .[] | select(.PublicIp==\\\"$ip\\\") | .InstanceId\""
    ],
    "utterance": "For each IP in a list, find the corresponding InstanceId where PublicIp matches the current value.",
    "expressions": [
      "jq --arg ip \"$ip\" '.Addresses[] | select(.PublicIp == $ip) | .InstanceId'",
      "jq \".Addresses | .[] | select(.PublicIp==\\\"$ip\\\") | .InstanceId\""
    ],
    "identifier": 31103748
  },
  {
    "context": [
      "$jq -n --arg number 3000 '{\"number\":$number}'",
      "{ \"number\": \"3000\" }",
      "I would like to be able to generate something as following :",
      "{ \"number\": 3000 }",
      "jq -n --argfile number <(printf '%d' 3000) '{\"number\":$number}'",
      "jq -n --arg number 3000 '{\"number\":$number|fromjson}'",
      "jq -n --arg number 300 '{\"number\": $number|tonumber}'",
      "jq -n --argjson number 300 '{\"number\": $number}'",
      "jq -n --arg number 300 '{$number} | .number |= tonumber'"
    ],
    "utterance": "Create an object with a property 'number' set to the numeric value 3000, passing 3000 as a variable from the command line.",
    "expressions": [
      "--arg number 3000 '{\"number\":$number|fromjson}'",
      "--arg number 3000 '{\"number\":$number|tonumber}'",
      "--argjson number 3000 '{\"number\":$number}'",
      "--arg number 3000 '{$number} | .number |= tonumber'",
      "--argfile number <(printf '%d' 3000) '{\"number\":$number}'"
    ],
    "data": [
      {
        "input": null,
        "output": {
          "number": 3000
        }
      }
    ],
    "identifier": 30991616
  },
  {
    "context": [
      "I have a JSON array of objects with groups and subgroups that looks like this:",
      "I'd like to convert it to a nested structure:\r\n\r\n    [ { type: group, name: Elevation, Items: [ ... ] } ]",
      "This did the job:",
      "group_by(.\"Group name\")|\r\n    map({\r\n      \"type\": \"group\", \r\n      \"name\": .[0].\"Group name\", \r\n      \"items\": (subgroups2|map(del(.\"Group name\")))\r\n    })",
      "By parameterizing your grouping function, you could build up your trees in a reusable fashion.\r\n\r\n    def regroup(keyfilter; itemfilter):\r\n        group_by(keyfilter) | map({\r\n            type: \"group\",\r\n            name: (.[0] | keyfilter),\r\n            items: itemfilter\r\n        })\r\n        ;\r\n    regroup(.\"Group name\";\r\n        regroup(.Subgroup;\r\n            map({ name })\r\n        )\r\n    )",
      "This yields the following results:\r\n\r\n    [\r\n      {\r\n        \"type\": \"group\",\r\n        \"name\": \"Elevation\",\r\n        \"items\": [\r\n          {\r\n            \"type\": \"group\",\r\n            \"name\": \"Contours\",\r\n            \"items\": [\r\n              { \"name\": \"Contours - Labels\" },\r\n              { \"name\": \"Contours\" }\r\n            ]\r\n          },\r\n          {\r\n            \"type\": \"group\",\r\n            \"name\": \"Cuttings\",\r\n            \"items\": [\r\n              { \"name\": \"Cuttings\" }\r\n            ]\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        \"type\": \"group\",\r\n        \"name\": \"Framework\",\r\n        \"items\": [\r\n          {\r\n            \"type\": \"group\",\r\n            \"name\": \"Indigenous Reserves\",\r\n            \"items\": [\r\n              { \"name\": \"Reserves\" }\r\n            ]\r\n          },\r\n          {\r\n            \"type\": \"group\",\r\n            \"name\": \"Land Borders\",\r\n            \"items\": [\r\n              { \"name\": \"Mainland\" }\r\n            ]\r\n          },\r\n          {\r\n            \"type\": \"group\",\r\n            \"name\": \"Reserves\",\r\n            \"items\": [\r\n              { \"name\": \"Reserves\" }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    ]"
    ],
    "utterance": "Convert a flat array of objects with 'Group name', 'Subgroup', and 'name' fields into a nested structure grouping by group, then subgroup, and listing names as items.",
    "expressions": [
      "def subgroups:\n    group_by(.\"Subgroup\")|\n    map({\n      \"type\": \"group\", \n      \"name\": .[0].\"Subgroup\", \n      \"items\": (map(del(.Subgroup)))\n    });\n    \ngroup_by(.\"Group name\")|\n    map({\n      \"type\": \"group\", \n      \"name\": .[0].\"Group name\", \n      \"items\": (subgroups|map(del(.\"Group name\")))\n    })",
      "def regroup(keyfilter; itemfilter):\n    group_by(keyfilter) | map({\n        type: \"group\",\n        name: (.[0] | keyfilter),\n        items: itemfilter\n    })\n    ;\nregroup(.\"Group name\";\n    regroup(.Subgroup;\n        map({ name })\n    )\n)"
    ],
    "data": [
      {
        "input": [
          {
            "Group name": "Elevation",
            "Subgroup": "Contours",
            "name": "Contours - Labels"
          },
          {
            "Group name": "Elevation",
            "Subgroup": "Contours",
            "name": "Contours"
          },
          {
            "Group name": "Elevation",
            "Subgroup": "Cuttings",
            "name": "Cuttings"
          },
          {
            "Group name": "Framework",
            "Subgroup": "Reserves",
            "name": "Reserves"
          },
          {
            "Group name": "Framework",
            "Subgroup": "Indigenous Reserves",
            "name": "Reserves"
          },
          {
            "Group name": "Framework",
            "Subgroup": "Land Borders",
            "name": "Mainland"
          }
        ],
        "output": [
          {
            "type": "group",
            "name": "Elevation",
            "items": [
              {
                "type": "group",
                "name": "Contours",
                "items": [
                  {
                    "name": "Contours - Labels"
                  },
                  {
                    "name": "Contours"
                  }
                ]
              },
              {
                "type": "group",
                "name": "Cuttings",
                "items": [
                  {
                    "name": "Cuttings"
                  }
                ]
              }
            ]
          },
          {
            "type": "group",
            "name": "Framework",
            "items": [
              {
                "type": "group",
                "name": "Indigenous Reserves",
                "items": [
                  {
                    "name": "Reserves"
                  }
                ]
              },
              {
                "type": "group",
                "name": "Land Borders",
                "items": [
                  {
                    "name": "Mainland"
                  }
                ]
              },
              {
                "type": "group",
                "name": "Reserves",
                "items": [
                  {
                    "name": "Reserves"
                  }
                ]
              }
            ]
          }
        ]
      }
    ],
    "identifier": 30565569
  },
  {
    "context": [
      "I am trying to increment a version field. Input is\n\n    {\"version\":1}\n\nOutput should be\n\n    {\"v\":2}",
      "When I do\n\n    echo '{\"version\":1}'|jq '{\"v\":.version+1}'\n\nI get\n\n    error: syntax error, unexpected '+'",
      "Try\n\necho '{\"version\":1}' | jq '{\"v\":(.version+1)}'\n\nThis seems to work on the [playground of jq][1]."
    ],
    "utterance": "Return an object with key v whose value is the version field incremented by 1.",
    "expressions": [
      "{ \"v\": (.version+1) }"
    ],
    "data": [
      {
        "input": {
          "version": 1
        },
        "output": {
          "v": 2
        }
      }
    ],
    "identifier": 31161831
  },
  {
    "context": [
      "1)\tConvert JSON file to Flat Structure using JQ utility. (http://stedolan.github.io/jq/)",
      "2)\tStore the output of JQ into Flat File",
      "3)\tLoad flat file into SQL Table using BCP",
      "Is it possible to skip Step 2) and load output of JQ directly into SQL Server table using BCP?",
      "JQCommand | BCP Database.Schema.Table in -T -S \"Server\" -w -t ~ -r \\n",
      "For Windows, there is a special file called `con` that could be used to capture stdin (similar to `/dev/stdin`).  Try using that.",
      "JQCommand | BCP Database.Schema.Table in con -T -S \"Server\" -w -t ~ -r \\n"
    ],
    "utterance": "Load the output directly into SQL Server Table using BCP without creating an intermediate file.",
    "expressions": [
      "JQCommand | BCP Database.Schema.Table in con -T -S \"Server\" -w -t ~ -r \\n"
    ],
    "identifier": 31294151
  },
  {
    "context": [
      "I want to get the id of the corresponding subnet that fit the variable subnet.",
      "subnet=\"192.168.112\"",
      "A sample script would look like:\n    echo \"${json}\" | jq --arg subnet \"$subnet\" '.subnets[] | select(.cidr | startswith($subnet)).id'"
    ],
    "utterance": "Select the id of the subnet where the cidr string starts with the value 192.168.112.",
    "expressions": [
      ".subnets[] | select(.cidr | startswith($subnet)).id"
    ],
    "data": [
      {
        "input": {
          "subnets": [
            {
              "cidr": "192.168.112.0/24",
              "id": "123"
            },
            {
              "cidr": "10.120.47.0/24",
              "id": "456"
            }
          ]
        },
        "output": "123"
      }
    ],
    "identifier": 31438087
  },
  {
    "context": [
      "I want to use jq tool to change the value of weight from 200 to 195 where name is \"mike\".",
      ".person |= map(\n    if .name == \"mike\"\n        then .weight = \"195\"\n        else .\n    end)",
      "(.person[] | select(.name == \"mike\")).weight = \"195\""
    ],
    "utterance": "Change the value of weight to 195 for the person whose name is mike.",
    "expressions": [
      ".person |= map(if .name == \"mike\" then .weight = \"195\" else . end)",
      "(.person[] | select(.name == \"mike\")).weight = \"195\""
    ],
    "data": [
      {
        "input": {
          "person": [
            {
              "name": "sam",
              "age": "40",
              "weight": "180",
              "height": "6"
            },
            {
              "name": "peter",
              "age": "41",
              "weight": "180",
              "height": "6.1"
            },
            {
              "name": "mike",
              "age": "40",
              "weight": "200",
              "height": "5.9"
            },
            {
              "name": "ethan",
              "age": "41",
              "weight": "190",
              "height": "6"
            }
          ]
        },
        "output": {
          "person": [
            {
              "name": "sam",
              "age": "40",
              "weight": "180",
              "height": "6"
            },
            {
              "name": "peter",
              "age": "41",
              "weight": "180",
              "height": "6.1"
            },
            {
              "name": "mike",
              "age": "40",
              "weight": "195",
              "height": "5.9"
            },
            {
              "name": "ethan",
              "age": "41",
              "weight": "190",
              "height": "6"
            }
          ]
        }
      }
    ],
    "identifier": 31149012
  },
  {
    "context": [
      "result=$(jq --raw-output '.some | .filters // \"\"')",
      "if [[ $result ]]; then",
      "foo",
      "else",
      "bar",
      "fi",
      "You can use the `-e` flag that will make `jq` return exit code `0` if the last output value was neither `false` or `null` so then your logic may become:",
      "result=$(jq -e -r '.some | .filters') && foo || bar"
    ],
    "utterance": "Run a command if the evaluated field exists and is not null or false, otherwise run a different command.",
    "expressions": [
      ".some | .filters // \"\"",
      "-e -r '.some | .filters'"
    ],
    "identifier": 31485906
  },
  {
    "context": [
      "echo '\"foo foo\"' | jq 'match(\"(foo)\"; \"g\")'",
      "I want my final output for this example to be:\n\n    \"foo,foo\"",
      "The following script takes the string value from each of the separate objects with `.string`, wraps them in an array `[...]` and then joins the members of the array with commas using `join`.",
      "`echo '\"foo foo\"' | jq '[match(\"foo\"; \"g\").string] | join(\",\")'`"
    ],
    "utterance": "Return all matches of \"foo\" in the input string, joined as a single comma-separated string.",
    "expressions": [
      "[match(\"foo\"; \"g\").string] | join(\",\")"
    ],
    "data": [
      {
        "input": "\"foo foo\"",
        "output": "foo,foo"
      }
    ],
    "identifier": 31537719
  },
  {
    "context": [
      "What I really want:\r\n\r\n    {\r\n      \"DimName\": \"DBInstanceIdentifier\",\r\n      \"DimValue\": \"db-master02\",\r\n      \"AlarmActions\": \"this is causing me trouble\",\r\n      \"EvaluationPeriods\": 2,\r\n      \"Threshold\": 0,\r\n      \"MetricName\": \"ReplicaLag\"\r\n    }\r\nI want to show the value for \"AlarmActions\" without an array.",
      "Use:\r\n\r\n    cat $JSON_FILE |\r\n    jq -r '.MetricAlarms[] |\r\n          { MetricName,\r\n            Threshold,\r\n            EvaluationPeriods,\r\n            \"AlarmActions\" : .AlarmActions[0]\r\n          } +\r\n          ( .Dimensions[] | { DimName: .Name, DimValue: .Value } )\r\n    '\r\n\ni.e. don't use  shortcut syntax for the `AlarmActions` element."
    ],
    "utterance": "Output the first string value of the 'AlarmActions' array as a plain value (not an array) in the result objects.",
    "expressions": [
      ".MetricAlarms[] | { MetricName, Threshold, EvaluationPeriods, \"AlarmActions\": .AlarmActions[0] } + ( .Dimensions[] | { DimName: .Name, DimValue: .Value } )"
    ],
    "data": [
      {
        "input": {
          "MetricAlarms": [
            {
              "EvaluationPeriods": 2,
              "AlarmActions": [
                "this is causing me trouble"
              ],
              "Threshold": 0.0,
              "Dimensions": [
                {
                  "Name": "DBInstanceIdentifier",
                  "Value": "db-master02"
                }
              ],
              "MetricName": "ReplicaLag"
            }
          ]
        },
        "output": {
          "DimName": "DBInstanceIdentifier",
          "DimValue": "db-master02",
          "AlarmActions": "this is causing me trouble",
          "EvaluationPeriods": 2,
          "Threshold": 0,
          "MetricName": "ReplicaLag"
        }
      }
    ],
    "identifier": 31462702
  },
  {
    "context": [
      "I need to get a csv (Time, Data.key, Lat, Lng, Qline)",
      "Example output of csv:\r\n\r\n    \"14:16:23\", 101043, 49, 15, 420\r\n    \"14:16:23\", 101044, 48, 15, 421",
      "Try this:\r\n\r\n    { Time } + (.Data | to_entries[] | { key: .key | tonumber } + .value)\r\n        | [ .Time, .key, .Lat, .Lng, .Qline ]\r\n        | @csv",
      "Here\u0019s another solution that doesn't involve the +'s.\r\n\r\n    {Time, Data: (.Data | to_entries)[]} \r\n    | [.Time, (.Data.key | tonumber), .Data.value.Lat, .Data.value.Lng, .Data.value.Qline] \r\n    | @csv",
      "jq -M -r '(.Data|keys[]) as $k | {Time,k:$k}+.Data[$k] | [.[]] | @csv' data.json"
    ],
    "utterance": "Extract rows with Time, each Data object's key as number, Lat, Lng, and Qline as CSV outputs",
    "expressions": [
      "{ Time } + (.Data | to_entries[] | { key: .key | tonumber } + .value) | [ .Time, .key, .Lat, .Lng, .Qline ] | @csv",
      "{Time, Data: (.Data | to_entries)[]} | [.Time, (.Data.key | tonumber), .Data.value.Lat, .Data.value.Lng, .Data.value.Qline] | @csv",
      "(.Data|keys[]) as $k | {Time,k:$k}+.Data[$k] | [.[]] | @csv"
    ],
    "data": [
      {
        "input": {
          "Time": "14:16:23",
          "Data": {
            "101043": {
              "Lat": 49,
              "Lng": 15,
              "Qline": 420
            },
            "101044": {
              "Lat": 48,
              "Lng": 15,
              "Qline": 421
            }
          }
        },
        "output": [
          "\"14:16:23\",101043,49,15,420",
          "\"14:16:23\",101044,48,15,421"
        ]
      }
    ],
    "identifier": 31321124
  },
  {
    "context": [
      "I\u2019d like to get the value of \"item1\", only when \"item2\" has a specific value.",
      "Let's say if item2 equals \"bbb\", then all I want to get back is \"value456\".",
      "An easier solution is available thanks to the magic powers of the recurse operator, `..`:\n\n`jq -r '.[] | select(.. | .item2? == \"bbb\").item1'`",
      "If you find the magic of .. too powerful for your purposes, the following may be useful.  It restricts the search for the \"item2\" key.\n\n    def some(condition): reduce .[] as $x\n     (false; if . then . else $x|condition end);\n\n    .[]\n    | to_entries\n    | select( some( .value | (type == \"array\") and some(.item2 == \"bbb\")) )\n    | from_entries\n    | .item1",
      "Here is a solution which uses **tostream** and **getpath**\n\n    foreach (tostream|select(length==2)) as [$p,$v] (.;.;\n      if $p[-1] == \"item2\" and $v == \"bbb\" then getpath($p[:-3]).item1 else empty end\n    )"
    ],
    "utterance": "Extract the value of item1 from array elements where a nested item2 equals \"bbb\".",
    "expressions": [
      ".[] | select(.. | .item2? == \"bbb\").item1",
      "def some(condition): reduce .[] as $x (false; if . then . else $x|condition end); .[] | to_entries | select( some( .value | (type == \"array\") and some(.item2 == \"bbb\")) ) | from_entries | .item1",
      "(tostream | select(length==2)) as [$p,$v] | if $p[-1] == \"item2\" and $v == \"bbb\" then getpath($p[:-3]).item1 else empty end"
    ],
    "data": [
      {
        "input": [
          {
            "item1": "value123",
            "array0": [
              {
                "item2": "aaa"
              }
            ]
          },
          {
            "item1": "value456",
            "array1": [
              {
                "item2": "bbb"
              }
            ]
          },
          {
            "item1": "value789",
            "array2": [
              {
                "item2": "ccc"
              }
            ]
          }
        ],
        "output": "value456"
      }
    ],
    "identifier": 31540337
  },
  {
    "context": [
      "I only know the name of the nested object (here \"nested\"), the name of the property I'd like to add (here \"freshly\") and its value.",
      "jq '.nested=(.nested + {\"freshly\": \"added\"})'",
      ".nested.freshly = \"added\"",
      ".nested += {freshly: \"added\"}"
    ],
    "utterance": "Add the property 'freshly' with value 'added' to the object inside the 'nested' key, while preserving all other data.",
    "expressions": [
      ".nested = (.nested + {\"freshly\": \"added\"})",
      ".nested.freshly = \"added\"",
      ".nested += {freshly: \"added\"}"
    ],
    "data": [
      {
        "input": {
          "some": "property",
          "nested": {
            "hello": "world"
          }
        },
        "output": {
          "some": "property",
          "nested": {
            "hello": "world",
            "freshly": "added"
          }
        }
      }
    ],
    "identifier": 31694182
  },
  {
    "context": [
      "Here is the data its streaming:\r\n\r\n> {\"id\":\"0xDECA34303170235F\",\"timestamp\":946684889.332,\"msgid\":78,\"coordinates\":{\"x\":0.392,\"y\":0.616,\"z\":1.228,\"heading\":0.000,\"pqf\":100},\"meas\":[{\"anchor\":\"0xDECA353034301E99\",\"dist\":1.433,\"dqf\":100},{\"anchor\":\"0xDECA323030901DE2\",\"dist\":8.307,\"dqf\":100},{\"anchor\":\"0xDECA323031300FBF\",\"dist\":6.288,\"dqf\":89},{\"anchor\":\"0xDECA333035101DAA\",\"dist\":10.308,\"dqf\":87}]}\r\n\r\nHere is what I need instead:\r\n\r\n> [\r\n  \"0xDECA34303170235F\",\r\n  946684889.332,\r\n  78,\r\n  0.392,\r\n  0.616,\r\n  1.228,\r\n  0\r\n]\r\n",
      "Here is the filter that I used to get that;\r\n\r\n\t [.id, .timestamp, .msgid, .coordinates[\"x\",\"y\",\"z\",\"heading\"]]\r\n",
      "Any missing data has to be null for the database."
    ],
    "utterance": "Convert each streamed object into an array containing id, timestamp, msgid, x, y, z, and heading fields in order, with nulls for any missing values.",
    "expressions": [
      "[.id, .timestamp, .msgid, .coordinates[\"x\",\"y\",\"z\",\"heading\"]] // null"
    ],
    "data": [
      {
        "input": {
          "id": "0xDECA34303170235F",
          "timestamp": 946684889.332,
          "msgid": 78,
          "coordinates": {
            "x": 0.392,
            "y": 0.616,
            "z": 1.228,
            "heading": 0.0,
            "pqf": 100
          },
          "meas": [
            {
              "anchor": "0xDECA353034301E99",
              "dist": 1.433,
              "dqf": 100
            },
            {
              "anchor": "0xDECA323030901DE2",
              "dist": 8.307,
              "dqf": 100
            },
            {
              "anchor": "0xDECA323031300FBF",
              "dist": 6.288,
              "dqf": 89
            },
            {
              "anchor": "0xDECA333035101DAA",
              "dist": 10.308,
              "dqf": 87
            }
          ]
        },
        "output": [
          "0xDECA34303170235F",
          946684889.332,
          78,
          0.392,
          0.616,
          1.228,
          0
        ]
      }
    ],
    "identifier": 31640639
  },
  {
    "context": [
      "I am using jq to search for specific results in a large file. I do not care for duplicate entries matching this specific condition, and it takes a while to process the whole file. What I would like to do is print some details about the first match and then terminate the jq command on the file to save time.",
      "The file I am parsing contains multiple json objects, one after another. They are not in an array.",
      "You can accomplish it using [`halt`][1] and the [`inputs`][2] builtin:",
      "jq -n 'inputs | if ... then \"something\", halt else ... end'",
      "Will print `\"something\"` and terminate gracefully when the condition matches.",
      "Here is an approach which uses a recent version of `first/1` (currently in  master) ",
      "first(inputs | if .==\"100\" then . else empty end)",
      "To do what is requested is possible using features that were added after the release of jq 1.4.  The following uses *foreach* and *inputs*:"
    ],
    "utterance": "Print details about the first object matching a condition and immediately terminate processing, without processing further objects.",
    "expressions": [
      "jq -n 'inputs | if <condition> then <output>, halt else empty end'",
      "first(inputs | if <condition> then . else empty end)",
      "label $top | foreach inputs as $line (false; if . then break $top else if $line | <condition> then true else false end end; if . then $line else empty end )"
    ],
    "identifier": 31658278
  },
  {
    "context": [
      "I want to get the values from all `alternateName` keys and output it as a TSV file.",
      "But how can I get both: the ones with only have one alternateName-object and the ones where the first `alternateName` key has a dictionary with `alternateName` keys?",
      "{ uri, alternateName: .alternateName | (arrays[].alternateName // .alternateName) }\n    | \"\\(.uri)\\t\\(.alternateName)\"",
      "def vals:\n  if (.|type) == \"object\" then .[] else . end\n;\n\n\"\\(.uri)\\t\\(.alternateName[] | vals)\""
    ],
    "utterance": "Extract all alternateName values for each item, whether alternateName is an array or object, and output each uri and alternateName pair as a TSV line.",
    "expressions": [
      "{ uri, alternateName: .alternateName | (arrays[].alternateName // .alternateName) } | \"\\(.uri)\\t\\(.alternateName)\"",
      "def vals: if (.|type) == \"object\" then .[] else . end; \"\\(.uri)\\t\\(.alternateName[] | vals)\""
    ],
    "data": [
      {
        "input": [
          {
            "a": "Person",
            "alternateName": [
              {
                "alternateName": "1793 Di\u00e9bolt"
              },
              {
                "alternateName": "XXX Di\u00e9bolt"
              }
            ],
            "uri": "http://500051893"
          },
          {
            "a": "Person",
            "alternateName": {
              "alternateName": "A1-53167"
            },
            "uri": "http://vocab.getty.edu/ulan/500116327"
          }
        ],
        "output": [
          "http://500051893\t1793 Di\u00e9bolt",
          "http://500051893\tXXX Di\u00e9bolt",
          "http://vocab.getty.edu/ulan/500116327\tA1-53167"
        ]
      }
    ],
    "identifier": 31688774
  },
  {
    "context": [
      "And I am trying to extract all the fields that are contain \"name test%NUMBER%\"",
      "I want to add digital parameter to .name==test.",
      "With jq 1.5, regular expression support has been added",
      ".property | map(select(.name | test(\"test[0-9]\")))",
      "Then for each of those objects, the `value` appears to be json strings.  You would have to parse those out before you could get anything out of those.",
      ".property | map(\n    select(.name | test(\"test[0-9]\"))\n        | .value |= fromjson\n        | { name } + .value\n    )"
    ],
    "utterance": "Select objects with a name matching 'test' followed by a digit and merge the fields from the parsed value string alongside the name.",
    "expressions": [
      ".property | map(select(.name | test(\"test[0-9]\")))",
      ".property | map(\n    select(.name | test(\"test[0-9]\"))\n    | .value |= fromjson\n    | { name } + .value\n)"
    ],
    "data": [
      {
        "input": {
          "property": [
            {
              "name": "test1",
              "value": "{\"test_type\":\"jsystem\",\"order\":1,\"test_id\":\"test_01\",\"physical_setup_id\":\"prd_01\",\"timeout\":\"20\"}",
              "own": true
            },
            {
              "name": "test2",
              "value": "{\"test_type\":\"jsystem\",\"order\":2,\"test_id\":\"test_02\",\"physical_setup_id\":\"prd_02\",\"timeout\":\"30\"}",
              "own": true
            },
            {
              "name": "pass",
              "value": "{\"test_type\":\"jsystem\",\"order\":3,\"test_id\":\"test_03\",\"physical_setup_id\":\"prd_01\",\"timeout\":\"15\"}",
              "own": true
            }
          ]
        },
        "output": [
          {
            "name": "test1",
            "test_type": "jsystem",
            "order": 1,
            "test_id": "test_01",
            "physical_setup_id": "prd_01",
            "timeout": "20"
          },
          {
            "name": "test2",
            "test_type": "jsystem",
            "order": 2,
            "test_id": "test_02",
            "physical_setup_id": "prd_02",
            "timeout": "30"
          }
        ]
      }
    ],
    "identifier": 31677800
  },
  {
    "context": [
      "I want to convert\n\n    [1,\"a\",2,\"b\",3,\"c\"]\n\nto\n\n    [[1,\"a\"],[2,\"b\"],[3,\"c\"]]",
      "to_entries | group_by(.key/2 | floor) | map(map(.value))",
      ". as $arr | [ range(0; length/2) * 2 | $arr[.:.+2] ]",
      "*[takes(2)]*"
    ],
    "utterance": "Group every two successive elements in an array into pairs, so that [1,\"a\",2,\"b\",3,\"c\"] becomes [[1,\"a\"],[2,\"b\"],[3,\"c\"]].",
    "expressions": [
      "to_entries | group_by(.key/2 | floor) | map(map(.value))",
      ". as $arr | [ range(0; length/2) * 2 | $arr[.:.+2] ]",
      "[takes(2)]",
      "[foreach .[] as $x ( [] ; if length>1 then [] else . end | . + [$x]; if length>1 then  . else empty end )]"
    ],
    "data": [
      {
        "input": [
          1,
          "a",
          2,
          "b",
          3,
          "c"
        ],
        "output": [
          [
            1,
            "a"
          ],
          [
            2,
            "b"
          ],
          [
            3,
            "c"
          ]
        ]
      }
    ],
    "identifier": 31756953
  },
  {
    "context": [
      "I need to convert this output ... into this one using jq: ... Note that I need to delete this key: ***aws:autoscaling:groupName***",
      "$ jq -cs 'from_entries | del(.\"aws:autoscaling:groupName\")'",
      "$ jq -M -c -s 'reduce .[] as $x\n   ([]; . + [{\"key\" : $x.Key, \"value\": $x.Value}])\n | from_entries\n | del(.\"aws:autoscaling:groupName\")'"
    ],
    "utterance": "Convert an array of objects with Key and Value fields to a single object mapping Key to Value, excluding the key aws:autoscaling:groupName.",
    "expressions": [
      "jq -cs 'from_entries | del(.\"aws:autoscaling:groupName\")'",
      "jq -M -c -s 'reduce .[] as $x ([]; . + [{\"key\" : $x.Key, \"value\": $x.Value}]) | from_entries | del(.\"aws:autoscaling:groupName\")'"
    ],
    "data": [
      {
        "input": [
          {
            "Key": "ssh_user",
            "Value": "abc"
          },
          {
            "Key": "ssh_port",
            "Value": "2200"
          },
          {
            "Key": "aws:autoscaling:groupName",
            "Value": "ASG-Api"
          },
          {
            "Key": "Name",
            "Value": "SV-V3-API"
          }
        ],
        "output": {
          "ssh_user": "abc",
          "ssh_port": "2200",
          "Name": "SV-V3-API"
        }
      }
    ],
    "identifier": 31814464
  },
  {
    "context": [
      "I.e. rename 'vertices' to 'nodes' and remove '_type' and '__eid', how can I rename a key nested deeper in the JSON?",
      "map(with_entries( .key |= sub(\"^_+\"; \"\") ))",
      "def ltrimall(str): str as $str | if startswith($str) then ltrimstr($str) | ltrimall(str) else . end;",
      "reduce keys[] as $k ( {}; .[$k | sub(\"^_+\";\"\")] = $n[$k] )"
    ],
    "utterance": "Rename all keys in objects under 'vertices' that start with one or more underscores by removing the leading underscores, and map the array to become the 'nodes' field.",
    "expressions": [
      "{nodes: .vertices | map(with_entries(.key |= sub(\"^_+\"; \"\"))), edges}",
      "def ltrimall(str): str as $str | if startswith($str) then ltrimstr($str) | ltrimall(str) else . end; {nodes: .vertices | map(with_entries(.key |= ltrimall(\"_\"))), edges}",
      ".nodes = .vertices | del(.vertices) | .nodes = [ .nodes[] | . as $n | del(._type, .__eid) | .label = \"metric: \\(.name)\" | reduce keys[] as $k ( {}; .[$k | sub(\"^_+\";\"\")] = $n[$k] ) ]"
    ],
    "data": [
      {
        "input": {
          "vertices": [
            {
              "__cp": "foo",
              "__type": "metric",
              "__eid": "foobar",
              "name": "Undertow Metrics~Sessions Created",
              "_id": 45056,
              "_type": "vertex"
            }
          ],
          "edges": []
        },
        "output": {
          "nodes": [
            {
              "cp": "foo",
              "type": "metric",
              "label": "metric: Undertow Metrics~Sessions Created",
              "name": "Undertow Metrics~Sessions Created",
              "id": 45056
            }
          ],
          "edges": []
        }
      }
    ],
    "identifier": 31756724
  },
  {
    "context": [
      "I want to return a list of IDs where tags contains \"one\" (not partial string match, full element match).",
      "map(select(.tags | index(\"one\")) | .id)",
      "map(select(.tags as $tags | \"one\" | IN($tags[])) | .id)"
    ],
    "utterance": "Return the list of id values for objects whose tags array contains the string \"one\" as a full element.",
    "expressions": [
      "map(select(.tags | index(\"one\")) | .id)",
      "map(select(.tags as $tags | \"one\" | IN($tags[])) | .id)"
    ],
    "data": [
      {
        "input": [
          {
            "id": "0001",
            "tags": [
              "one",
              "two"
            ]
          },
          {
            "id": "0002",
            "tags": [
              "two"
            ]
          }
        ],
        "output": [
          "0001"
        ]
      }
    ],
    "identifier": 31836961
  },
  {
    "context": [
      "How can I transform the JSON input\n\n    {\n    \"Subnets\": [\n        {\n            \"VpcId\": \"vpc-xxx\",\n            \"Tags\": [\n                {\n                    \"Value\": \"staging_subnet_private_a\",\n                    \"Key\": \"Name\"\n                }\n            ],\n            \"SubnetId\": \"subnet-xxx\"\n        },\n        ...\n        ]\n    }\n\nto\n\n    [\n     {\n      \"SubnetId\": \"subnet-xxx\",\n      \"Name\": \"staging_subnet_private_a\"\n     },\n     ...\n    ]\n",
      "I have a working solution using `jq '[.Subnets[] | {SubnetId, Name: .Tags[0] | .Value }]'`, but this relies on the order of Tags (not good).",
      "Yes, you could use `from_entries`. In jq 1.5rc1 and above, it is defined as taking `Key`/`Value` key names as well as `key`/`value`.",
      "Try something like:\n\n`jq '.Subnets | map({SubnetId} + (.Tags | from_entries))'`",
      "On previous versions, you could modify the \"entries\" before passing them to `from_entries`:\n\n`jq '.Subnets | map({SubnetId} + (.Tags | map({value: .Value, key: .Key}) | from_entries))'`",
      "Here is a solution which only uses jq primitives.\n\n    [\n      .Subnets[]\n    | {SubnetId} + (.Tags[] | if .Key==\"Name\" then {Name:.Value} else empty end)\n    ]"
    ],
    "utterance": "Extract a list of objects from the Subnets array, each containing the SubnetId and the Name value from the Tag with Key equal to \"Name\".",
    "expressions": [
      ".Subnets | map({SubnetId} + (.Tags | from_entries))",
      ".Subnets | map({SubnetId} + (.Tags | map({value: .Value, key: .Key}) | from_entries))",
      "[ .Subnets[] | {SubnetId} + (.Tags[] | if .Key==\"Name\" then {Name:.Value} else empty end) ]"
    ],
    "data": [
      {
        "input": {
          "Subnets": [
            {
              "VpcId": "vpc-xxx",
              "Tags": [
                {
                  "Value": "staging_subnet_private_a",
                  "Key": "Name"
                }
              ],
              "SubnetId": "subnet-xxx"
            }
          ]
        },
        "output": [
          {
            "SubnetId": "subnet-xxx",
            "Name": "staging_subnet_private_a"
          }
        ]
      }
    ],
    "identifier": 31764035
  },
  {
    "context": [
      "I want to choose the order of the fields (without any consideration about the type of the field or the alphabetical order, my choice only :) )",
      "For jq versions 1.4 and up, the simplest way to specify a particular order of keys explicitly is to use the\n\n   {foo, bar, ...}\n\nform for specifying objects.  E.g. if input.json has the JSON shown in the question, then:\n\n    jq -Mc '{prop1, prop3, prop2}' input.json\n\nproduces:\n\n    {\"prop1\":1,\"prop3\":true,\"prop2\":{\"nested\":0}}",
      "def orderKeys(keys):\n  . as $in\n  | reduce keys[] as $key ({}; . + { ($key): $in[$key] });\n\n# Example:\norderKeys( [\"prop1\", \"prop3\", \"prop2\"] )",
      "Here's my hacky solution to include the \"rest\" of the properties (not specified in the order) at the end of the resulting object, so as to not lose any of the input:\n```\ndef orderKeys(orderedkeys):\n  . as $in\n  | reduce keys[] as $key ({}; if orderedkeys|contains([$key]) then . else . + { ($key): $in[$key] } end)\n  | . as $rest\n  | reduce orderedkeys[] as $key ({}; . + { ($key): $in[$key] })\n  | . + $rest;\n\n# Example:\norderKeys( [\"prop1\", \"prop3\", \"prop2\"] )\n```",
      "Here's a simple approach using `to_entries` and `from_entries` to perform \"object subtraction\":\n```\n{prop1, prop3, prop2} as $first\n| $first + (to_entries - ($first|to_entries) | from_entries)\n```"
    ],
    "utterance": "Reorder the fields so that 'prop1', 'prop3', and 'prop2' appear first and in that order, with any other properties following.",
    "expressions": [
      "{prop1, prop3, prop2}",
      "def orderKeys(keys): . as $in | reduce keys[] as $key ({}; . + { ($key): $in[$key] }); orderKeys([\"prop1\", \"prop3\", \"prop2\"])",
      "def orderKeys(orderedkeys): . as $in | reduce keys[] as $key ({}; if orderedkeys|contains([$key]) then . else . + { ($key): $in[$key] } end) | . as $rest | reduce orderedkeys[] as $key ({}; . + { ($key): $in[$key] }) | . + $rest; orderKeys([\"prop1\", \"prop3\", \"prop2\"])",
      "{prop1, prop3, prop2} as $first | $first + (to_entries - ($first|to_entries) | from_entries)"
    ],
    "data": [
      {
        "input": {
          "prop1": 1,
          "prop2": {
            "nested": 0
          },
          "prop3": true
        },
        "output": {
          "prop1": 1,
          "prop3": true,
          "prop2": {
            "nested": 0
          }
        }
      },
      {
        "input": {
          "prop1": 1,
          "otherprop": "foo",
          "prop2": {
            "nested": 0
          },
          "prop3": true
        },
        "output": {
          "prop1": 1,
          "prop3": true,
          "prop2": {
            "nested": 0
          },
          "otherprop": "foo"
        }
      }
    ],
    "identifier": 31719737
  },
  {
    "context": [
      "I\u2019d like to produce a summarized output showing: a list of users, the unique domains they visited, the total count. Bonus points if I can also get count per domain name.",
      "Here is a sample of the file:",
      "{ \"machine\": \"possible_victim01\", \"domain\": \"evil.com\", \"timestamp\":1435071870 }",
      "{ \"machine\": \"possible_victim01\", \"domain\": \"evil.com\", \"timestamp\":1435071875 }",
      "{ \"machine\": \"possible_victim01\", \"domain\": \"soevil.com\", \"timestamp\":1435071877 }",
      "{ \"machine\": \"possible_victim02\", \"domain\": \"bad.com\", \"timestamp\":1435071877 }",
      "{ \"machine\": \"possible_victim03\", \"domain\": \"soevil.com\", \"timestamp\":1435071879 }",
      "Ideally, I would like the output to be something like:\n\n    {\"possible_victim01\": \"total\": 3, {\"evil.com\": 2, \"soevil.com\": 1}}\n    {\"possible_victim02\": \"total\": 1, {\"bad.com\": 1}}\n    {\"possible_victim03\": \"total\": 1, {\"soevil.com\": 1}}",
      "jq query:\n\n    group_by(.machine) | map({\n        \"machine\": .[0].machine, \n        \"total\":length, \n        \"domains\": (group_by(.domain) | map({\n            \"key\":.[0].domain, \n            \"value\":length}) | from_entries\n        )\n    })",
      "reduce .[] as $o (\n  {}\n; [$o.machine, \"total\"] as $p1\n| [$o.machine, \"domains\", $o.domain] as $p2\n| setpath($p1; 1+getpath($p1))\n| setpath($p2; 1+getpath($p2))\n)"
    ],
    "utterance": "Summarize the data by user, showing for each user the total number of records and, for each domain visited, the count of times that user accessed it.",
    "expressions": [
      "group_by(.machine) | map({\n    \"machine\": .[0].machine,\n    \"total\": length,\n    \"domains\": (group_by(.domain) | map({\n        \"key\": .[0].domain,\n        \"value\": length}) | from_entries )\n})",
      "reduce inputs as $line\n  ({};\n   . as $in\n   | ($line.machine) as $machine\n   | ($line.domain) as $domain\n   | ($in[$machine].evildoers ) as $evildoers\n   | . + { ($machine): {\"total\": (1 + $in[$machine][\"total\"]),\n                        \"evildoers\": ($evildoers | (.[$domain] += 1)) }} )",
      "reduce .[] as $o (\n  {}\n; [$o.machine, \"total\"] as $p1\n| [$o.machine, \"domains\", $o.domain] as $p2\n| setpath($p1; 1+getpath($p1))\n| setpath($p2; 1+getpath($p2))\n)"
    ],
    "data": [
      {
        "input": [
          {
            "machine": "possible_victim01",
            "domain": "evil.com",
            "timestamp": 1435071870
          },
          {
            "machine": "possible_victim01",
            "domain": "evil.com",
            "timestamp": 1435071875
          },
          {
            "machine": "possible_victim01",
            "domain": "soevil.com",
            "timestamp": 1435071877
          },
          {
            "machine": "possible_victim02",
            "domain": "bad.com",
            "timestamp": 1435071877
          },
          {
            "machine": "possible_victim03",
            "domain": "soevil.com",
            "timestamp": 1435071879
          }
        ],
        "output": {
          "possible_victim01": {
            "total": 3,
            "domains": {
              "evil.com": 2,
              "soevil.com": 1
            }
          },
          "possible_victim02": {
            "total": 1,
            "domains": {
              "bad.com": 1
            }
          },
          "possible_victim03": {
            "total": 1,
            "domains": {
              "soevil.com": 1
            }
          }
        }
      }
    ],
    "identifier": 31035704
  },
  {
    "context": [
      "But for the instances that are returned I would like them to be sorted by their Tag Name.",
      "In each `Reservation`, I want the `Instances` inside to be sorted by the `Value` of the `Tag` whose `Key` is `\"Name\"`",
      "jq '.Reservations[].Instances |= sort_by(.Tags[] | select(.Key == \"Name\").Value)'"
    ],
    "utterance": "Sort Instances within each Reservation by the Value of their Tag with Key equal to Name.",
    "expressions": [
      ".Reservations[].Instances |= sort_by(.Tags[] | select(.Key == \"Name\").Value)"
    ],
    "data": [
      {
        "input": {
          "Reservations": [
            {
              "Instances": [
                {
                  "Tags": [
                    {
                      "Key": "Name",
                      "Value": "banana"
                    }
                  ],
                  "PrivateDnsName": "private.name.here"
                },
                {
                  "Tags": [
                    {
                      "Key": "Name",
                      "Value": "apple"
                    }
                  ],
                  "PrivateDnsName": "private.dns.name"
                }
              ]
            }
          ]
        },
        "output": {
          "Reservations": [
            {
              "Instances": [
                {
                  "Tags": [
                    {
                      "Key": "Name",
                      "Value": "apple"
                    }
                  ],
                  "PrivateDnsName": "private.dns.name"
                },
                {
                  "Tags": [
                    {
                      "Key": "Name",
                      "Value": "banana"
                    }
                  ],
                  "PrivateDnsName": "private.name.here"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 31817450
  },
  {
    "context": [
      "i have huge json data, in every object has download_able and playable attribute which is boolean type.",
      "So i try to compare each other every objects attribute and get only one response.",
      "`jq '.result[].downlaodable or .result[].playable'` response me like that",
      "I want to compare these response again and i have to get one response.",
      "I think you want to do a boolean `or` of the results you get with your existing jq program.",
      "`jq '[.result[].downlaodable or .result[].playable] | any'`",
      "This should just output: `true`"
    ],
    "utterance": "Determine if any object in the array has downlaodable or playable set to true and return a single boolean result.",
    "expressions": [
      "[.result[].downlaodable or .result[].playable] | any"
    ],
    "identifier": 31935170
  },
  {
    "context": [
      "I know you asked for an Awk command, but since you're already using jq to generate the CSV file, you might as well do it there:",
      "jq --arg date \"$(date)\" -r '\n    .pagedEntities._embedded.teamActivityList | \n    [.[].teamName, .[].rank, .[].average, .[].total, $date] | \n    @csv'",
      "Here is a solution... but uses jq's **now** and **strftime** functions instead of using the unix `date` command.",
      "jq -r '\n     (now|strftime(\"%c\")) as $date\n   | .pagedEntities._embedded.teamActivityList\n   | [.[].teamName, .[].rank, .[].average, .[].total, $date]\n   | @csv\n' file.json"
    ],
    "utterance": "Output each team's teamName, rank, average, and total, appending the current date as the last column of the CSV.",
    "expressions": [
      "jq --arg date \"$(date)\" -r '.pagedEntities._embedded.teamActivityList | [.[].teamName, .[].rank, .[].average, .[].total, $date] | @csv'",
      "jq -r ' (now|strftime(\"%c\")) as $date | .pagedEntities._embedded.teamActivityList | [.[].teamName, .[].rank, .[].average, .[].total, $date] | @csv ' file.json"
    ],
    "identifier": 31908071
  },
  {
    "context": [
      "For example, I want to extract the values from a key, but that key sometimes contains an object (I mean just one value) or sometimes contains an array (i mean multiples values). HOw check if there is an array or there is an object?",
      "Use the `type` function:\r\n\r\n> `type`  \r\n> The type function returns the type of its argument as a string,\r\n> which is one of null, boolean, number, string, array or object.",
      "Example 2:\r\n\r\n    echo '[0,1]' | jq 'if type==\"array\" then \"yes\" else \"no\" end'\r\n    \"yes\"",
      "Example 3:\r\n\r\n    echo '{\"0\":0,\"1\":1}' | jq 'if type==\"array\" then \"yes\" else \"no\" end'\r\n    \"no\""
    ],
    "utterance": "Determine whether a key holds an array or an object and extract values accordingly.",
    "expressions": [
      "if .key | type == \"array\" then (.key | .[]) else .key end",
      "if .key | type == \"object\" then (.key | to_entries[] | .value) else .key[] end"
    ],
    "data": [
      {
        "input": {
          "key": [
            1,
            2,
            3
          ]
        },
        "output": [
          1,
          2,
          3
        ]
      },
      {
        "input": {
          "key": {
            "a": 1,
            "b": 2
          }
        },
        "output": [
          1,
          2
        ]
      }
    ],
    "identifier": 31912454
  },
  {
    "context": [
      "It seems that it is not able to replace the variable i in the children[] array , as because if we give the expression -\n\n    array[$i]=$(cat json.txt | jq '.children[0]') \n\nit runs well .",
      "You should use the following syntax:\n\n    array[$i]=$(cat json.txt | jq '.children['${i}']')",
      "An argument syntax is provided by jq for this purpose. This syntax allows you to set jq variables to the value of shell variables. You could replace your current jq invocation with this:\n\n`array[$i]=$(cat json.txt | jq --arg i $i '.children[$i | tonumber]')`"
    ],
    "utterance": "Access a specific element at index i from the children array, where i is a shell variable.",
    "expressions": [
      ".children[${i}]",
      ".children[$i | tonumber]"
    ],
    "data": [
      {
        "input": {
          "first_name": "John",
          "last_name": "Smith",
          "things_carried": [
            "apples",
            "hat",
            "harmonica"
          ],
          "children": [
            {
              "first_name": "Bobby Sue",
              "last_name": "Smith"
            },
            {
              "first_name": "John Jr",
              "last_name": "Smith"
            }
          ]
        },
        "output": {
          "first_name": "John Jr",
          "last_name": "Smith"
        }
      }
    ],
    "identifier": 31969719
  },
  {
    "context": [
      "The data I have looks like:\r\n\r\n    [\r\n        {\"id\":1, \"value\":\"yes\"},\r\n        {\"id\":2, \"value\":\"no\"},\r\n        {\"id\":3, \"value\":\"maybe\"}\r\n    ]",
      "And I'd like to transform that into a list like this:\r\n\r\n    [\r\n        {\"id\":1, \"value\":\"10\"},\r\n        {\"id\":2, \"value\":\"0\"},\r\n        {\"id\":3, \"value\":\"5\"}\r\n    ]",
      "With the fixed mapping:\r\n\r\n    yes => 10\r\n    no => 0\r\n    maybe => 5",
      "map(.value = {\"yes\":\"10\",\"no\":\"0\",\"maybe\":\"5\"}[.value])",
      "map(.value |= {\"yes\":\"10\",\"no\":\"0\",\"maybe\":\"5\"}[.])",
      "jq --arg mapping '{\"yes\":\"10\",\"no\":\"0\",\"maybe\":\"5\"}'\r\n    'map(.value |= ($mapping | fromjson)[.])' data.json",
      "def mapping: {\"yes\":\"10\",\"no\":\"0\",\"maybe\":\"5\"};\r\nmap(.value |=  mapping[.])",
      "jq --argfile mapping mapping.jq 'map(.value |= $mapping[.])' data.json"
    ],
    "utterance": "Replace each object's value according to the mapping: yes \u2192 10, no \u2192 0, maybe \u2192 5.",
    "expressions": [
      "map(.value = {\"yes\":\"10\",\"no\":\"0\",\"maybe\":\"5\"}[.value])",
      "map(.value |= {\"yes\":\"10\",\"no\":\"0\",\"maybe\":\"5\"}[.])",
      "jq --arg mapping '{\"yes\":\"10\",\"no\":\"0\",\"maybe\":\"5\"}' 'map(.value |= ($mapping | fromjson)[.])'",
      "def mapping: {\"yes\":\"10\",\"no\":\"0\",\"maybe\":\"5\"}; map(.value |=  mapping[.])",
      "jq --argfile mapping mapping.jq 'map(.value |= $mapping[.])'"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "value": "yes"
          },
          {
            "id": 2,
            "value": "no"
          },
          {
            "id": 3,
            "value": "maybe"
          }
        ],
        "output": [
          {
            "id": 1,
            "value": "10"
          },
          {
            "id": 2,
            "value": "0"
          },
          {
            "id": 3,
            "value": "5"
          }
        ]
      }
    ],
    "identifier": 31887253
  },
  {
    "context": [
      "Using jq 1.5 (e.g. jq 1.5rc2 -- see http://stedolan.github.io/jq):",
      "$ jq -n env",
      "jq -n 'env | {USER, HOME, PS1}'"
    ],
    "utterance": "Output all or selected UNIX environment variables as a key-value object.",
    "expressions": [
      "jq -n env",
      "jq -n 'env | {USER, HOME, PS1}'"
    ],
    "identifier": 31976186
  },
  {
    "context": [
      "I'm trying to compare two attributes on every object. This is the code i use for this problem:\r\n\r\n`(.result[].downlaodable or .result[].playable)` but this time jq does cartesian product.",
      "Change your filter to generate the results once.\r\n\r\n    .result[] | .downloadable or .playable"
    ],
    "utterance": "For each item in the array, return the value of 'downloadable' if it exists, otherwise 'playable'.",
    "expressions": [
      ".result[] | .downloadable // .playable"
    ],
    "identifier": 31981270
  },
  {
    "context": [
      "Now, I want to know how I can use parallelism/multi threading approach in JQ in order to complete the process in less amount of time.",
      "Here is a streaming approach which assumes your 3GB data file is in `data.json` and the following filter is in `filter1.jq`:\r\n\r\n      select(length==2)\r\n    | . as [$p, $v]\r\n    | {r:$p[1]}\r\n    | if   $p[2:6] == [\"body\",\"party\",\"general-info\",\"full-name\"]       then .name = $v\r\n      elif $p[2:6] == [\"body\",\"party\",\"xrefs\",\"xref\"] and $p[7] == \"id\" then .id   = $v\r\n      else  empty\r\n      end",
      "jq will produce a stream of results with minimal details you need",
      "which you can convert to your desired format by using a second `filter2.jq`:",
      "which consumes the output of the first filter when run with \r\n \r\n    $ jq -M -c --stream -f filter1.jq data.json | jq -M -s -r -f filter2.jq",
      "If you need more parallelism you could use the record number (r) as to partition the data and process the partitions in parallel.  For example, if you save the intermediate output into a `temp.json` file",
      "$ jq -M -c --stream -f filter1.jq data.json > temp.json",
      "then you could process `temp.json` in parallel with filters such as\r\n\r\n    $ jq -M 'select(0==.r%3)' temp.json | jq -M -s -r -f filter2.jq > result0.out &\r\n    $ jq -M 'select(1==.r%3)' temp.json | jq -M -s -r -f filter2.jq > result1.out &\r\n    $ jq -M 'select(2==.r%3)' temp.json | jq -M -s -r -f filter2.jq > result2.out &\r\n    \r\nand concatenate your partitions into a single result at the end if necessary."
    ],
    "utterance": "Split a large file into logical partitions based on a record number and process each partition concurrently to transform each xrefs/xref id and corresponding party general-info full-name into the format <id>~<full-name>.",
    "expressions": [
      "jq -M -c --stream -f filter1.jq data.json > temp.json",
      "jq -M 'select(0==.r%3)' temp.json | jq -M -s -r -f filter2.jq > result0.out &",
      "jq -M 'select(1==.r%3)' temp.json | jq -M -s -r -f filter2.jq > result1.out &",
      "jq -M 'select(2==.r%3)' temp.json | jq -M -s -r -f filter2.jq > result2.out &"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "_id": "0000001",
              "body": {
                "party": {
                  "related-parties": {},
                  "general-info": {
                    "last-update-ts": "2011-02-14T08:21:51.000-05:00",
                    "full-name": "Ibercaja Gestion SGIIC SAPensiones Nuevas Oportunidades",
                    "status": "ACTIVE",
                    "last-update-user": "TS42922",
                    "create-date": "2011-02-14T08:21:51.000-05:00",
                    "classifications": {
                      "classification": [
                        {
                          "code": "PENS"
                        }
                      ]
                    }
                  },
                  "xrefs": {
                    "xref": [
                      {
                        "type": "LOCCU1",
                        "id": "X00893X"
                      },
                      {
                        "type": "ID",
                        "id": "1012227139"
                      }
                    ]
                  }
                }
              }
            },
            {
              "_id": "000002",
              "body": {
                "party": {
                  "related-parties": {},
                  "general-info": {
                    "last-update-ts": "2015-05-21T15:10:45.174-04:00",
                    "full-name": "Innova Capital Sp zoo",
                    "status": "ACTIVE",
                    "last-update-user": "jw74592",
                    "create-date": "1994-08-31T00:00:00.000-04:00",
                    "classifications": {
                      "classification": [
                        {
                          "code": "CORP"
                        }
                      ]
                    }
                  },
                  "xrefs": {
                    "xref": [
                      {
                        "type": "ULTDUN",
                        "id": "144349875"
                      },
                      {
                        "type": "AVID",
                        "id": "6098743"
                      },
                      {
                        "type": "LOCCU1",
                        "id": "1001210218"
                      },
                      {
                        "type": "ID",
                        "id": "1001210218"
                      },
                      {
                        "type": "BLMBRG",
                        "id": "10009050"
                      },
                      {
                        "type": "REG_CO",
                        "id": "0000068508"
                      },
                      {
                        "type": "SMCI",
                        "id": "13159"
                      }
                    ]
                  }
                }
              }
            }
          ]
        },
        "output": [
          "X00893X~Ibercaja Gestion SGIIC SAPensiones Nuevas Oportunidades",
          "1012227139~Ibercaja Gestion SGIIC SAPensiones Nuevas Oportunidades",
          "144349875~Innova Capital Sp zoo",
          "6098743~Innova Capital Sp zoo",
          "1001210218~Innova Capital Sp zoo",
          "1001210218~Innova Capital Sp zoo",
          "10009050~Innova Capital Sp zoo",
          "0000068508~Innova Capital Sp zoo",
          "13159~Innova Capital Sp zoo"
        ]
      }
    ],
    "identifier": 30982175
  },
  {
    "context": [
      "Instead of calling `jq` again on each array element, just fetch the name with the first call that feeds the loop.",
      "jq one liner `jq '.[] | (.name)' jobs`",
      "`\"my job name\"\n\"my \\\"quoted\\\" job name\"`"
    ],
    "utterance": "Extract all name values from each object in the array, including those with escaped quotes.",
    "expressions": [
      ".[] | .name"
    ],
    "data": [
      {
        "input": [
          {
            "id": "1a-2b",
            "name": "my job name",
            "description": "my job description"
          },
          {
            "id": "3c-4d",
            "name": "my \\\"quoted\\\" job name",
            "description": "my \\\"quoted\\\" job description"
          }
        ],
        "output": [
          "my job name",
          "my \\\"quoted\\\" job name"
        ]
      }
    ],
    "identifier": 32125603
  },
  {
    "context": [
      "Is there relatively simple way to filter these objects without loading whole file into memory?",
      "**--stream** option looks suitable, but I can't figure out how to fold stream of [path,value] to original objects.",
      "jq 1.5 has a streaming parser. The jq [FAQ][1] gives an example of how to convert a top-level array of JSON objects into a stream of its elements:",
      "$ jq -nc --stream 'fromstream(1|truncate_stream(inputs))'",
      "[{\"foo\":\"bar\"},{\"foo\":\"baz\"}]",
      "{\"foo\":\"bar\"}",
      "{\"foo\":\"baz\"}"
    ],
    "utterance": "Convert a large top-level array to a stream of individual objects for processing without loading the entire file into memory.",
    "expressions": [
      "fromstream(1|truncate_stream(inputs))"
    ],
    "data": [
      {
        "input": [
          {
            "foo": "bar"
          },
          {
            "foo": "baz"
          }
        ],
        "output": [
          {
            "foo": "bar"
          },
          {
            "foo": "baz"
          }
        ]
      }
    ],
    "identifier": 32182087
  },
  {
    "context": [
      "I\u2019d like to only add strings that do not already exist.",
      ".widgets[] | select(.name==\"foo\") | select(.properties | index(\"cat\") | not) | .properties += [\"cat\"]",
      ".widgets |= [ .[] | if .properties|index(\"cat\")|not then .properties += [\"cat\"] else . end]"
    ],
    "utterance": "Add \"cat\" to the properties array of the widget named \"foo\" only if it is not already present.",
    "expressions": [
      ".widgets[] | select(.name==\"foo\") | select(.properties | index(\"cat\") | not) | .properties += [\"cat\"]",
      ".widgets |= [ .[] | if .properties|index(\"cat\")|not then .properties += [\"cat\"] else . end]"
    ],
    "data": [
      {
        "input": {
          "widgets": [
            {
              "name": "foo",
              "properties": [
                "baz"
              ]
            },
            {
              "name": "bar"
            }
          ]
        },
        "output": {
          "widgets": [
            {
              "name": "foo",
              "properties": [
                "baz",
                "cat"
              ]
            },
            {
              "name": "bar"
            }
          ]
        }
      }
    ],
    "identifier": 32167453
  },
  {
    "context": [
      "input\n\n    {\"key1\": [\"value1\", \"value2\"], \"key2\": [\"value3\"]}\n\n\nDesired output\n\n    key1, value1\n    key1, value2\n    key2, value3\n\nHaving a hard time figuring out jq command to achieve this...",
      "jq -r 'to_entries | map({key, value: .value[]}) | map([.key, .value])[] | @csv' test.json",
      "$ jq -r 'to_entries[] | { key, value: .value[] } | [ .key, .value ] | @csv'",
      "$ jq -r 'to_entries[] | [ [.key], .value ] | combinations | @csv'",
      ". as $v\n| keys[]\n| \"\\(.), \\($v[.][])\""
    ],
    "utterance": "List each key paired with each of its values, one per line, as two columns separated by a comma.",
    "expressions": [
      "to_entries | map({key, value: .value[]}) | map([.key, .value])[] | @csv",
      "to_entries[] | { key, value: .value[] } | [ .key, .value ] | @csv",
      "to_entries[] | [ [.key], .value ] | combinations | @csv",
      ". as $v | keys[] | \"\\(.), \\($v[.][])\""
    ],
    "data": [
      {
        "input": {
          "key1": [
            "value1",
            "value2"
          ],
          "key2": [
            "value3"
          ]
        },
        "output": [
          "key1, value1",
          "key1, value2",
          "key2, value3"
        ]
      }
    ],
    "identifier": 32086615
  },
  {
    "context": [
      "returns the value of FileSystemId when the value of Name = \"efs-docker\" and breaks out of the script if no matching records are found.",
      "jq '.FileSystems[]' | jq 'select(.Name==\"efs-docker\")' | jq -r '.FileSystemId'",
      "jq -r '.FileSystems[] | select(.Name==\"efs-docker\") | .FileSystemId'"
    ],
    "utterance": "Retrieve the FileSystemId where Name equals \"efs-docker\".",
    "expressions": [
      ".FileSystems[] | select(.Name==\"efs-docker\") | .FileSystemId",
      "-r '.FileSystems[] | select(.Name==\"efs-docker\") | .FileSystemId'"
    ],
    "data": [
      {
        "input": {
          "FileSystems": [
            {
              "SizeInBytes": {
                "Value": 6144
              },
              "Name": "not-docker",
              "CreationToken": "console-db868fd6-ed6d-46f8-9e3e-4501293847f5",
              "CreationTime": 1440519280.0,
              "FileSystemId": "fs-0fdd32a6",
              "NumberOfMountTargets": 3,
              "LifeCycleState": "available",
              "OwnerId": "310444902345"
            },
            {
              "SizeInBytes": {
                "Timestamp": 1440514799.0,
                "Value": 307060736
              },
              "Name": "efs-docker",
              "CreationToken": "console-3b8b33de-dc45-4634-b6e1-882187ac3cd3",
              "CreationTime": 1440426036.0,
              "FileSystemId": "fs-d2c22d7b",
              "NumberOfMountTargets": 3,
              "LifeCycleState": "available",
              "OwnerId": "310444902345"
            }
          ]
        },
        "output": "fs-d2c22d7b"
      }
    ],
    "identifier": 32214120
  },
  {
    "context": [
      "I want to use [jq][1] to generate a file that looks like:",
      "{\r\n  \"population\": \"4779736\",\r\n  \"state_name\": \"Alabama\",\r\n  \"state_code\": \"01\"\r\n}\r\n{ ... }",
      "The correct method is to use `map()`:\r\n\r\n    .[1:999999999999] | map({population:.[0], state_name:.[1], state_code:.[2]})",
      "(1) Instead of the *.[1:999999999999]* hack, you can simply write *.[1:]*.",
      "(2) The stated goal is to produce a sequence (i.e. stream) of objects, rather than an array of objects. This can be accomplished as follows:\r\n\r\n    .[1:][] | {population:.[0], state_name:.[1], state_code:.[2]}"
    ],
    "utterance": "Output each state's population, name, and code as separate objects, skipping the header row.",
    "expressions": [
      ".[1:] | map({population:.[0], state_name:.[1], state_code:.[2]})",
      ".[1:][] | {population:.[0], state_name:.[1], state_code:.[2]}"
    ],
    "data": [
      {
        "input": [
          [
            "P0010001",
            "NAME",
            "state"
          ],
          [
            "4779736",
            "Alabama",
            "01"
          ],
          [
            "710231",
            "Alaska",
            "02"
          ],
          [
            "6392017",
            "Arizona",
            "04"
          ]
        ],
        "output": [
          {
            "population": "4779736",
            "state_name": "Alabama",
            "state_code": "01"
          },
          {
            "population": "710231",
            "state_name": "Alaska",
            "state_code": "02"
          },
          {
            "population": "6392017",
            "state_name": "Arizona",
            "state_code": "04"
          }
        ]
      }
    ],
    "identifier": 32176017
  },
  {
    "context": [
      "Here is where I need your help, how can I get the value of the key \"dashboard\" but without the escaped '\\' character in the key/val pair not affecting the escaped that are part of the values?",
      "The output that I need should be something like:\n\n    { \"title\": \"My Dashboard\", \"services\": { \"query\": { \"list\": { \"0\": { \"id\": 0, \"type\": \"lucene\", \"query\": \"type:dh AND severity:ERROR AND (response.baseUrl:\\\"/rm/recordings/*\\\" OR request.baseUrl:\\\"/rm/recordings/*\\\")\", \"alias\": \"DH errors rcc\",.......",
      "\"fromjson\" is your friend.  For example:",
      "data | ._source.dashboard | fromjson",
      "Output:\n\n    $ jq -n -f elastic.jq\n    {\n      \"title\": \"My Dashboard\",\n      \"services\": {\n        \"query\": {\n          \"list\": {\n            \"0\": \"foobar\"\n          }\n        }\n      }\n    }"
    ],
    "utterance": "Extract and parse the value of the 'dashboard' key under '_source' as a structured object, ensuring embedded escaped characters in values are preserved.",
    "expressions": [
      "._source.dashboard | fromjson"
    ],
    "data": [
      {
        "input": {
          "_index": "kibana-int",
          "_type": "dashboard",
          "_id": "my_Dashboard",
          "_version": 5,
          "found": true,
          "_source": {
            "user": "guest",
            "group": "guest",
            "title": "my_Dashboard",
            "dashboard": "{ \\\"title\\\": \\\"My Dashboard\\\", \\\"services\\\": { \\\"query\\\": { \\\"list\\\": { \\\"0\\\": \\\"foobar\\\" }}}}"
          }
        },
        "output": {
          "title": "My Dashboard",
          "services": {
            "query": {
              "list": {
                "0": "foobar"
              }
            }
          }
        }
      }
    ],
    "identifier": 32168795
  },
  {
    "context": [
      "For example, given I have this input array:",
      "`['foo', bar', 'baz']`",
      "And this filter array:",
      "`['foo', 'baz']`",
      "I want to have this output:",
      "`['bar']`",
      "You can use the convenient subtraction operator `-` as follows:",
      "    jq '. - [\"foo\", \"baz\"]'"
    ],
    "utterance": "Return the elements from the array ['foo', 'bar', 'baz'] that are not present in ['foo', 'baz'].",
    "expressions": [
      ". - [\"foo\", \"baz\"]"
    ],
    "data": [
      {
        "input": [
          "foo",
          "bar",
          "baz"
        ],
        "output": [
          "bar"
        ]
      }
    ],
    "identifier": 32338872
  },
  {
    "context": [
      "One can sort a stream of Twitter JSON blobs with:",
      "jq -r '(.created_at | strptime(\"%a %b %d %H:%M:%S +0000 %Y\") | todate) + \"\\t\" + tostring' |",
      "sort -k1,1 |",
      "cut -f2",
      "For each JSON blob, the `jq` command parses the \"created_at\" field and outputs an ISO8601 date, followed by a tab, followed by the original JSON (which does not contain tabs or newlines). The `--raw-output`/`-r` flag ensures this is not JSON-encoded, but output as raw text. The stream is then sorted by GNU `sort` or equivalent, and the JSON blobs alone are retuned by `cut`."
    ],
    "utterance": "Sort line-delimited Twitter tweet objects by their created_at timestamp while retaining the original objects in the output.",
    "expressions": [
      "jq -r '(.created_at | strptime(\"%a %b %d %H:%M:%S +0000 %Y\") | todate) + \"\\t\" + tostring'"
    ],
    "data": [
      {
        "input": [
          {
            "created_at": "Wed Oct 10 20:19:24 +0000 2018",
            "text": "First tweet"
          },
          {
            "created_at": "Thu Oct 11 15:03:21 +0000 2018",
            "text": "Second tweet"
          }
        ],
        "output": [
          {
            "created_at": "Wed Oct 10 20:19:24 +0000 2018",
            "text": "First tweet"
          },
          {
            "created_at": "Thu Oct 11 15:03:21 +0000 2018",
            "text": "Second tweet"
          }
        ]
      }
    ],
    "identifier": 32217197
  },
  {
    "context": [
      "The value of the field `requirementsString` contains a string, of which I need only a part of this. For this i use `sub` I want to assign the result to a new field.",
      "What is the correct syntax for this?",
      ".minimalVersion = (.softwareInfo.requirementsString | sub(\"iOS(?<version>.*?) or\"; \"\\(.version)\"))"
    ],
    "utterance": "Extract part of requirementsString matching 'iOS(?<version>.*?) or' and assign the result to a new field called minimalVersion.",
    "expressions": [
      ".minimalVersion = (.softwareInfo.requirementsString | sub(\"iOS(?<version>.*?) or\"; \"\\(.version)\"))"
    ],
    "identifier": 32370843
  },
  {
    "context": [
      "The *business.json* contains **categories** and **business_id**, from which I can get all ids of restaurants, using which I want to filter the *review.json* to extract all reviews for restaurants.",
      "select(.categories | index(\"Restaurant\"))\n| .business_id as $business_id\n| $reviews[]\n| select( .type == \"review\" and .business_id == $business_id)",
      "$ jq --slurpfile reviews reviews.json yelp.jq businesses.json"
    ],
    "utterance": "Extract all reviews where the business is categorized as 'Restaurant' by matching business_id from business data to review data.",
    "expressions": [
      "select(.categories | index(\"Restaurant\"))\n| .business_id as $business_id\n| $reviews[]\n| select( .type == \"review\" and .business_id == $business_id)"
    ],
    "data": [
      {
        "input": [
          {
            "business_id": "vcNAWiLM4dR7D2nwwJ7nCA",
            "full_address": "4840 E Indian School Rd\nSte 101\nPhoenix, AZ 85018",
            "categories": [
              "Restaurant"
            ]
          }
        ],
        "output": [
          {
            "date": "2012-05-15",
            "text": "Got a letter in the mail last week that said Dr. Goldberg is moving to Arizona to take a new position there in June.  He will be missed very much.  \n\nI think finding a new doctor in NYC that you actually like might almost be as awful as trying to find a date!",
            "type": "review",
            "business_id": "vcNAWiLM4dR7D2nwwJ7nCA"
          }
        ]
      }
    ],
    "identifier": 32442433
  },
  {
    "context": [
      "What is the easiest way to take the json output of a curl statement and save variables created by filters in jq with the goal of creating a report (e.g., using javascript)?",
      "jq -r '@sh \"a=\\(.a) b=\\(.b)\"' | while read -r line; do eval \"$line\"; done"
    ],
    "utterance": "Extract fields such as a and b from the input and assign them to shell variables for use in creating a custom report.",
    "expressions": [
      "jq -r '@sh \"a=\\(.a) b=\\(.b)\"' | while read -r line; do eval \"$line\"; done"
    ],
    "identifier": 32509866
  },
  {
    "context": [
      "I\u2019m looking to use `jq` to transpose a 2-dimensional object such as this:",
      "[{ \"name\": \"A\", \"keys\": [\"k1\", \"k2\", \"k3\"] }, { \"name\": \"B\", \"keys\": [\"k2\", \"k3\", \"k4\"] }]",
      "I\u2019d like to transform it to:",
      "{ \"k1\": [\"A\"], \"k2\": [\"A\", \"B\"], \"k3\": [\"A\", \"B\"], \"k4\": [\"A\"] }",
      "This should work:\n\n    map({ name, key: .keys[] })\n        | group_by(.key)\n        | map({ key: .[0].key, value: map(.name) })\n        | from_entries",
      "Here is a simple solution that may also be easier to understand.\n\ndef extend_dictionary(keys; value):\n  reduce keys[] as $key (.; .[$key] += [value]);\n\nreduce .[] as $o ({}; extend_dictionary($o.keys; $o.name) )",
      "map( { (.name) : .keys} )\n| add\n| invertMapping"
    ],
    "utterance": "For each unique string from all elements' keys arrays, list the names of all objects containing that key, as an object with keys as array elements and values as arrays of names.",
    "expressions": [
      "map({ name, key: .keys[] }) | group_by(.key) | map({ key: .[0].key, value: map(.name) }) | from_entries",
      "def extend_dictionary(keys; value): reduce keys[] as $key (.; .[$key] += [value]); reduce .[] as $o ({}; extend_dictionary($o.keys; $o.name) )",
      "def invertMapping: reduce to_entries[] as $pair ({}; reduce $pair.value[] as $v (.; .[$v] += [$pair.key] )); map( { (.name) : .keys} ) | add | invertMapping"
    ],
    "data": [
      {
        "input": [
          {
            "name": "A",
            "keys": [
              "k1",
              "k2",
              "k3"
            ]
          },
          {
            "name": "B",
            "keys": [
              "k2",
              "k3",
              "k4"
            ]
          }
        ],
        "output": {
          "k1": [
            "A"
          ],
          "k2": [
            "A",
            "B"
          ],
          "k3": [
            "A",
            "B"
          ],
          "k4": [
            "B"
          ]
        }
      }
    ],
    "identifier": 32357240
  },
  {
    "context": [
      "The output I need:\r\n\r\n    consumer-leads,txt-2300,null\r\n    main,null,brown-space|default|txt-hosts\r\n    paid-media,txt-2300,null\r\n    reports,null,default|grey-space|txt-hosts\r\n\r\nNote that StateGroups (if they exist at all) are sorted by StateGroupName as (or before) they are being transformed into a string of values separated by vertical bars.",
      "This should work:\r\n\r\n    [\r\n        .ClassIdentifier,\r\n        .StateMode // &quot;null&quot;,\r\n        (.StateGroups\r\n            | map(select(.Status==&quot;active&quot;).StateGroupName)\r\n            | sort\r\n            | join(&quot;|&quot;)\r\n            | if .==&quot;&quot; then &quot;null&quot; else . end\r\n        )\r\n    ] | @csv",
      "Note that since you&#39;re using 1.3, `join/1` won&#39;t be available to you.  But it shouldn&#39;t be difficult to implement yourself.\r\n\r\n    def join(sep): sep as $sep\r\n        | reduce .[1:][] as $item (.[0]|tostring; . + $sep + $item)\r\n        ;"
    ],
    "utterance": "For each object, output ClassIdentifier, StateMode, and for StateGroups with Status == \"active\", concatenate StateGroupName values sorted and joined with |, or \"null\" if no such group; format as CSV.",
    "expressions": [
      "def join(sep): sep as $sep | reduce .[1:][] as $item (.[0]|tostring; . + $sep + $item); [ .ClassIdentifier, .StateMode // \"null\", ( .StateGroups | map(select(.Status==\"active\").StateGroupName) | sort | join(\"|\") | if .==\"\" then \"null\" else . end ) ] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "ClassIdentifier": "consumer-leads",
            "StateMode": "txt-2300",
            "StateGroups": []
          },
          {
            "ClassIdentifier": "main",
            "StateMode": null,
            "StateGroups": [
              {
                "Status": "active",
                "StateGroupName": "default"
              },
              {
                "Status": "active",
                "StateGroupName": "brown-space"
              },
              {
                "Status": "active",
                "StateGroupName": "txt-hosts"
              }
            ]
          },
          {
            "ClassIdentifier": "paid-media",
            "StateMode": "txt-2300",
            "StateGroups": []
          },
          {
            "ClassIdentifier": "reports",
            "StateMode": null,
            "StateGroups": [
              {
                "Status": "active",
                "StateGroupName": "txt-hosts"
              },
              {
                "Status": "active",
                "StateGroupName": "grey-space"
              },
              {
                "Status": "active",
                "StateGroupName": "default"
              }
            ]
          }
        ],
        "output": [
          "\"consumer-leads\",\"txt-2300\",\"null\"",
          "\"main\",\"null\",\"brown-space|default|txt-hosts\"",
          "\"paid-media\",\"txt-2300\",\"null\"",
          "\"reports\",\"null\",\"default|grey-space|txt-hosts\""
        ]
      }
    ],
    "identifier": 32275538
  },
  {
    "context": [
      "I need to add a unique id in my csv output that will be based on index of current element in its JSON array.",
      "Is there any built-in JQ function returning the element index?",
      "As of jq 1.4, there's [`index/1`](https://stedolan.github.io/jq/manual/#%60index%28s%29%60,%60rindex%28s%29%60) or [`indices/1`](https://stedolan.github.io/jq/manual/#%60indices%28s%29%60) as outlined in the [manual](https://stedolan.github.io/jq/manual/).",
      "There are two robust (i.e., that work in jq 1.3, 1.4 and 1.5) ways to iterate through an array with an index: one is to use keys[] (which works on arrays as well as objects), and the other using range/2.  These two approaches can be illustrated as follows, assuming $a is an array:\r\n\r\n    ($a | keys[]) as $i | [$i, $a[$i]] \r\n  \r\n    range(0; $a | length) as $i | [$i, $a[$i]]\r\n\r\nOr more succinctly:\r\n\r\n    $a | keys[] as $i | [$i, .[$i]]\r\n\r\n    $a | range(0;length) as $i | [$i, .[$i]]",
      "[`to_entries`](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries) should work perfectly.",
      "jq -n '[\"a\",\"b\",\"c\"] | to_entries'",
      "will produce",
      "[{\"key\":0,\"value\":\"a\"},{\"key\":1,\"value\":\"b\"},{\"key\":2,\"value\":\"c\"}]"
    ],
    "utterance": "Return each element of an array with its index as a unique identifier.",
    "expressions": [
      "to_entries",
      "keys[] as $i | [$i, .[$i]]",
      "range(0;length) as $i | [$i, .[$i]]"
    ],
    "data": [
      {
        "input": [
          "a",
          "b",
          "c"
        ],
        "output": [
          {
            "key": 0,
            "value": "a"
          },
          {
            "key": 1,
            "value": "b"
          },
          {
            "key": 2,
            "value": "c"
          }
        ]
      }
    ],
    "identifier": 32499268
  },
  {
    "context": [
      "Are there any command line utilities that can be used to find if two JSON files are identical with invariance to within-dictionary-key and within-list-element ordering?",
      "jq --argfile a a.json --argfile b b.json -n '($a | (.. | arrays) |= sort) as $a | ($b | (.. | arrays) |= sort) as $b | $a == $b'",
      "def post_recurse(f): def r: (f | select(. != null) | r), .; r; def post_recurse: post_recurse(.[]?); (post_recurse | arrays) |= sort",
      "jq --argfile a a.json --argfile b b.json -n 'def post_recurse(f): def r: (f | select(. != null) | r), .; r; def post_recurse: post_recurse(.[]?); ($a | (post_recurse | arrays) |= sort) as $a | ($b | (post_recurse | arrays) |= sort) as $b | $a == $b'",
      "def walk(f):\n  . as $in\n  | if type == \"object\" then\n      reduce keys[] as $key\n        ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\n  elif type == \"array\" then map( walk(f) ) | f\n  else f\n  end;\n\ndef normalize: walk(if type == \"array\" then sort else . end);\n\ndef equiv(x): normalize == (x | normalize);",
      "{ \"a\":[1,2,[3,4]] } | equiv( { \"a\": [[4,3], 2,1] } )"
    ],
    "utterance": "Determine whether two files contain structurally identical data regardless of object key ordering and regardless of the order of elements within arrays.",
    "expressions": [
      "jq --argfile a a.json --argfile b b.json -n 'def post_recurse(f): def r: (f | select(. != null) | r), .; r; def post_recurse: post_recurse(.[]?); ($a | (post_recurse | arrays) |= sort) as $a | ($b | (post_recurse | arrays) |= sort) as $b | $a == $b'",
      "def walk(f):\n  . as $in\n  | if type == \"object\" then\n      reduce keys[] as $key\n        ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\n  elif type == \"array\" then map( walk(f) ) | f\n  else f\n  end;\n\ndef normalize: walk(if type == \"array\" then sort else . end);\n\ndef equiv(x): normalize == (x | normalize);"
    ],
    "data": [
      {
        "input": {
          "A": {
            "People": [
              "John",
              "Bryan"
            ],
            "City": "Boston",
            "State": "MA"
          },
          "B": {
            "People": [
              "Bryan",
              "John"
            ],
            "State": "MA",
            "City": "Boston"
          }
        },
        "output": true
      },
      {
        "input": {
          "A": {
            "People": [
              "John",
              "Bryan",
              "Carla"
            ],
            "City": "Boston",
            "State": "MA"
          },
          "C": {
            "People": [
              "Bryan",
              "John"
            ],
            "State": "MA",
            "City": "Boston"
          }
        },
        "output": false
      }
    ],
    "identifier": 31930041
  },
  {
    "context": [
      "And I want to replace `user -> songs` to 40 and print the whole file, so that I get:",
      "How can I do this with [`jq`](https://stedolan.github.io/jq/#) (using `jq version 1.3`)?",
      "Use the assignment operator:",
      "    jq '.user.songs = 40' myfile"
    ],
    "utterance": "Set the 'songs' field of the 'user' object to 40 and output the entire data structure.",
    "expressions": [
      ".user.songs = 40"
    ],
    "data": [
      {
        "input": {
          "user": {
            "name": "Manu",
            "songs": 30
          },
          "admin": {
            "name": "Chao",
            "songs": 50
          }
        },
        "output": {
          "user": {
            "name": "Manu",
            "songs": 40
          },
          "admin": {
            "name": "Chao",
            "songs": 50
          }
        }
      }
    ],
    "identifier": 32522064
  },
  {
    "context": [
      "Is there a way I could use jq to find all paths that hold a value that matches a given criteria?",
      "For example, given the following JSON, I&#39;d like to return all paths where the value of &quot;age&quot; is &gt;35, regardless of the depth of the structure containing that field:",
      "So the execution would yield something like:\r\n\r\n    [\r\n      [\"springfield\", \"homer\"],\r\n      [\"shelbyville\", \"zone2\", \"mark\"],\r\n      [\"homeless2\"]\r\n    ]",
      "This should do the trick:\r\n\r\n    [paths(.age?>35)]"
    ],
    "utterance": "List all paths to objects where the field age exists and its value is greater than 35, regardless of depth.",
    "expressions": [
      "[paths(.age? > 35)]",
      "(paths | select(.[length-1] ==\"age\")) as $path | if (getpath($path) > 35) then $path else empty end"
    ],
    "data": [
      {
        "input": {
          "springfield": {
            "marge": {
              "age": 30
            },
            "homer": {
              "age": 40,
              "job": "xyz"
            }
          },
          "shelbyville": {
            "zone1": {
              "john": {
                "age": 10
              }
            },
            "zone2": {
              "mark": {
                "age": 50
              }
            }
          },
          "homeless1": {
            "age": 25
          },
          "homeless2": {
            "age": 60
          }
        },
        "output": [
          [
            "springfield",
            "homer"
          ],
          [
            "shelbyville",
            "zone2",
            "mark"
          ],
          [
            "homeless2"
          ]
        ]
      }
    ],
    "identifier": 32470524
  },
  {
    "context": [
      "I'm trying to produce:\r\n\r\n    {\r\n      \"StatusInfos\": null,\r\n      \"ReadReplicaSourceDBInstanceIdentifier\": null,\r\n      \"DBInstanceIdentifier\": \"test1\"\r\n    }\r\n    {\r\n      \"StatusInfos\": null,\r\n      \"ReadReplicaSourceDBInstanceIdentifier\": null,\r\n      \"DBInstanceIdentifier\": \"test2\"\r\n    }\r\n    {\r\n      \"RepStatus\": \"replicating\",\r\n      \"RepStatusType\": \"read replication\",\r\n      \"ReadReplicaSourceDBInstanceIdentifier\": \"test1\",\r\n      \"DBInstanceIdentifier\": \"read-rep-test1\"\r\n    }\r\n    {\r\n      \"RepStatus\": \"replicating\",\r\n      \"RepStatusType\": \"read replication\",\r\n      \"ReadReplicaSourceDBInstanceIdentifier\": \"test2\",\r\n      \"DBInstanceIdentifier\": \"read-rep-test2\"\r\n    }",
      "An `if` processing all entities but leaving the ones with `StatusInfos: null` intact would do as in:\r\n\r\n    jq -r 'if .StatusInfos != null then {\r\n        RepStatus: .StatusInfos[0].Status,\r\n        RepStatusType: .StatusInfos[0].StatusType,\r\n        ReadReplicaSourceDBInstanceIdentifier,\r\n        DBInstanceIdentifier } else . end'",
      "or, when required to deal with multiple StatusInfo's:\r\n\r\n    jq -r 'if .StatusInfos != null then \r\n            .StatusInfos[] as $info | {\r\n                 RepStatus: $info.Status,\r\n                 RepStatusType: $info.StatusType,\r\n                 ReadReplicaSourceDBInstanceIdentifier,\r\n                 DBInstanceIdentifier }\r\n        else . end'"
    ],
    "utterance": "For each object, if StatusInfos is not null, output RepStatus and RepStatusType from the first StatusInfos element and include ReadReplicaSourceDBInstanceIdentifier and DBInstanceIdentifier; otherwise, output the object unchanged.",
    "expressions": [
      "if .StatusInfos != null then {\n  RepStatus: .StatusInfos[0].Status,\n  RepStatusType: .StatusInfos[0].StatusType,\n  ReadReplicaSourceDBInstanceIdentifier,\n  DBInstanceIdentifier\n} else . end",
      "if .StatusInfos != null then \n  .StatusInfos[] as $info | {\n    RepStatus: $info.Status,\n    RepStatusType: $info.StatusType,\n    ReadReplicaSourceDBInstanceIdentifier,\n    DBInstanceIdentifier\n  }\nelse . end"
    ],
    "data": [
      {
        "input": [
          {
            "StatusInfos": null,
            "ReadReplicaSourceDBInstanceIdentifier": null,
            "DBInstanceIdentifier": "test1"
          },
          {
            "StatusInfos": null,
            "ReadReplicaSourceDBInstanceIdentifier": null,
            "DBInstanceIdentifier": "test2"
          },
          {
            "StatusInfos": [
              {
                "Status": "replicating",
                "StatusType": "read replication",
                "Normal": true
              }
            ],
            "ReadReplicaSourceDBInstanceIdentifier": "test1",
            "DBInstanceIdentifier": "read-rep-test1"
          },
          {
            "StatusInfos": [
              {
                "Status": "replicating",
                "StatusType": "read replication",
                "Normal": true
              }
            ],
            "ReadReplicaSourceDBInstanceIdentifier": "test2",
            "DBInstanceIdentifier": "read-rep-test2"
          }
        ],
        "output": [
          {
            "StatusInfos": null,
            "ReadReplicaSourceDBInstanceIdentifier": null,
            "DBInstanceIdentifier": "test1"
          },
          {
            "StatusInfos": null,
            "ReadReplicaSourceDBInstanceIdentifier": null,
            "DBInstanceIdentifier": "test2"
          },
          {
            "RepStatus": "replicating",
            "RepStatusType": "read replication",
            "ReadReplicaSourceDBInstanceIdentifier": "test1",
            "DBInstanceIdentifier": "read-rep-test1"
          },
          {
            "RepStatus": "replicating",
            "RepStatusType": "read replication",
            "ReadReplicaSourceDBInstanceIdentifier": "test2",
            "DBInstanceIdentifier": "read-rep-test2"
          }
        ]
      }
    ],
    "identifier": 32381023
  },
  {
    "context": [
      "Following command is working, it print value from json:\r\n``type config.json | \"jq-win64.exe\" .path.editor``",
      "config.json content:\r\n``{ \"path\" : { \"editor\" : \"...value...\" } }``",
      "I tried this, but is not working:\r\n``set editorPath = type config.json | \"jq-win64.exe\" -r .path.editor``",
      "for /f \"delims=\" %%I in ('jq -n -r \"\\\"123\\\"\"') do set A=%%I",
      "for /f \"delims=\" %%I in ('cscript /nologo /e:JScript \"%~f0\" \"%JSONfile%\"') do set \"%%~I\""
    ],
    "utterance": "Extract the value at the path 'path.editor' from a configuration file and assign it to a Windows batch variable.",
    "expressions": [
      "for /f \"delims=\" %%I in ('type config.json | jq-win64.exe -r .path.editor') do set \"editorPath=%%I\""
    ],
    "data": [
      {
        "input": {
          "path": {
            "editor": "...value..."
          }
        },
        "output": "...value..."
      }
    ],
    "identifier": 32584952
  },
  {
    "context": [
      "This is what I want as an output:\n\n    \"http://example.com/pop\"\n    \"Pop\"\n    \"http://example.com/rock\"\n    \"Rock\"\n\nSo I need jq to replace `.channels[].id` with `.links[].streams[0].url` based on `.links[].id`",
      "The question is, how do I add `.channels[].name` to it?",
      ".channels[] as $channel\n| $channel.name,\n  (.links[] | select(.id == $channel.id) | .streams[0].url)",
      "(\n  reduce .links[] as $l (\n    {};\n    setpath([ $l.id|tostring ]; [$l.streams[].url])\n  )\n) as $urls\n| .channels[]\n| $urls[ .id|tostring ][], .name"
    ],
    "utterance": "For each channel, output the associated stream URLs (by matching channel id and link id) followed by the channel name, in the same order as channels appear.",
    "expressions": [
      ".channels[] as $channel | (.links[] | select(.id == $channel.id) | .streams[0].url), $channel.name",
      "(\n  reduce .links[] as $l (\n    {};\n    setpath([ $l.id|tostring ]; [$l.streams[].url])\n  )\n) as $urls\n| .channels[]\n| $urls[ .id|tostring ][], .name"
    ],
    "data": [
      {
        "input": {
          "channels": [
            {
              "id": 1,
              "name": "Pop"
            },
            {
              "id": 2,
              "name": "Rock"
            }
          ],
          "links": [
            {
              "id": 2,
              "streams": [
                {
                  "url": "http://example.com/rock"
                }
              ]
            },
            {
              "id": 1,
              "streams": [
                {
                  "url": "http://example.com/pop"
                }
              ]
            }
          ]
        },
        "output": [
          "http://example.com/pop",
          "Pop",
          "http://example.com/rock",
          "Rock"
        ]
      },
      {
        "input": {
          "channels": [
            {
              "id": 1,
              "name": "Pop"
            },
            {
              "id": 2,
              "name": "Rock"
            }
          ],
          "links": [
            {
              "id": 2,
              "streams": [
                {
                  "url": "http://example.com/rock"
                },
                {
                  "url": "http://example.com/hardrock"
                }
              ]
            },
            {
              "id": 1,
              "streams": [
                {
                  "url": "http://example.com/pop"
                }
              ]
            }
          ]
        },
        "output": [
          "http://example.com/pop",
          "Pop",
          "http://example.com/rock",
          "http://example.com/hardrock",
          "Rock"
        ]
      }
    ],
    "identifier": 32534990
  },
  {
    "context": [
      "I want to alter object `interpreterSettings.2B263G4Z1.properties` by adding several key-values, like `\"spark.executor.instances\": \"16\"`.",
      "So far I only managed to fully replace this object, not add new properties",
      "The following works using jq 1.4 or jq 1.5 with a Mac/Linux shell:",
      "jq  '.interpreterSettings.\"2B188AQ5T\".properties.\"spark.executor.instances\" = \"16\" ' test.json",
      "p.s. You were on the right track - try replacing *=* with *+=*"
    ],
    "utterance": "Add the key-value pair \"spark.executor.instances\": \"16\" to interpreterSettings.2B188AQ5T.properties while preserving its other properties.",
    "expressions": [
      ".interpreterSettings.\"2B188AQ5T\".properties.\"spark.executor.instances\" = \"16\"",
      ".interpreterSettings.\"2B188AQ5T\".properties += {\"spark.executor.instances\": \"16\"}"
    ],
    "data": [
      {
        "input": {
          "interpreterSettings": {
            "2B263G4Z1": {
              "id": "2B263G4Z1",
              "name": "sh",
              "group": "sh",
              "properties": {}
            },
            "2B188AQ5T": {
              "id": "2B188AQ5T",
              "name": "spark",
              "group": "spark",
              "properties": {
                "spark.cores.max": "",
                "spark.yarn.jar": "",
                "master": "yarn-client",
                "zeppelin.spark.maxResult": "1000",
                "zeppelin.dep.localrepo": "local-repo",
                "spark.app.name": "Zeppelin",
                "spark.executor.memory": "2560M",
                "zeppelin.spark.useHiveContext": "true",
                "spark.home": "/usr/lib/spark",
                "zeppelin.spark.concurrentSQL": "false",
                "args": "",
                "zeppelin.pyspark.python": "python"
              }
            }
          },
          "interpreterBindings": {
            "2AXUMXYK4": [
              "2B188AQ5T",
              "2AY8SDMRU"
            ]
          }
        },
        "output": {
          "interpreterSettings": {
            "2B263G4Z1": {
              "id": "2B263G4Z1",
              "name": "sh",
              "group": "sh",
              "properties": {}
            },
            "2B188AQ5T": {
              "id": "2B188AQ5T",
              "name": "spark",
              "group": "spark",
              "properties": {
                "spark.cores.max": "",
                "spark.yarn.jar": "",
                "master": "yarn-client",
                "zeppelin.spark.maxResult": "1000",
                "zeppelin.dep.localrepo": "local-repo",
                "spark.app.name": "Zeppelin",
                "spark.executor.memory": "2560M",
                "zeppelin.spark.useHiveContext": "true",
                "spark.home": "/usr/lib/spark",
                "zeppelin.spark.concurrentSQL": "false",
                "args": "",
                "zeppelin.pyspark.python": "python",
                "spark.executor.instances": "16"
              }
            }
          },
          "interpreterBindings": {
            "2AXUMXYK4": [
              "2B188AQ5T",
              "2AY8SDMRU"
            ]
          }
        }
      }
    ],
    "identifier": 32591769
  }
]