Descendants Selector (..)

Descendants Selector (..myKey)

The .. selector acts on arrays and objects.

This selector applies to the context using the form ..myKey, and it retrieves the values of all matching key-value pairs in the sub-tree under the selected context. Regardless of the hierarchical structure of the fields, the output is returned at the same level.

In this example, all of the fields that match the key name are placed in a list called names regardless of their cardinality in the tree of the input data.

The descendants selector (..) is the perfect tool to use when you need the values for a certain key no matter where they appear in a piece of data. Here’s an example:


Input:

{

“echo”: {“value”: “Hello there!”},

“sequence”: [

{

“echo”: “Getting details…”,

“try”: {

“curl”: “somelocation.com”,

“echo”: “Success!”

}

},

{

“grep”: “Success”

}

]

}

DW Script:

%dw 2.0

output json

payload..echo

Output:

[{ “value”: “Hello there!”}, “Getting details…”, “Success!”]


This selector can be combined with the multi value selector to also find repeated keys.

DataWeave Script:

%dw 2.0

output application/json

{ names: payload.people..name }

Input JSON Payload:

{

“people”: {

“person”: {

“name”: “Nial”,

“address”: {

“street”: {

“name”: “Italia”,

“number”: 2164

},

“area”: {

“zone”: “San Isidro”,

“name”: “Martinez”

}

}

}

}

}

Output JSON:

{

“names”: [

“Nial”,

“Italia”,

“Martinez”

]

}

Follow Me

If you like my post please follow me to read my latest post on programming and technology.

Instagram

Facebook

Recent Posts

Generate Parenthesis | Intuition + Code | Recursion Tree | Backtracking | Java

Problem Statement: Given n pairs of parentheses, write a function to generate all combinations of well-formed parentheses. Example…

2 months ago

Square Root of Integer

Given an integer A. Compute and return the square root of A. If A is…

1 year ago

Build Array From Permutation

Given a zero-based permutation nums (0-indexed), build an array ans of the same length where…

1 year ago

DSA: Heap

A heap is a specialized tree-based data structure that satisfies the heap property. It is…

1 year ago

DSA: Trie

What is a Trie in DSA? A trie, often known as a prefix tree, is…

1 year ago

Trees: Lowest Common Ancestor

What is the Lowest Common Ancestor? In a tree, the lowest common ancestor (LCA) of…

1 year ago