2016-11-16 21:20:36 +08:00
|
|
|
Long: output
|
|
|
|
Arg: <file>
|
|
|
|
Short: o
|
|
|
|
Help: Write to file instead of stdout
|
|
|
|
See-also: remote-name remote-name-all remote-header-name
|
2020-07-13 20:15:04 +08:00
|
|
|
Category: important curl
|
2016-11-16 21:20:36 +08:00
|
|
|
---
|
|
|
|
Write output to <file> instead of stdout. If you are using {} or [] to fetch
|
2020-03-30 05:51:52 +08:00
|
|
|
multiple documents, you should quote the URL and you can use '#' followed by a
|
|
|
|
number in the <file> specifier. That variable will be replaced with the current
|
|
|
|
string for the URL being fetched. Like in:
|
2016-11-16 21:20:36 +08:00
|
|
|
|
2020-03-30 05:51:52 +08:00
|
|
|
curl "http://{one,two}.example.com" -o "file_#1.txt"
|
2016-11-16 21:20:36 +08:00
|
|
|
|
|
|
|
or use several variables like:
|
|
|
|
|
2020-03-30 05:51:52 +08:00
|
|
|
curl "http://{site,host}.host[1-5].com" -o "#1_#2"
|
2016-11-16 21:20:36 +08:00
|
|
|
|
|
|
|
You may use this option as many times as the number of URLs you have. For
|
|
|
|
example, if you specify two URLs on the same command line, you can use it like
|
|
|
|
this:
|
|
|
|
|
|
|
|
curl -o aa example.com -o bb example.net
|
|
|
|
|
|
|
|
and the order of the -o options and the URLs doesn't matter, just that the
|
|
|
|
first -o is for the first URL and so on, so the above command line can also be
|
|
|
|
written as
|
|
|
|
|
|
|
|
curl example.com example.net -o aa -o bb
|
|
|
|
|
|
|
|
See also the --create-dirs option to create the local directories
|
|
|
|
dynamically. Specifying the output as '-' (a single dash) will force the
|
|
|
|
output to be done to stdout.
|