J'essaie de télécharger des fichiers de données publics. J'ai fait un screenscrape pour obtenir les liens vers les fichiers qui ressemblent tous à ceci
ftp://ftp.cdc.gov/pub/Health_Statistics/NCHS/nhanes/2001-2002/L28POC_B.xpt
Je ne trouve aucune documentation sur le site Web de la bibliothèque Requests. 1
Merci d'avance!
La bibliothèque requests
ne prend pas en charge les liens ftp.
Pour télécharger un fichier depuis un serveur FTP, vous pouvez:
import urllib
urllib.urlretrieve('ftp://server/path/to/file', 'file')
# if you need to pass credentials:
# urllib.urlretrieve('ftp://username:password@server/path/to/file', 'file')
Ou:
import shutil
import urllib2
from contextlib import closing
with closing(urllib2.urlopen('ftp://server/path/to/file')) as r:
with open('file', 'wb') as f:
shutil.copyfileobj(r, f)
Vous pouvez essayer ceci
import ftplib
path = 'pub/Health_Statistics/NCHS/nhanes/2001-2002/'
filename = 'L28POC_B.xpt'
ftp = ftplib.FTP("Server IP")
ftp.login("UserName", "Password")
ftp.cwd(path)
ftp.retrbinary("RETR " + filename, open(filename, 'wb').write)
ftp.quit()
Utilisez urllib2 . Pour plus de détails, consultez cet exemple de doc.python.org :
Voici un extrait du tutoriel qui peut aider
import urllib2
req = urllib2.Request('ftp://example.com')
response = urllib2.urlopen(req)
the_page = response.read()
import os
import ftplib
from contextlib import closing
with closing(ftplib.FTP()) as ftp:
try:
ftp.connect(Host, port, 30*5) #5 mins timeout
ftp.login(login, passwd)
ftp.set_pasv(True)
with open(local_filename, 'w+b') as f:
res = ftp.retrbinary('RETR %s' % orig_filename, f.write)
if not res.startswith('226 Transfer complete'):
print('Downloaded of file {0} is not compile.'.format(orig_filename))
os.remove(local_filename)
return None
return local_filename
except:
print('Error during download from FTP')
Comme plusieurs personnes l'ont noté, les requêtes ne prennent pas en charge FTP, mais Python possède d'autres bibliothèques. Si vous souhaitez continuer à utiliser la bibliothèque de requêtes, il existe un paquet request-ftp qui ajoute une fonctionnalité FTP aux requêtes. J'ai un peu utilisé cette bibliothèque et ça marche. La documentation est pleine d'avertissements sur la qualité du code. À compter de la version 0.2.0, les docs disent: "Cette bibliothèque a été travaillée en cowboy en environ 4 heures de travail total, ne comporte pas de test et repose sur quelques logiciels malveillants".
import requests, requests_ftp
requests_ftp.monkeypatch_session()
response = requests.get('ftp://example.com/foo.txt')
Essayez d’utiliser la bibliothèque wget pour python. Vous pouvez trouver la documentation correspondante ici .
import wget
link = 'ftp://example.com/foo.txt'
wget.download(link)
urllib2.urlopen
gère les liens ftp.
urlretrieve n’est pas un travail pour moi, et le fonctionnaire document a déclaré qu’ils pourraient devenir obsolètes à l’avenir.
import shutil
from urllib.request import URLopener
opener = URLopener()
url = 'ftp://ftp_domain/path/to/the/file'
store_path = 'path//to//your//local//storage'
with opener.open(url) as remote_file, open(store_path, 'wb') as local_file:
shutil.copyfileobj(remote_file, local_file)