Json 我需要将jq comand的输出转换为一个表
我使用这个命令从Json中提取一些信息Json 我需要将jq comand的输出转换为一个表,json,jq,Json,Jq,我使用这个命令从Json中提取一些信息 #!/bin/bash TOKEN=$(oc whoami -t) ENDPOINT=$(oc config current-context | cut -d/ -f2 | tr - .) NAMESPACE=$(oc config current-context | cut -d/ -f1) curl -k \ -H "Authorization: Bearer $TOKEN" \ -H 'Accept: application/j
#!/bin/bash
TOKEN=$(oc whoami -t)
ENDPOINT=$(oc config current-context | cut -d/ -f2 | tr - .)
NAMESPACE=$(oc config current-context | cut -d/ -f1)
curl -k \
-H "Authorization: Bearer $TOKEN" \
-H 'Accept: application/json' \
https://$ENDPOINT/api/v1/resourcequotas | jq -jr '[[.items[].metadata.namespace ], [.items[].metadata.creationTimestamp ], [.items[].spec.hard["requests.storage"]],[.items[].status.used["requests.storage"]],[.items[].spec.hard["limits.cpu"]],[.items[].spec.hard["limits.memory"]],[.items[].status.used["limits.cpu"]],[.items[].status.used["limits.memory"]]] ' > item.txt
当我执行脚本时,它会返回一个包含以下内容的txt文件:
[
[
"glusterfs",
"timpdv",
"timpdv",
"whatsappprd",
"whatsappprd",
"wso2ms",
"wso2ms"
],
[
"2019-12-12T13:47:25Z",
"2019-01-10T19:53:29Z",
"2019-01-10T20:36:18Z",
"2019-02-15T17:39:43Z",
"2019-02-13T18:20:30Z",
"2019-12-12T13:49:57Z",
"2019-12-12T13:50:45Z"
],
[
"200Gi",
null,
"300Gi",
null,
"1150Gi",
null,
"200Gi"
],
[
"0",
null,
"68Gi",
null,
"1074Gi",
null,
"0"
],
[
null,
"16",
null,
"192",
null,
"80",
null
],
[
null,
"192Gi",
我需要以表格的形式返回这些数据,每个值都是一列。
前
忽略标题行,您想要的jq查询看起来更像这样:
.items[]
| [.metadata.namespace,
.metadata.creationTimestamp,
.spec.hard["requests.storage"],
.status.used["requests.storage"],
.spec.hard["limits.cpu"],
.spec.hard["limits.memory"],
.status.used["limits.cpu"],
.status.used["limits.memory"]]
| @tsv
对于CSV,使用
@CSV
而不是@tsv
。在任何一种情况下,您都可能希望在bash中使用-r选项调用jq。!?你是个虐待狂,我不是虐待狂,我只是需要你去做。我正在从普罗米修斯那里提取这些信息。几乎是这样,我唯一不明白的是为什么每个人都有一个“t”glusterfs\t2019-12-12T13:47:25Z\t200Gi\t0\t\t\t“\t
是选项卡的JSON表示。请看更新。好的,现在有意义了。谢谢,我差点放弃使用jq了
.items[]
| [.metadata.namespace,
.metadata.creationTimestamp,
.spec.hard["requests.storage"],
.status.used["requests.storage"],
.spec.hard["limits.cpu"],
.spec.hard["limits.memory"],
.status.used["limits.cpu"],
.status.used["limits.memory"]]
| @tsv