Мне нужно преобразовать вывод команды jq в таблицу - PullRequest
0 голосов
/ 16 января 2020

Я использую эту команду для извлечения некоторой информации из 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

Когда я выполняю сценарий, он возвращает текстовый файл с этим:

[
  [
    "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",

И Мне нужно вернуть эти данные в виде таблицы, каждое значение является столбцом. Пример.

namespace,        timestamp,              request.storage
 "glusterfs",    "2019-12-12T13:47:25Z",    "200Gi",
    "timpdv",    "2019-01-10T19:53:29Z",    null,
    "timpdv",    "2019-01-10T20:36:18Z",    "300Gi",

1 Ответ

0 голосов
/ 16 января 2020

Игнорируя строку заголовка, похоже, что запрос 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. В любом случае вы, вероятно, захотите вызвать jq с параметром -r.

...