{"id":41225903,"url":"https://github.com/ahmet2mir/wildq","last_synced_at":"2026-01-23T00:35:53.915Z","repository":{"id":82115364,"uuid":"267061786","full_name":"ahmet2mir/wildq","owner":"ahmet2mir","description":"Command-line TOML/JSON/INI/YAML/XML/HCL processor using jq c bindings","archived":false,"fork":false,"pushed_at":"2025-02-12T10:03:37.000Z","size":100,"stargazers_count":29,"open_issues_count":1,"forks_count":4,"subscribers_count":1,"default_branch":"master","last_synced_at":"2025-09-15T17:15:45.256Z","etag":null,"topics":["cli","hcl","jq","json","productivity","terminal","toml","tool","xml","yaml"],"latest_commit_sha":null,"homepage":"","language":"Python","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"apache-2.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/ahmet2mir.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2020-05-26T14:14:11.000Z","updated_at":"2025-02-19T23:35:32.000Z","dependencies_parsed_at":"2023-03-15T01:32:40.209Z","dependency_job_id":null,"html_url":"https://github.com/ahmet2mir/wildq","commit_stats":null,"previous_names":[],"tags_count":11,"template":false,"template_full_name":null,"purl":"pkg:github/ahmet2mir/wildq","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ahmet2mir%2Fwildq","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ahmet2mir%2Fwildq/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ahmet2mir%2Fwildq/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ahmet2mir%2Fwildq/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/ahmet2mir","download_url":"https://codeload.github.com/ahmet2mir/wildq/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ahmet2mir%2Fwildq/sbom","scorecard":{"id":172206,"data":{"date":"2025-08-11","repo":{"name":"github.com/ahmet2mir/wildq","commit":"c6e9535829cf6b4d0c2df2de5f8938d249602d08"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":2.3,"checks":[{"name":"Packaging","score":-1,"reason":"packaging workflow not detected","details":["Warn: no GitHub/GitLab publishing workflow detected."],"documentation":{"short":"Determines if the project is published as a package that others can easily download, install, easily update, and uninstall.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#packaging"}},{"name":"Maintained","score":0,"reason":"0 commit(s) and 0 issue activity found in the last 90 days -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#maintained"}},{"name":"Binary-Artifacts","score":10,"reason":"no binaries found in the repo","details":null,"documentation":{"short":"Determines if the project has generated executable (binary) artifacts in the source repository.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#binary-artifacts"}},{"name":"Code-Review","score":0,"reason":"Found 0/30 approved changesets -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project requires human code review before pull requests (aka merge requests) are merged.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#code-review"}},{"name":"Dangerous-Workflow","score":10,"reason":"no dangerous workflow patterns detected","details":null,"documentation":{"short":"Determines if the project's GitHub Action workflows avoid dangerous patterns.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#dangerous-workflow"}},{"name":"Pinned-Dependencies","score":0,"reason":"dependency not pinned by hash detected -- score normalized to 0","details":["Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/publish.yml:20: update your workflow using https://app.stepsecurity.io/secureworkflow/ahmet2mir/wildq/publish.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/publish.yml:25: update your workflow using https://app.stepsecurity.io/secureworkflow/ahmet2mir/wildq/publish.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/publish.yml:36: update your workflow using https://app.stepsecurity.io/secureworkflow/ahmet2mir/wildq/publish.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/publish.yml:49: update your workflow using https://app.stepsecurity.io/secureworkflow/ahmet2mir/wildq/publish.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/publish.yml:59: update your workflow using https://app.stepsecurity.io/secureworkflow/ahmet2mir/wildq/publish.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/unit-tests.yml:19: update your workflow using https://app.stepsecurity.io/secureworkflow/ahmet2mir/wildq/unit-tests.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/unit-tests.yml:21: update your workflow using https://app.stepsecurity.io/secureworkflow/ahmet2mir/wildq/unit-tests.yml/master?enable=pin","Info:   0 out of   4 GitHub-owned GitHubAction dependencies pinned","Info:   0 out of   3 third-party GitHubAction dependencies pinned"],"documentation":{"short":"Determines if the project has declared and pinned the dependencies of its build process.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#pinned-dependencies"}},{"name":"SAST","score":0,"reason":"no SAST tool detected","details":["Warn: no pull requests merged into dev branch"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#sast"}},{"name":"Token-Permissions","score":0,"reason":"detected GitHub workflow tokens with excessive permissions","details":["Warn: no topLevel permission defined: .github/workflows/publish.yml:1","Warn: no topLevel permission defined: .github/workflows/unit-tests.yml:1","Info: no jobLevel write permissions found"],"documentation":{"short":"Determines if the project's workflows follow the principle of least privilege.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#token-permissions"}},{"name":"CII-Best-Practices","score":0,"reason":"no effort to earn an OpenSSF best practices badge detected","details":null,"documentation":{"short":"Determines if the project has an OpenSSF (formerly CII) Best Practices Badge.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#cii-best-practices"}},{"name":"Security-Policy","score":0,"reason":"security policy file not detected","details":["Warn: no security policy file detected","Warn: no security file to analyze","Warn: no security file to analyze","Warn: no security file to analyze"],"documentation":{"short":"Determines if the project has published a security policy.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#security-policy"}},{"name":"Fuzzing","score":0,"reason":"project is not fuzzed","details":["Warn: no fuzzer integrations found"],"documentation":{"short":"Determines if the project uses fuzzing.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#fuzzing"}},{"name":"License","score":10,"reason":"license file detected","details":["Info: project has a license file: LICENSE:0","Info: FSF or OSI recognized license: Apache License 2.0: LICENSE:0"],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#license"}},{"name":"Branch-Protection","score":0,"reason":"branch protection not enabled on development/release branches","details":["Warn: branch protection not enabled for branch 'master'"],"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#branch-protection"}},{"name":"Signed-Releases","score":0,"reason":"Project has not signed or included provenance with any releases.","details":["Warn: release artifact v1.1.11 not signed: https://api.github.com/repos/ahmet2mir/wildq/releases/59316198","Warn: release artifact v1.1.10 not signed: https://api.github.com/repos/ahmet2mir/wildq/releases/41459617","Warn: release artifact v1.1.8 not signed: https://api.github.com/repos/ahmet2mir/wildq/releases/33151648","Warn: release artifact v1.1.7 not signed: https://api.github.com/repos/ahmet2mir/wildq/releases/33023670","Warn: release artifact v1.1.6 not signed: https://api.github.com/repos/ahmet2mir/wildq/releases/33023503","Warn: release artifact v1.1.11 does not have provenance: https://api.github.com/repos/ahmet2mir/wildq/releases/59316198","Warn: release artifact v1.1.10 does not have provenance: https://api.github.com/repos/ahmet2mir/wildq/releases/41459617","Warn: release artifact v1.1.8 does not have provenance: https://api.github.com/repos/ahmet2mir/wildq/releases/33151648","Warn: release artifact v1.1.7 does not have provenance: https://api.github.com/repos/ahmet2mir/wildq/releases/33023670","Warn: release artifact v1.1.6 does not have provenance: https://api.github.com/repos/ahmet2mir/wildq/releases/33023503"],"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#signed-releases"}},{"name":"Vulnerabilities","score":0,"reason":"26 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: PYSEC-2021-421 / GHSA-h4m5-qpfp-3mpv","Warn: Project is vulnerable to: PYSEC-2024-48 / GHSA-fj7x-q9j7-g6q6","Warn: Project is vulnerable to: PYSEC-2022-42986 / GHSA-43fp-rhv2-5gv8","Warn: Project is vulnerable to: PYSEC-2023-135 / GHSA-xqr8-7jwr-rhp7","Warn: Project is vulnerable to: PYSEC-2022-42991 / GHSA-v3c5-jqr6-7qm8","Warn: Project is vulnerable to: PYSEC-2024-4 / GHSA-2mqj-m65w-jghx","Warn: Project is vulnerable to: PYSEC-2023-165 / GHSA-cwvm-v4w8-q58c","Warn: Project is vulnerable to: PYSEC-2022-42992 / GHSA-hcpj-qp55-gfph","Warn: Project is vulnerable to: PYSEC-2023-137 / GHSA-pr76-5cm5-w9cj","Warn: Project is vulnerable to: PYSEC-2023-161 / GHSA-wfm5-v35h-vwf4","Warn: Project is vulnerable to: PYSEC-2024-60 / GHSA-jjg7-2v4v-x38h","Warn: Project is vulnerable to: GHSA-cpwx-vrp4-4pq7","Warn: Project is vulnerable to: GHSA-h5c8-rqwp-cp95","Warn: Project is vulnerable to: GHSA-h75v-3vvj-5mfj","Warn: Project is vulnerable to: GHSA-q2x7-8rv6-6q7h","Warn: Project is vulnerable to: PYSEC-2023-117 / GHSA-mrwq-x4v8-fh7p","Warn: Project is vulnerable to: PYSEC-2023-292 / GHSA-9w2p-rh8c-v9g5","Warn: Project is vulnerable to: GHSA-9hjg-9r4m-mvj7","Warn: Project is vulnerable to: GHSA-9wx4-h78v-vm56","Warn: Project is vulnerable to: PYSEC-2023-74 / GHSA-j8r2-6x86-q33q","Warn: Project is vulnerable to: GHSA-34jh-p97f-mpxf","Warn: Project is vulnerable to: PYSEC-2023-212 / GHSA-g4mx-q9vg-27p4","Warn: Project is vulnerable to: GHSA-pq67-6m6q-mj2v","Warn: Project is vulnerable to: PYSEC-2021-108 / GHSA-q2q7-5pp4-w6pg","Warn: Project is vulnerable to: PYSEC-2023-192 / GHSA-v845-jxx5-vc9f","Warn: Project is vulnerable to: GHSA-jfmj-5v4g-7637"],"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#vulnerabilities"}}]},"last_synced_at":"2025-08-16T16:53:14.492Z","repository_id":82115364,"created_at":"2025-08-16T16:53:14.492Z","updated_at":"2025-08-16T16:53:14.492Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":28676145,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-01-22T20:48:19.482Z","status":"ssl_error","status_checked_at":"2026-01-22T20:48:14.968Z","response_time":144,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.5:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["cli","hcl","jq","json","productivity","terminal","toml","tool","xml","yaml"],"created_at":"2026-01-23T00:35:53.630Z","updated_at":"2026-01-23T00:35:53.904Z","avatar_url":"https://github.com/ahmet2mir.png","language":"Python","funding_links":[],"categories":[],"sub_categories":[],"readme":"# wildq - Command-line TOML/JSON/INI/YAML/XML/HCL processor using jq c bindings\n\n![GitHub](https://img.shields.io/github/license/ahmet2mir/wildq.svg)\n[![image](https://img.shields.io/pypi/pyversions/wildq.svg)](https://python.org/pypi/wildq)\n[![Build Status](https://github.com/ahmet2mir/wildq/workflows/Unit%20Tests/badge.svg)](https://github.com/ahmet2mir/wildq/actions)\n\nPurpose of this package is to provide a simple wrapper arround jq for different formats.\nI'm tired of searching a package doing yaml jq, toml jq, ini jq etc. mainly used for scripting.\n\nThis script uses:\n* @mwilliamson [Python bindings](https://github.com/mwilliamson/jq.py) on top of @stedolan famous [jq](https://github.com/stedolan/jq/) lib\n* swiss knife for coloration [pygments](https://github.com/pygments/pygments)\n* binary built with [pyinstaller](https://github.com/pyinstaller/pyinstaller)\n* easy CLI with [click](https://github.com/pallets/click)\n* for supported types sources, check table `Supported file types`\n\n# Installation\n\nYou could install via pipx, pip, brew, deb, rpm or fallback to binary version.\n\n## Pipx\n\n`pipx` install and run python applications in isolated environments\n\n```sh\npipx install wildq\n```\n\n## Pip\n\n```sh\npip install wildq\n```\n\n## MacOS\n\n```\nbrew install ahmet2mir/tap/wildq\nbrew install ahmet2mir/tap/wq\n```\n\n## Debian (no gpg signature) \u003e= 10\n\n```\nVERSION=$(curl -s \"https://api.github.com/repos/ahmet2mir/wildq/releases/latest\" | grep '\"tag_name\":' | sed -E 's/.*\"v([^\"]+)\".*/\\1/')\ncurl -sL https://github.com/ahmet2mir/wildq/releases/download/v${VERSION}/wildq_${VERSION}-1_amd64.deb -o wildq_${VERSION}-1_amd64.deb\nsudo dpkg -i wildq_${VERSION}-1_amd64.deb\n\nwq --help\nwildq --help\n```\n\n## Centos (no gpg singature) \u003e= 7\n\n```\nVERSION=$(curl -s \"https://api.github.com/repos/ahmet2mir/wildq/releases/latest\" | grep '\"tag_name\":' | sed -E 's/.*\"v([^\"]+)\".*/\\1/')\ncurl -sL https://github.com/ahmet2mir/wildq/releases/download/v${VERSION}/wildq-${VERSION}-1.x86_64.rpm -o wildq-${VERSION}-1.x86_64.rpm\nsudo yum install -y ./wildq-${VERSION}-1.x86_64.rpm\n\nwq --help\nwildq --help\n```\n\n## Gentoo\n\n[@zmedico](https://github.com/zmedico) did a portage on [app-misc](https://packages.gentoo.org/packages/app-misc/wildq)\n\n```\nemerge -av app-misc/wildq\n```\n\n## GNU/Linux Binary\n\nCompiled using glibc 2.17, it should work on lot of stable/LTS distros.\n\n```\nmkdir -p ~/bin/\nVERSION=$(curl -s \"https://api.github.com/repos/ahmet2mir/wildq/releases/latest\" | grep '\"tag_name\":' | sed -E 's/.*\"v([^\"]+)\".*/\\1/')\ncurl -sL https://github.com/ahmet2mir/wildq/releases/download/v${VERSION}/wildq-${VERSION}-linux-x86_64.tar.gz -o wildq-${VERSION}-linux-x86_64.tar.gz\ntar xvfz wildq-${VERSION}-linux-x86_64.tar.gz -C ~/bin\nexport PATH=\"~/bin:$PATH\"\n\nwq --help\nwildq --help\n```\n\n## Windows\n\nWildq use [jq.py](https://github.com/mwilliamson/jq.py) and it's not yet available on windows platforms.\nI tried to compile it without windows machine and I failed, and I don't had the time to try to understand how Windows / C binding / Python works.\nIf anybody would contribute, there is an [open issue](https://github.com/mwilliamson/jq.py/issues/20) (jq and onigurama are 'compilable' on Windows so I think that someone confortable with that OS could make it);\n\n\n# Supported file types\n\n| type | color | ordering | output | source                                                              |\n|------|-------|----------|--------|---------------------------------------------------------------------|\n| hcl  |  json |    no    |  json  | [pyhcl](https://github.com/virtuald/pyhcl) by @virtuald             |\n| ini  |  yes  |    no    |  yes   | [ConfigParser](https://docs.python.org/3/library/configparser.html) |\n| json |  yes  |    yes   |  yes   | [json](https://docs.python.org/3/library/json.html)                 |\n| toml |  yes  |    no    |  yes   | [toml](https://github.com/uiri/toml) by @uiri                       |\n| xml  |  yes  |    no    |  yes   | [xmldict](https://github.com/martinblech/xmltodict) by @martinblech |\n| yaml |  yes  |    yes   |  yes   | [pyyaml](https://github.com/yaml/pyyaml)                            |\n\n# Usage\n\n```\n$ wildq --help\nUsage: wildq [OPTIONS] JQ_FILTER [FILE]\n\nOptions:\n  -c, --compact-output            compact instead of pretty-printed output\n  -r, --raw                       output raw strings, not content texts\n  -C, --color-output              colorize content (default), mutally\n                                  exclusive with --monochrome-output\n\n  -M, --monochrome-output         monochrome (don't colorize content), mutally\n                                  exclusive with --color-output\n\n  --hcl                           Combine --input hcl --output json, mutally\n                                  exclusive with other Combined options\n\n  --ini                           Combine --input ini --output json, mutally\n                                  exclusive with other Combined options\n\n  --json                          Combine --input json --output json, mutally\n                                  exclusive with other Combined options\n\n  --toml                          Combine --input toml --output json, mutally\n                                  exclusive with other Combined options\n\n  --xml                           Combine --input xml --output json, mutally\n                                  exclusive with other Combined options\n\n  --yaml                          Combine --input yaml --output json, mutally\n                                  exclusive with other Combined options\n\n  -i, --input [hcl|ini|json|toml|xml|yaml]\n                                  Define the content type of file, mutally\n                                  exclusive with Combined option\n\n  -o, --output [hcl|ini|json|toml|xml|yaml]\n                                  Define the content type of printed output,\n                                  mutally exclusive with Combined option\n                                  (default input format)\n\n  --version                       Show the version and exit.\n  --help                          Show this message and exit.\n```\n\n\u003e For backward compatibility in previous version only `--[yaml|json|toml|ini|xml|hcl]` was possible with default to json output.\nWe still keep Monochrome, raw and json output with thoses options.\nOutput was similar to `jq -MCr` (no color, no compact and no quote on single value)\n\nBut now, by default it's colorized, not raw and if you specify input using `-i` or `--input` output will be the same format.\n\nThere is also a shorter command `wq` comming with the package.\n\nLike `jq cli`, wildq supports both of stdin and file to the function\n\nSee examples to get some example.\n\nContent of `examples/json.json`\n\n```\n{\n    \"general\": {\n        \"user\": \"admin\"\n    },\n    \"keys\": [\n        {\"key\": \"value1\"},\n        {\"key\": \"value2\"},\n        \"alone\"\n    ]\n}\n```\n\n```sh\ncat examples/json.json | wildq -i json \".keys[]\"\n{\n    \"key\": \"value1\"\n}\n{\n    \"key\": \"value2\"\n}\nalone\n```\n\nor\n\n```sh\nwildq -i json \".keys[]\" examples/json.json\n{\n    \"key\": \"value1\"\n}\n{\n    \"key\": \"value2\"\n}\nalone\n```\nor\n\n```sh\nwq -i json \".keys[]\" examples/json.json\n{\n    \"key\": \"value1\"\n}\n{\n    \"key\": \"value2\"\n}\nalone\n```\n\nFor TOML\n```sh\ncat examples/toml.toml | wildq -i toml \".keys[]\"\n{\n    \"key\": \"value1\"\n}\n{\n    \"key\": \"value2\"\n}\nalone\n```\n\nFor INI (no array)\n```sh\ncat examples/ini.ini | wildq -i ini \".keys\"\n{\n    \"key1\": \"value1\",\n    \"key2\": \"value2\"\n}\n```\n\nFor XML\n```sh\ncat examples/xml.xml | wildq -i xml \".\"\n{\n    \"root\": {\n        \"general\": {\n            \"user\": \"admin\"\n        },\n        \"keys\": {\n            \"element\": [\n                {\n                    \"key\": \"value1\"\n                },\n                {\n                    \"key\": \"value2\"\n                },\n                \"alone\"\n            ]\n        }\n    }\n}\n```\n\nFor YAML\n```sh\ncat examples/yaml.yaml  | wildq -i yaml \".keys[]\"\n{\n    \"key1\": \"value1\"\n}\n{\n    \"key2\": \"value2\"\n}\nalone\n```\n\nFor HCL\n```sh\ncat examples/hcl.hcl  | wildq -i hcl \".keys[]\"\n{\n    \"key\": \"value1\"\n}\n{\n    \"key\": \"value2\"\n}\n```\n\n## Tips and tricks\n\nLoop on keys in bash without creating a subshell\n\n```sh\nwildq -i toml \"keys[]\" examples/toml.toml | while read -r key \ndo\n    echo \"Getting key ${key}\"\ndone\n```\n\nYou could also found some examples on some blogs/websites:\n\n* a complete guide with advanced examples on how to read/update files with differents processing tools [(Original Japanese)](https://yujiorama.hatenablog.com/entry/2021/03/21/113425) [(Translate EN)](https://translate.google.com/translate?sl=auto\u0026tl=en\u0026u=https://yujiorama.hatenablog.com/entry/2021/03/21/113425)\n\n* an example of INI manipulation made by AWS ParallelCluster Workshop [(workshop)](https://containers-on-pcluster.workshop.aws/setup/pcluster.html) [(example 1)](https://containers-on-pcluster.workshop.aws/setup/pcluster/pcluster-cfg/refine.html) [(example 2)](https://containers-on-pcluster.workshop.aws/setup/pcluster/pcluster-cnt/create-x86.html)\n\n## TODO\n\n- [x] add tests...\n- [x] add more control over filters and files\n- [x] use click for the CLI\n- [x] support different output\n- [ ] detect automagically filetype\n- [ ] support all jq types\n- [ ] ordering\n\n## Contributing\n\nMerge requests are welcome :)\n\n\n## License\n\nLicensed under the terms of the [Apache License, Version 2.0](http://www.apache.org/licenses/LICENSE-2.0).\n\n\n## Repository URL\n\nhttps://github.com/ahmet2mir/wildq\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fahmet2mir%2Fwildq","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fahmet2mir%2Fwildq","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fahmet2mir%2Fwildq/lists"}