curlコマンドを使用してダウンロード可能なファイルのサイズを取得するには?

curlコマンドを使用してダウンロード可能なファイルのサイズを取得するには?

curlコマンドを使用して「url」からファイルをダウンロードする必要があるなど、シェルスクリプトの要件があります。ファイルをダウンロードする前に、メソッドで同じファイルサイズを処理したいと思います。

誰でも助けることができますか?

ベストアンサー1

-Iヘッダーのみを検索し、「Content-Length」ヘッダーを検索するには、このオプションを使用します。-Lリダイレクトに従う必要がある場合は、このオプションを追加してください。たとえば、

$ curl -L -I https://cdimage.debian.org/debian-cd/current/amd64/iso-cd/debian-9.4.0-amd64-netinst.iso
HTTP/1.1 302 Found
Date: Mon, 18 Jun 2018 09:51:32 GMT
Server: Apache/2.4.29 (Unix)
Location: https://gensho.ftp.acc.umu.se/debian-cd/current/amd64/iso-cd/debian-9.4.0-amd64-netinst.iso
Cache-Control: max-age=300
Expires: Mon, 18 Jun 2018 09:56:32 GMT
Content-Type: text/html; charset=iso-8859-1

HTTP/1.1 200 OK
Date: Mon, 18 Jun 2018 09:51:32 GMT
Server: Apache/2.4.29 (Unix)
Last-Modified: Sat, 10 Mar 2018 11:56:52 GMT
Accept-Ranges: bytes
Content-Length: 305135616
Age: 228
Content-Type: application/x-iso9660-image

これは、ファイルサイズが305,135,616バイトであることを示します。

Gawkを使用してフィルタリングできます。たとえば、次のようになります。

$ curl -s -L -I https://cdimage.debian.org/debian-cd/current/amd64/iso-cd/debian-9.4.0-amd64-netinst.iso | gawk -v IGNORECASE=1 '/^Content-Length/ { print $2 }'
305135616

(この-sオプションはcurl進捗情報を印刷しないように指示します。デフォルトでは、出力がリダイレクトされると進捗情報を印刷します。)

この情報は常に利用できるわけではないので、これを処理できるようにスクリプトを準備する必要があります。

おすすめ記事