curl/docs/cmdline-opts/output.md

58 lines
1.6 KiB
Markdown
Raw Normal View History

---
c: Copyright (C) Daniel Stenberg, <daniel@haxx.se>, et al.
SPDX-License-Identifier: curl
2016-11-16 21:20:36 +08:00
Long: output
Arg: <file>
Short: o
Help: Write to file instead of stdout
Category: important curl
Added: 4.0
Multi: append
See-also:
- remote-name
- remote-name-all
- remote-header-name
Example:
- -o file $URL
- "http://{one,two}.example.com" -o "file_#1.txt"
- "http://{site,host}.host[1-5].example" -o "#1_#2"
- -o file $URL -o file2 https://example.net
2016-11-16 21:20:36 +08:00
---
# `--output`
2016-11-16 21:20:36 +08:00
Write output to <file> instead of stdout. If you are using {} or [] to fetch
multiple documents, you should quote the URL and you can use '#' followed by a
number in the <file> specifier. That variable is replaced with the current
string for the URL being fetched. Like in:
2016-11-16 21:20:36 +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:
curl "http://{site,host}.host[1-5].example" -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
2016-11-16 21:20:36 +08:00
and the order of the -o options and the URLs does not matter, just that the
2016-11-16 21:20:36 +08:00
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
2016-11-16 21:20:36 +08:00
See also the --create-dirs option to create the local directories
dynamically. Specifying the output as '-' (a single dash) passes the output to
stdout.
To suppress response bodies, you can redirect output to /dev/null:
curl example.com -o /dev/null
Or for Windows:
curl example.com -o nul