json2struct

command module
v1.9.3 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Apr 17, 2025 License: GPL-3.0 Imports: 1 Imported by: 0

README

json2struct

PRs Welcome

CLI tool to convert JSON to struct type definitions

At some point when dealing with JSONs in Go, you will have to write struct types to json.Unmarshal your JSONs into. Doing this by hand is not only repetitive and time consuming, but also error prone. json2struct saves you this work by automatically parsing the JSON and generating you the matching struct type definitions ready to be used.

Unlike other tools, json2struct tries to avoid generating interface{} and map[string]interface{} as much as possible. Nonetheless it's very fast 🚀.

Installation

Homebrew
brew tap marhaupe/json2struct https://github.com/marhaupe/json2struct

brew install marhaupe/json2struct/json2struct
Manually

Grab the latest release binaries.

Usage

json2struct [options]

Calling json2struct without flags opens a text editor. Simply input your JSON and save and exit.

Example

Options

You probably don't want to manually write that 1MB JSON you have to generate a struct for by hand. I mean, if you really want to, I'm not here to judge, but that's not the point. These options will make your life easier. If you miss some, feel free to open an issue.

Generating a struct from a string

-s, --string string: JSON string

This is basically your bread and butter thanks to pipes. Usage:

 json2struct -s "$(curl "https://reqres.in/api/users?page=2")"
Generating a struct from an existing file

-f, --file string: path to JSON file

This is useful if you have a JSON file stored in your filesystem and are too lazy to use pipes. Usage:

json2struct -f input.json
Generating a struct from the clipboard to the clipboard

-c, --clipboard: read from and write types to clipboard

Reads JSON from clipboard, generates types and writes those types to the clipboard.

json2struct -c
Other options

-b, --benchmark: measure execution time

-h, --help: help for json2struct

--version: version for json2struct

Benchmarks

Command Mean [ms] Min [ms] Max [ms] Relative
json2struct -f big_reddit_response 8.1 ± 0.6 7.3 11.3 1.00
gojson -input big_reddit_response 9.0 ± 0.5 8.1 10.8 1.12 ± 0.10
cat big_reddit_response | gojsonstruct 71.7 ± 1.3 69.9 76.9 8.87 ± 0.64
quicktype -l go -o output.go big_reddit_response 329.5 ± 2.2 326.7 333.5 40.75 ± 2.86

Specifics

A lot of the lexing/parsing in this project is inspired by the text/template package. Rob Pike also gave a talk about how and why they wrote the package. The link can be found here, and the slides to it here

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis
pkg
editor
Package editor contains fields to create, edit, save and then delete files with currently only vim
Package editor contains fields to create, edit, save and then delete files with currently only vim
lex

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL