我发现jq在将tsv转换为JSON文件时非常有帮助,然而,当我的tsv中有数组时,我想知道如何使用jq来做这件事:
name age pets
Tim 15 cats,dogs
Joe 11 rabbits,birds
...理想的JSON:
[
{
name: "Tim",
age: "15",
pet:["cats","dogs"]
},
name: "Joe",
age: "11",
pet:["rabbits","birds"]
}, ...
]这是我尝试过的命令:
cat file.tsv | jq -s --slurp --raw-input --raw-output 'split("\n") | .[1:-1] | map(split("\t")) |
map({"name": .[0],
"age": .[1],
"pet": .[2]})'上面命令的输出是:
[
{
name: "Tim",
age: "15",
pet:"cats,dogs"
},
name: "Joe",
age: "11",
pet:"rabbits,birds"-
}, ...
]发布于 2018-08-20 21:36:56
如果名称包含任何逗号,我将使用以下内容,这也避免了必须“吞咽”输入:
inputs
| split("\t")
| {name: .[0], age: .[1], pet: .[2]}
| .pet |= split(",") 要跳过标头,只需使用-R选项调用jq,例如:
jq -R -f program.jq input.tsv如果您希望结果为数组,只需将上面的整个过滤器括在方括号中即可。
发布于 2018-08-20 19:31:52
如下所示:
jq -rRs 'split("\n")[1:-1] |
map([split("\t")[]|split(",")] | {
"name":.[0],
"age":.[1],
"pet":.[2]
}
)' input.tsvhttps://stackoverflow.com/questions/51929141
复制相似问题