Trabalhando com JSON no terminal? O jq salva você!
Para quem utiliza JSON, sabe que visualizar ele no terminal é algo bem cansativo. Nesta dica vamos aprender como tornar nossa vida mais fácil com o "jq".
Primeiramente será necessário realizar o download da versão para o nosso sistema operacional:
Em seguida vamos transferir o arquivo "jq-linux64" para nossa máquina, e em seguida vamos alterar o nome dele para ficar mais simples:
mv jq-linux64 jq
Abaixo temos um exemplo de um arquivo com JSON em uma única linha, neste caso trata-se de um json pequeno para exemplificarmos o uso, mas poderá ser utilizado para qualquer tamanho que ele trabalhará da mesma forma.
jq is a tool for processing JSON inputs, applying the given filter to
its JSON text inputs and producing the filter's results as JSON on
standard output.
The simplest filter is ., which copies jq's input to its output
unmodified (except for formatting, but note that IEEE754 is used
for number representation internally, with all that that implies).
For more advanced filters see the jq(1) manpage ("man jq")
and/or https://stedolan.github.io/jq
Example:
$ echo '{"foo": 0}' | jq .
{
"foo": 0
}
Some of the options include:
-c compact instead of pretty-printed output;
-n use `null` as the single input value;
-e set the exit status code based on the output;
-s read (slurp) all inputs into an array; apply filter to it;
-r output raw strings, not JSON texts;
-R read raw strings, not JSON texts;
-C colorize JSON;
-M monochrome (don't colorize JSON);
-S sort keys of objects on output;
--tab use tabs for indentation;
--arg a v set variable $a to value <v>;
--argjson a v set variable $a to JSON value <v>;
--slurpfile a f set variable $a to an array of JSON texts read from <f>;
--rawfile a f set variable $a to a string consisting of the contents of <f>;
--args remaining arguments are string arguments, not files;
--jsonargs remaining arguments are JSON arguments, not files;
-- terminates argument processing;