Query JSON is a Obsidian plugin designed to simplify the process of querying and extracting data from JSON objects. By incorporating a user-friendly syntax, the plugin enables you to retrieve specific information from JSON data stored within your notes or external files.
To utilize QJSON, simply include the plugin's syntax within your note, encapsulating the JSON data or providing a file reference. Below is an example of the syntax:
```qjson
#qj-id: 23
#qj-file: data.json
#qj-hide-id
#qj-show-json
```
Caution
If your JSON files is considerably large it may slow down the rendering process. In those cases is better to query the file directly.
Then, you can query the data using the following syntax:
@23>store.books.0.author;
Crafting queries with QJSON is straightforward, allowing you to refine and extract specific information tailored to your needs. For instance, consider the following JSON:
{
"store": {
"books": [
{
"author": "John Doe",
"title": "The Book"
}
]
}
}
To retrieve the author of the first book within the store, use the following query:
@23>store.books.0.author;
23
: represents the object identifier (ID)store.books.0.author
: specifies the path to the desired data
Furthermore, QJSON extends its functionality to external JSON files. For example, if you possess a file named data.json
containing the same JSON data as above, you can use the following query:
@data.json>store.books.0.author;
It's also posible to query the file directly using the #qj-query
flag:
```qjson
#qj-id: 24
#qj-file: data.json
#qj-show-json
#qj-hide-id
#qj-query: pageProps.heroData[win_rate >= 55 && role == Mage]
```
If you want to get all the elements of an array you can use the *
wildcard:
```qjson
#qj-id: 24
#qj-file: data.json
#qj-show-json
#qj-hide-id
#qj-query: pageProps.heroData[*]
```
Query JSON supports various flags to enhance customization and functionality:
This flag denotes the JSON object identifier. It must be unique and numeric.
This flag suppresses the display of the identifier after rendering.
Short for "id description," this flag provides a way to describe the JSON object. It is particularly useful for identifying the purpose of the object. The default value is »»» QJSON «««
.
This flag allows you to display the JSON within the rendered output. By default is hidden.
If provided, this flag specifies the file path containing the JSON data. In its absence, the plugin scans for JSON data within the code block.
This flag allows you to query the JSON file directly from your codeblock. The query syntax must be inside brackets []
. The supported operators are:
- Logical operators:
&&
,||
- Comparison operators:
==
,!=
,>
,>=
,<
,<=
Example:
```qjson
#qj-id: 24
#qj-file: data.json
#qj-show-json
#qj-hide-id
#qj-query: pageProps.heroData[win_rate >= 55 && role == Mage]
```
Note
The #qj-show-json
flag is mandatory when using the #qj-query
flag.
This flag allows you to format the output of the JSON data. The supported values are:
list
: displays the data in a list formattable
: displays the data in a table formatimg
: displays the data as an image
Add column formatting:
> #qj-format: table[<flags>:<field or template>:<link field>=<custom name>,<flags>:<field or template>:<link field>=<custom name>,...]
For example:
> #qj-format: table[h:title=Name,:value,b:test=Value 2]
with a template:
> #qj-format: table[:"Custom {value} of {test}"=Something]
The following flags are implemented:
b: display bold
h: header column/field (only allowed in the first entry)
l: create a link - a second field name must be provided, which contains the link URL
c: if a list of values is the content, use comma separation for the entries
n: if a list of values is the content, use new-line/
separation for the entries
If you encounter any issues or have suggestions for improvement, please feel free to contribute to the project. Your feedback is invaluable in enhancing the plugin's functionality and user experience.