Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/stedolan/jq
Command-line JSON processor
https://github.com/stedolan/jq
jq
Last synced: about 2 months ago
JSON representation
Command-line JSON processor
- Host: GitHub
- URL: https://github.com/stedolan/jq
- Owner: jqlang
- License: other
- Created: 2012-07-18T19:57:25.000Z (over 12 years ago)
- Default Branch: master
- Last Pushed: 2024-04-12T19:52:58.000Z (8 months ago)
- Last Synced: 2024-04-14T13:02:01.634Z (8 months ago)
- Topics: jq
- Language: C
- Homepage: https://jqlang.github.io/jq/
- Size: 8.99 MB
- Stars: 28,929
- Watchers: 324
- Forks: 1,519
- Open Issues: 431
-
Metadata Files:
- Readme: README.md
- Changelog: ChangeLog
- License: COPYING
- Security: SECURITY.md
- Authors: AUTHORS
Awesome Lists containing this project
- fucking-awesome-cli-apps - jq - JSON processor. (Data Manipulation / Processors)
- awesome-devtools - jq - A parser for all things json ![ossoft][oss] (Command line - Linux / Learning resources)
- starred-awesome - jq - Command-line JSON processor (C)
- awesome-github - json格式化
- awesome - jq - line JSON processor. (Tools)
- awesome-starred - jq - Command-line JSON processor (C)
- awesome-cli-apps - jq - JSON processor. (Data Manipulation / Processors)
README
# jq
`jq` is a lightweight and flexible command-line JSON processor akin to `sed`,`awk`,`grep`, and friends for JSON data. It's written in portable C and has zero runtime dependencies, allowing you to easily slice, filter, map, and transform structured data.
## Documentation
- **Official Documentation**: [jqlang.github.io/jq](https://jqlang.github.io/jq)
- **Try jq Online**: [jqplay.org](https://jqplay.org)## Installation
### Prebuilt Binaries
Download the latest releases from the [GitHub release page](https://github.com/jqlang/jq/releases).
### Docker Image
Pull the [jq image](https://github.com/jqlang/jq/pkgs/container/jq) to start quickly with Docker.
#### Run with Docker
##### Example: Extracting the version from a `package.json` file
```bash
docker run --rm -i ghcr.io/jqlang/jq:latest < package.json '.version'
```
##### Example: Extracting the version from a `package.json` file with a mounted volume
```bash
docker run --rm -i -v "$PWD:$PWD" -w "$PWD" ghcr.io/jqlang/jq:latest '.version' package.json
```### Building from source
#### Dependencies
- libtool
- make
- automake
- autoconf#### Instructions
```console
git submodule update --init # if building from git to get oniguruma
autoreconf -i # if building from git
./configure --with-oniguruma=builtin
make clean # if upgrading from a version previously built from source
make -j8
make check
sudo make install
```Build a statically linked version:
```console
make LDFLAGS=-all-static
```If you're not using the latest git version but instead building a released tarball (available on the release page), skip the `autoreconf` step, and flex or bison won't be needed.
##### Cross-Compilation
For details on cross-compilation, check out the [GitHub Actions file](.github/workflows/ci.yml) and the [cross-compilation wiki page](https://github.com/jqlang/jq/wiki/Cross-compilation).
## Community & Support
- Questions & Help: [Stack Overflow (jq tag)](https://stackoverflow.com/questions/tagged/jq)
- Chat & Community: [Join us on Discord](https://discord.gg/yg6yjNmgAC)
- Wiki & Advanced Topics: [Explore the Wiki](https://github.com/jqlang/jq/wiki)## License
`jq` is released under the [MIT License](COPYING). `jq`'s documentation is
licensed under the [Creative Commons CC BY 3.0](COPYING).
`jq` uses parts of the open source C library "decNumber", which is distributed
under [ICU License](COPYING)