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
進捗情報を印刷しないように指示します。デフォルトでは、出力がリダイレクトされると進捗情報を印刷します。)
この情報は常に利用できるわけではないので、これを処理できるようにスクリプトを準備する必要があります。