Jestem całkiem nowy w Pythonie i szukam wskazówek dla pytania, które dla wielu może wydawać się trywialne.
Czy istnieje sposób użycia „wget” w skrypcie Pythona do pobierania plików rastrowych z serwera i przetwarzania ich w tym samym skrypcie?
Python ma wbudowane urllib2 , które otwierają obiekt podobny do wskaźnika pliku z zasobu IP (HTTP, HTTPS, FTP).
import urllib2, os
# See http://data.vancouver.ca/datacatalogue/2009facetsGridSID.htm
rast_url = 'ftp://webftp.vancouver.ca/opendata/2009sid/J01.zip'
infp = urllib2.urlopen(rast_url)
Następnie możesz przesłać i zapisać bajty lokalnie (tj. Pobrać):
# Open a new file for writing, same filename as source
rast_fname = os.path.basename(rast_url)
outfp = open(rast_fname, 'wb')
# Transfer data .. this can take a while ...
outfp.write(infp.read())
outfp.close()
print('Your file is at ' + os.path.join(os.getcwd(), rast_fname))
Teraz możesz zrobić, co chcesz z plikiem.
Kilka sposobów na osiągnięcie tego. Możesz użyć modułu podprocesu do wywołania wget - patrz http://docs.python.org/library/subprocess.html
import subprocess
retcode = subprocess.call(["wget", args])
Możesz też użyć Pythona, aby pobrać plik bezpośrednio za pomocą modułu urllib (lub urllib2) - http://docs.python.org/library/urllib.html . Istnieją przykłady w dokumentacji.
źródło
W poprzedniej odpowiedzi jest metoda wykorzystująca wywołanie do os.system.
źródło