Json 我需要将jq comand的输出转换为一个表

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

我使用这个命令从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/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