Staging
v0.5.1
https://github.com/python/cpython
Revision 427613f005f0f412d12f0d775d2b609bae0ae1ad authored by Irit Katriel on 01 December 2020, 01:35:25 UTC, committed by GitHub on 01 December 2020, 01:35:25 UTC
1 parent 1244c81
Raw File
Tip revision: 427613f005f0f412d12f0d775d2b609bae0ae1ad authored by Irit Katriel on 01 December 2020, 01:35:25 UTC
bpo-42482: remove reference to exc_traceback from TracebackException (GH-23531)
Tip revision: 427613f
urlretrieve.py
# Simple Python script to download a file. Used as a fallback
# when other more reliable methods fail.
#
from __future__ import print_function
import sys

try:
    from requests import get
except ImportError:
    try:
        from urllib.request import urlretrieve
        USING = "urllib.request.urlretrieve"
    except ImportError:
        try:
            from urllib import urlretrieve
            USING = "urllib.retrieve"
        except ImportError:
            print("Python at", sys.executable, "is not suitable",
                  "for downloading files.", file=sys.stderr)
            sys.exit(2)
else:
    USING = "requests.get"

    def urlretrieve(url, filename):
        r = get(url, stream=True)
        r.raise_for_status()
        with open(filename, 'wb') as f:
            for chunk in r.iter_content(chunk_size=1024):
                f.write(chunk)
        return filename

if __name__ == '__main__':
    if len(sys.argv) != 3:
        print("Usage: urlretrieve.py [url] [filename]", file=sys.stderr)
        sys.exit(1)
    URL = sys.argv[1]
    FILENAME = sys.argv[2]
    print("Downloading from", URL, "to", FILENAME, "using", USING)
    urlretrieve(URL, FILENAME)
back to top