DeepJSON is a lightweight module for retrieving values from a JSON object based on a given path. It provides a simple and intuitive way to navigate nested JSON structures and extract specific values.
-
Add the dependency to your
shard.yml
:dependencies: deep-json: github: KirillFurtikov/deep-json
-
Run
shards install
require "deep-json"
json = JSON.parse(File.read("example.json"))
{
"glossary": {
"title": "example glossary",
"size": [
5,
"asd",
null
],
"GlossDiv": {
"title\"s": "S",
"id": 5000000000000,
"null": null,
"bool": true,
"GlossList": {
"Gloss.Entry": {
"ID": "SGML",
"Sort As": "SGML",
"Gloss-Term": "Standard Generalized Markup Language",
"Acronym": "SGML",
"Abbrev": "ISO 8879:1986",
"GlossDef": {
"para": "A meta-markup language, used to create markup languages such as DocBook.",
"GlossSeeAlso": [
"GML",
"XML"
]
},
"GlossSee": "markup"
}
}
}
}
}
# Int
DeepJSON.get("glossary.GlossDiv.id", json) # => 5000000000000
# Bool
DeepJSON.get("glossary.GlossDiv.bool", json) # => true
# add # to get size of array
DeepJSON.get("glossary.size.#", json) # => 3
# allow to use escaping in key
DeepJSON.get("glossary.GlossDiv.title\"s", json) # => "S"
# If key has a dot, just escape it
DeepJSON.get("glossary.GlossDiv.GlossList.Gloss\\.Entry.ID", json) # => "SGML"
- Fork it (https://github.com/KirillFurtikov/deep-json/fork)
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request
- Kirill Furtikov - creator and maintainer