私がいくつかのサイトにカールすると、まっすぐjsonを取得できます:
curl http://httpbin.org/ip
{ "Origin": "37.77.126.22"}
美化するために、私はします:
curl http://httpbin.org/ip | jq
{
"Origin": "37.77.126.22"
}
それを美しくして保存するために、私はリダイレクトします...しかしそれは機能しません
curl http://httpbin.org/ip | jq > output.txt
{
"Origin": "37.77.126.22"
}
(23) Failed writing body
どのようにすればよいですか?
2番目の例でJSON出力が得られることに少し驚いています。私のシステムでは、jq
はエラーメッセージを出力します。これには、使用方法の情報も含まれています。
$ curl "http://httpbin.org/ip" | jq >file
jq - commandline JSON processor [version 1.5]
Usage: jq [options] <jq filter> [file...]
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 is the identity filter,
copying jq's input to its output unmodified (except for
formatting).
For more advanced filters see the jq(1) manpage ("man jq")
and/or https://stedolan.github.io/jq
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>;
See the manpage for more options.
% Total % Received % Xferd Average Speed Time Time Time Current
Dload Upload Total Spent Left Speed
100 33 100 33 0 0 115 0 --:--:-- --:--:-- --:--:-- 136
(23) Failed writing body
エラーのためにcurl
が終了し、本文(Webページのコンテンツ)を読み取ることができないため、「失敗した書き込み本文」はjq
からのものです。
jq
にはフィルター式が必要です。最も単純なフィルターは.
(ドット)「パススルー」フィルターのように機能します(上記の使用法情報では「識別フィルター」と呼ばれています):
$ curl "http://httpbin.org/ip" | jq . >file