Go to file
2019-02-28 23:21:19 +07:00
snap Update snapcraft.yaml 2018-12-19 23:30:27 +07:00
.gitignore Add standalone binary dist 2018-01-27 06:44:19 +07:00
.travis.yml ci: test Node.js 8, 10 and 11 (#26) 2018-11-08 14:42:32 +07:00
bang.js Add big bang of life 2019-02-09 23:48:13 +07:00
config.js Show status bar if pattern not found 2018-12-15 14:52:48 +07:00
Dockerfile Add docker image 2019-02-24 15:58:28 +07:00
docs.md Update docs 2019-02-25 01:57:47 +07:00
find.js Search on keys, not paths 2018-12-15 14:52:48 +07:00
fx.js Fix bug with empty pattern 2019-02-09 18:12:22 +07:00
index.js Fix bug in stream processor 2019-02-26 02:06:12 +07:00
LICENSE Update LICENSE 2019-01-30 10:17:39 +07:00
package.json Release 12.0.2 2019-02-26 02:07:55 +07:00
print.js Fix style on search cancel 2018-12-15 15:04:22 +07:00
README.md Update README.md 2019-02-28 23:21:19 +07:00
reduce.js Add better detection of functions in reduce 2018-12-07 23:33:55 +07:00
stream.js Fix bug in stream processor 2019-02-26 02:06:12 +07:00
test.js Fix bug in stream processor 2019-02-26 02:06:12 +07:00

fx logo

fx example

* Function eXecution

Build Status Npm Version Brew Version Snap Version

Command-line JSON processing tool

Features

  • Easy to use
  • Standalone binary
  • Interactive mode 🎉
  • Themes support 🎨
  • Streaming support 🌊
  • Bash completion

Install

$ npm install -g fx

Or via Homebrew

$ brew install fx

Or download standalone binary from releases page.

Did you like fx? Buy me a beer 🍺 or send come ₿

Usage

Start interactive mode without passing any arguments.

$ curl ... | fx

Or by passing filename as first argument.

$ fx data.json

Pipe into fx any JSON and anonymous function for reducing it.

$ curl ... | fx 'json => json.message'

Or same as above but short.

$ curl ... | fx this.message
$ curl ... | fx .message

Pass any numbers of arguments as code.

$ curl ... | fx 'json => json.message' 'json => json.filter(x => x.startsWith("a"))'

Access all lodash (or ramda, etc) methods by using .fxrc file.

$ curl ... | fx '_.groupBy("commit.committer.name")' '_.mapValues(_.size)'

Update JSON using spread operator.

$ echo '{"count": 0}' | fx '{...this, count: 1}'
{
  "count": 1
}

Pretty print JSON with dot.

$ curl ... | fx .

Stream JSON into fx.

$ kubectl logs ... -f | fx .message

Apply fx to a few JSON files.

$ cat *.json | fx .length
3
4

And try this:

$ fx --life

Documentation

See full documentation.

License

MIT