como extrair o arquivo json usando o awk / sed?

0

Inserir dados.json

{
  "lastUpdateTime" : "2018-07-20T10:56:26.000Z",
  "items" : [ {
    "date" : "2018-07-19T21:09:27.000Z",
    "user" : "dddd",
    "size" : 5219402,
    "rawSize" : 15658206,
    "numFiles" : 119
  }, {
    "date" : "2018-07-19T21:09:27.000Z",
    "user" : "aaaa",
    "size" : 20524410845,
    "rawSize" : 61573215663,
    "numFiles" : 7540
  }, {
    "date" : "2018-07-19T21:09:27.000Z",
    "user" : "wwww",
    "size" : 0,
    "rawSize" : 0,
    "numFiles" : 2
  }, {
    "date" : "2018-07-19T21:09:27.000Z",
    "user" : "qqqq",
    "size" : 201084,
    "rawSize" : 603252,
    "numFiles" : 25
  }, {
    "date" : "2018-07-19T21:09:27.000Z",
    "user" : "ttttt",
    "size" : 280395332,
    "rawSize" : 288900666,
    "numFiles" : 199
  } ]
}

Saída esperada

User Size
aaa   121
bbb   123

Como converter JSON para a tabela acima? Por favor me ajude.

    
por Praveen Prakasan 20.07.2018 / 13:57

2 respostas

1

Bem, apesar de eu concordar completamente com @gronostaj sobre NÃO usar awk ou sed como ferramenta de análise para JSON, eu sei que às vezes pode haver casos em que você não pode usar nada além do que vem com o sistema operacional .

Se você tem certeza absoluta de que o JSON que você postou estará sempre no mesmo formato que você postou, então a solução está abaixo:

#!/bin/sh

data='
{
  "lastUpdateTime" : "2018-07-20T10:56:26.000Z",
  "items" : [ {
    "date" : "2018-07-19T21:09:27.000Z",
    "user" : "dddd",
    "size" : 5219402,
    "rawSize" : 15658206,
    "numFiles" : 119
  }, {
    "date" : "2018-07-19T21:09:27.000Z",
    "user" : "aaaa",
    "size" : 20524410845,
    "rawSize" : 61573215663,
    "numFiles" : 7540
  }, {
    "date" : "2018-07-19T21:09:27.000Z",
    "user" : "wwww",
    "size" : 0,
    "rawSize" : 0,
    "numFiles" : 2
  }, {
    "date" : "2018-07-19T21:09:27.000Z",
    "user" : "qqqq",
    "size" : 201084,
    "rawSize" : 603252,
    "numFiles" : 25
  }, {
    "date" : "2018-07-19T21:09:27.000Z",
    "user" : "ttttt",
    "size" : 280395332,
    "rawSize" : 288900666,
    "numFiles" : 199
  } ]
}
'
###########################################################
echo "${data}" | awk -F: 'BEGIN{
  printf ("%s\t\t%s\t%s\n","Date", "User", "Size")
}
/lastUpdateTime/ {next}
/date/ { gsub(/\"|,|\s/,""); gsub(/T.+$/,""); printf ("%s\t", $2) }
/user/ { gsub(/\"|,|\s/,""); printf ("%s\t", $2) }
/size/ { gsub(/\"|,|\s/,""); printf ("%s\n", $2) }
'
    
por 20.07.2018 / 16:02
4

A única resposta honesta e correta é:

Não.

awk e sed não são ferramentas certas para o trabalho. Você não poderá lidar adequadamente com escape e codificação JSON. Você poderia tentar cobrir alguns casos básicos, mas também poderia usar uma ferramenta adequada: jq .

jq solution

jq '.items[] | "\(.user) \(.size)"' -r /path/to/file

(alternativamente, você pode canalizar JSON para o comando em vez de lê-lo a partir do arquivo)

Para alinhar colunas:

jq '.items[] | "\(.user) \(.size)"' -r /path/to/file | column -t
    
por 20.07.2018 / 14:22