1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
|
### jsoncons::jsonpath::jsonpath_expression::select
```cpp
std::vector<basic_json_location<char_type>> select_paths(const_reference root,
result_options options = result_options::nodups | result_options::sort); (1) (since 0.172.0)
```
(1) Evaluates the root value against the compiled JSONPath expression and returns the
locations of the selected values in the root value.
#### Parameters
<table>
<tr>
<td>root</td>
<td>Root JSON value</td>
</tr>
<tr>
<td><code>options</code> (since 0.161.0)</td>
<td>Result options, a bitmask of type <a href="../result_options.md">result_options</></td>
</tr>
</table>
### Examples
#### Return locations of selected values
```cpp
#include <jsoncons/json.hpp>
#include <jsoncons_ext/jsonpath/jsonpath.hpp>
using json = jsoncons::json;
namespace jsonpath = jsoncons::jsonpath;
int main()
{
auto expr = jsoncons::jsonpath::make_expression<json>("$.books[*]");
std::ifstream is(/*path_to_books_file*/);
json doc = json::parse(is);
std::vector<jsonpath::json_location> paths = expr.select_paths(doc);
for (const auto& path : paths)
{
std::cout << jsonpath::to_string(path) << "\n";
}
}
```
Output:
```
[
$['books'][0]
$['books'][1]
$['books'][2]
$['books'][3]
]
```
|