yq is a portable command-line YAML, JSON, XML, CSV, TOML and properties processor
Go to file
kenjones 3beee3f804 Bugfix: Panic on non-string keys
Adds check if the key is an `int` or `bool`, and converts to a string
as part of the `toJSON` function.
Test cases added.

Resolves: #28
2017-09-21 12:01:03 -04:00
docs Update docs re using values that look like flags 2017-05-03 10:42:53 +10:00
mkdocs Update docs re using values that look like flags 2017-05-03 10:42:53 +10:00
vendor Handle arrays and strings when reading 2017-08-08 16:42:11 +10:00
.gitignore switched from godeps to govendor, now supports new 'vendor' folder 2017-05-03 09:19:55 +10:00
.travis.yml Added travis config 2017-02-13 07:28:48 +11:00
ci.sh Fixed travis script, added Travis banner to readme 2017-02-13 07:55:06 +11:00
coverage.sh Removed redundant code, updated doc w.r.t reading json files 2017-04-19 15:45:45 +10:00
data_navigator_test.go switched from godeps to govendor, now supports new 'vendor' folder 2017-05-03 09:19:55 +10:00
data_navigator.go switched from godeps to govendor, now supports new 'vendor' folder 2017-05-03 09:19:55 +10:00
instruction_sample.yaml Can update a yaml file from an instruction yaml file 2015-10-08 10:31:31 +11:00
json_converter_test.go Bugfix: Panic on non-string keys 2017-09-21 12:01:03 -04:00
json_converter.go Bugfix: Panic on non-string keys 2017-09-21 12:01:03 -04:00
LICENSE Added License (MIT) 2017-02-10 16:00:25 +11:00
mkdocs.yml Removed redundant code, updated doc w.r.t reading json files 2017-04-19 15:45:45 +10:00
order.yaml Maintain order 2017-02-27 09:09:29 +11:00
order.yml Maintain order 2017-02-27 09:09:29 +11:00
path_parser_test.go Custom path parsing 2015-10-03 17:04:12 +10:00
path_parser.go Custom path parsing 2015-10-03 17:04:12 +10:00
precheckin.sh Fixed travis script, added Travis banner to readme 2017-02-13 07:55:06 +11:00
README.md switched from godeps to govendor, now supports new 'vendor' folder 2017-05-03 09:19:55 +10:00
release.sh Release task now clears build directory first 2015-10-13 21:34:40 +11:00
sample2.yaml Can now splat maps 2015-10-06 10:08:31 +11:00
sample_array.yaml Handle arrays and strings when reading 2017-08-08 16:42:11 +10:00
sample_text.yaml Handle arrays and strings when reading 2017-08-08 16:42:11 +10:00
sample.json Added json input functionality 2015-10-11 17:06:52 +11:00
sample.yaml Can handle arrays 2015-09-28 13:17:50 +10:00
utils_test.go switched from godeps to govendor, now supports new 'vendor' folder 2017-05-03 09:19:55 +10:00
yaml_test.go Can create arrays 2017-08-08 17:04:30 +10:00
yaml.go Can create arrays 2017-08-08 17:04:30 +10:00

yaml Build Status

yaml is a lightweight and portable command-line YAML processor

The aim of the project is to be the jq or sed of yaml files.

Install

Download latest binary or alternatively:

go get github.com/mikefarah/yaml

Features

  • Written in portable go, so you can download a lovely dependency free binary
  • Deep read a yaml file with a given path
  • Update a yaml file given a path
  • Update a yaml file given a script file
  • Update creates any missing entries in the path on the fly
  • Create a yaml file given a deep path and value
  • Create a yaml file given a script file
  • Convert from json to yaml
  • Convert from yaml to json
  • Pipe data in by using '-'

Usage

Check out the documentation for more detailed and advanced usage.

Usage:
  yaml [command]

Available Commands:
  read        yaml r sample.yaml a.b.c
  write       yaml w [--inplace/-i] [--script/-s script_file] sample.yaml a.b.c newValueForC
  new         yaml n [--script/-s script_file] a.b.c newValueForC

Flags:
  -h, --help[=false]: help for yaml
  -j, --tojson[=false]: output as json
  -t, --trim[=true]: trim yaml output
  -v, --verbose[=false]: verbose mode

Use "yaml [command] --help" for more information about a command.

Contribute

  1. run govendor sync link
  2. add unit tests
  3. make changes
  4. run ./precheckin.sh
  5. profit