JQLite - The query language for JSON
from jay0072007@programming.dev to programming@programming.dev on 11 May 06:15
https://programming.dev/post/30128028
from jay0072007@programming.dev to programming@programming.dev on 11 May 06:15
https://programming.dev/post/30128028
Created a simple query language for JSON data.
Features:
- Basic query selection
- Fallback Mechanism
- Wildcard support
- Array Slices
- Multiple Key Selection
- Key Omission
- Single Key Omission
- Functions
- Comparison Operators
- Conditions
- Configurable
Here’s an example to get the list of adult friends:
$.friends[?(@.age >= 18)]
Runs in browsers, and Node.js
Documentation site: jqlite.vercel.app
GitHub: github.com/Jay-Karia/jqlite
NPM Package: www.npmjs.com/package/jqlite-ts
⭐ Leaving a star on GitHub is much appreciated!
#programming
threaded - newest
You might want to look into using some form of parameterized queries.
Thanks for your suggestion! It’s definitely something I’ll look into.
github.com/bazaarvoice/jolt
That’s a great project! JQLite is mainly focused on query-style approach. Also it’s a hobby project for learning parsers and stuff.
jqlang.org
I’ve been using that for all my JSON extraction and processing needs. Let me automate a bunch of my builds for JS stuff for FoundryVTT gitlab.com/foundry-azzurite/pings/-/…/build.sh
Thanks for sharing the project! JQLite is aimed to run in browsers and node, but will definitely take inspiration from “jq”.
I just kinda wonder why when you’re in a browser or node, you wouldn’t just do
why learn another language when you already literally got the language to process JavaScript Object Notation right there.
100% agreed. It’s just a learning/hobby project, to know more about parsers, and how languages work. Some of the features like Wildcard, Multiple key selection/omission comes handy, and might add more features like that.
Totally fair. Sounds fun :)
At first I thought that it is like SQLite, but for JSON, not just “JQ-lite”.
Speaking of JSON and queries, it is worth to mention DuckDB’s JSON features. This allows you to use actual SQL to query JSON.
Here is example of a DuckDB analogue of
$.orders[?(@.status.#equals(‘delivered’))][*].items
from JQLite documentation:That’s actually great to query JSON with SQL! But as you can see the example from DuckDB is quite complex and unreadable as well.
And I have made this project for learning purpose and to challenge myself.
However, Thanks for sharing the project.
But what about all those hours I spent torturing myself learning
jq
’s filter syntax, andjmespath
?JQLite is not any replacement for existing tools, it’s just a learning/hobby project.
Which animal’s @$$ does this whip?