首页 > 解决方案 > jq to_entries 字符串和数字不能加

问题描述

我不明白to_entriesjq 是如何工作的。

我有以下 json 有效负载payload.json

{"REGION":"us-east-1","EMAIL":"contain","UPDATE":1}

我想将其转换为=分隔的密钥对,就像这样;

REGION=us-east-1
EMAIL=contain
UPDATE=1

我正在使用

jq -r 'to_entries | .[] | .key + "=" + .value' < payload.json

但我得到一个错误

jq: error (at <stdin>:0): string ("UPDATE=") and number (1) cannot be added

如果我理解正确,问题是更新值是一个数字,而不是一个字符串(即,让它们不匹配类型是一个问题)所以我尝试了以下,两者都出现相同的错误;

string interpolation:
jq -r 'to_entries | .[] | (.key) + "=" + (.value)' < payload.json

tostring:
jq -r 'to_entries | .[] | .key + "=" + .value|tostring' < payload.json

我错过了什么?

标签: jsonjq

解决方案


我错过了什么?

一对括号:

.key + "=" + ( .value|tostring )

或者,您可以使用字符串插值,例如

"\(.key)=\(.value)"

推荐阅读