Skip to content

Value Parsing

This describes how values are parsed from the CLI to commands that create/update yaml (e.g. new/write).

yq attempts to parse values intelligently, e.g. when a number is passed it - it will assume it's a number as opposed to a string. yq will not alter the representation of what you give. So if you pass '03.0' in, it will assume it's a number and keep the value formatted as it was passed in, that is '03.0'.

The --tag flag can be used to override the tag type to force particular tags.

Default behaviour

Integers

Given

yq new key 3

results in

key: 3

Given a formatted number

yq new key 03

results in

key: 03

yq keeps the number formatted as it was passed in.

Float

Given

yq new key "3.1"

results in

key: 3.1

Note that quoting the number does not make a difference.

Given a formatted decimal number

yq new key 03.0

results in

key: 03.0

yq will keep the number formatted as it was passed in

Booleans

yq new key true

results in

key: true

Nulls

yq new key null

results in

key: null
yq new key '~'

results in

key: ~
yq new key ''

results in

key:

Strings

yq new key whatever

results in

key: whatever
yq new key ' whatever '

results in

key: ' whatever '

Using the tag field to override

Previous versions of yq required double quoting to force values to be strings, this no longer works - instead use the --tag flag.

Casting booleans

yq new --tag '!!str' key true

results in

key: 'true'

Casting nulls

yq new --tag '!!str' key null

results in

key: 'null'

Custom types

yq new --tag '!!farah' key gold

results in

key: !!farah gold