Optimized JSON for Go is a high performance parser with a variety of additional JSON tools.
- Fast JSON parser. Check out the cmd/benchmarks app in this repo.
- Full JSONPath implemenation that operates on simple types as well as structs.
- Generic types. Not the proposed golang generics but type safe JSON elements.
- Fast JSON validator (7 times faster with io.Reader).
- Fast JSON writer with a sort option (4 times faster).
- JSON builder from JSON sources using a simple assembly plan.
- Simple data builders using a push and pop approach.
- Object encoding and decoding using an approach similar to that used with Oj for Ruby.
- Simple Encoding Notation, a lazy way to write JSON omitting commas and quotes.
A basic Parse:
obj, err := oj.ParseString(`{
"a":[
{"x":1,"y":2,"z":3},
{"x":2,"y":4,"z":6}
]
}`)
Using JSONPath expressions:
x, err := jp.ParseString("a[?(@.x > 1)].y")
ys := x.Get(obj)
// returns [4]
The oj command (cmd/oj) which uses JSON path for filtering and extracting JSON elements. It also includes sorting, reformatting, and colorizing options.
$ oj -m "(@.name == 'Pete')" myfile.json
go get github.com/ohler55/ojg
go get github.com/ohler55/ojg/cmd/oj
or just import in your .go
files.
import (
"github.com/ohler55/ojg/alt"
"github.com/ohler55/ojg/asm"
"github.com/ohler55/ojg/gen"
"github.com/ohler55/ojg/jp"
"github.com/ohler55/ojg/oj"
"github.com/ohler55/ojg/sen"
)
To build and install the oj
application:
go install ./...
Higher numbers (longer bars) are better.
Parse string/[]byte
json.Unmarshal 47204 ns/op 17777 B/op 334 allocs/op
oj.Parse 27983 ns/op 18489 B/op 429 allocs/op
oj-reuse.Parse 18573 ns/op 5691 B/op 364 allocs/op
oj-reuse.Parse █████████████████████████▍ 2.54
oj.Parse ████████████████▊ 1.69
json.Unmarshal ▓▓▓▓▓▓▓▓▓▓ 1.00
Parse io.Reader
json.Decode 65334 ns/op 32449 B/op 344 allocs/op
oj.ParseReader 38374 ns/op 22582 B/op 430 allocs/op
oj-reuse.ParseReader 23578 ns/op 9787 B/op 365 allocs/op
oj.TokenizeLoad 12790 ns/op 6072 B/op 157 allocs/op
oj.TokenizeLoad ███████████████████████████████████████████████████ 5.11
oj-reuse.ParseReader ███████████████████████████▋ 2.77
oj.ParseReader █████████████████ 1.70
json.Decode ▓▓▓▓▓▓▓▓▓▓ 1.00
to JSON with indentation
json.Marshal 80889 ns/op 26979 B/op 352 allocs/op
oj.JSON 11201 ns/op 4096 B/op 1 allocs/op
sen.String 11512 ns/op 3456 B/op 1 allocs/op
oj.JSON █████████████████████████████████████████████████████████▊ 7.22
sen.String ████████████████████████████████████████████████████████▏ 7.03
json.Marshal ▓▓▓▓▓▓▓▓ 1.00
See all benchmarks
See CHANGELOG.md
-
Documentation: https://pkg.go.dev/github.com/ohler55/ojg
-
GitHub repo: https://github.com/ohler55/ojg
-
JSONPath description: https://goessner.net/articles/JsonPath
-
JSONPath Comparisons https://cburgmer.github.io/json-path-comparison
-
Oj, a Ruby JSON parser: http://www.ohler.com/oj/doc/index.html also at https://github.com/ohler55/oj
-
OjC, a C JSON parser: http://www.ohler.com/ojc/doc/index.html also at https://github.com/ohler55/ojc
-
Fast XML parser and marshaller on GitHub: https://github.com/ohler55/ox
-
Agoo, a high performance Ruby web server supporting GraphQL on GitHub: https://github.com/ohler55/agoo
-
Agoo-C, a high performance C web server supporting GraphQL on GitHub: https://github.com/ohler55/agoo-c
- Provide a Pull Request off the
develop
branch. - Report a bug
- Suggest an idea