jq 无法使用 join 迭代数字
jq cannot iterate over number with join
我想从 json 文件中添加一些值,用竖线分隔。到目前为止它运行良好,直到值是数字而不是字符串。
这是我到目前为止所做的:jq -r '.content[] | {seasonTitle, number, name} | join("|")' file.json
我尝试将数字转换为字符串但没有成功jq -r '.content[] | {seasonTitle, "episodeNumber|tostring", name} | join("|")' file.json
实际结果:
Top Master||Last Chance / Season 12
Top Master||Épisode 8 / Season 12
Top Master||Épisode 7 / Season 12
预期结果:
Top Master|236|Last Chance / Season 12
Top Master|235|Épisode 8 / Season 12
Top Master|234|Épisode 7 / Season 12
这里是file.json
{
"page": 0,
"size": 3,
"count": 3,
"content": [
{
"name": "Last Chance / Season 12",
"releaseDate": "2008",
"duration": 2100,
"episodeNumber": 236,
"title": "Last Chance / Season 12",
"seasonTitle": "Top Master"
},
{
"name": "Épisode 8 / Season 12",
"releaseDate": "2008",
"duration": 7320,
"episodeNumber": 235,
"title": "Épisode 8 / Season 12",
"seasonTitle": "Top Master"
},
{
"name": "Épisode 7 / Season 12",
"releaseDate": "2008",
"duration": 7200,
"episodeNumber": 234,
"title": "Épisode 7 / Season 12",
"seasonTitle": "Top Master"
}
]
}
您正在使用 join
连接不同类型的值,这在 jq v1.6 下工作正常:
.content[] | {seasonTitle, episodeNumber, name} | join("|")
Top Master|236|Last Chance / Season 12
Top Master|235|Épisode 8 / Season 12
Top Master|234|Épisode 7 / Season 12
但是,对于 jq v1.5,它不会,您需要使用 tostring
将 non-strings 转换为字符串。当您使用快捷方式为 join
创建对象时,引入此转换会牺牲解决方案的简洁性。所以要么坚持下去:
.content[] | {seasonTitle, episodeNumber: (.episodeNumber | tostring), name} | join("|")
或者改用数组,因为无论如何您只需要值:
.content[] | [.seasonTitle, (.episodeNumber | tostring), .name] | join("|")
我想从 json 文件中添加一些值,用竖线分隔。到目前为止它运行良好,直到值是数字而不是字符串。
这是我到目前为止所做的:jq -r '.content[] | {seasonTitle, number, name} | join("|")' file.json
我尝试将数字转换为字符串但没有成功jq -r '.content[] | {seasonTitle, "episodeNumber|tostring", name} | join("|")' file.json
实际结果:
Top Master||Last Chance / Season 12
Top Master||Épisode 8 / Season 12
Top Master||Épisode 7 / Season 12
预期结果:
Top Master|236|Last Chance / Season 12
Top Master|235|Épisode 8 / Season 12
Top Master|234|Épisode 7 / Season 12
这里是file.json
{
"page": 0,
"size": 3,
"count": 3,
"content": [
{
"name": "Last Chance / Season 12",
"releaseDate": "2008",
"duration": 2100,
"episodeNumber": 236,
"title": "Last Chance / Season 12",
"seasonTitle": "Top Master"
},
{
"name": "Épisode 8 / Season 12",
"releaseDate": "2008",
"duration": 7320,
"episodeNumber": 235,
"title": "Épisode 8 / Season 12",
"seasonTitle": "Top Master"
},
{
"name": "Épisode 7 / Season 12",
"releaseDate": "2008",
"duration": 7200,
"episodeNumber": 234,
"title": "Épisode 7 / Season 12",
"seasonTitle": "Top Master"
}
]
}
您正在使用 join
连接不同类型的值,这在 jq v1.6 下工作正常:
.content[] | {seasonTitle, episodeNumber, name} | join("|")
Top Master|236|Last Chance / Season 12
Top Master|235|Épisode 8 / Season 12
Top Master|234|Épisode 7 / Season 12
但是,对于 jq v1.5,它不会,您需要使用 tostring
将 non-strings 转换为字符串。当您使用快捷方式为 join
创建对象时,引入此转换会牺牲解决方案的简洁性。所以要么坚持下去:
.content[] | {seasonTitle, episodeNumber: (.episodeNumber | tostring), name} | join("|")
或者改用数组,因为无论如何您只需要值:
.content[] | [.seasonTitle, (.episodeNumber | tostring), .name] | join("|")