Comment puis-je télécharger un fichier dans un répertoire spécifique ?
Question
J'ai récemment essayé de créer un programme en python qui télécharge des fichiers dans un répertoire spécifique.J'utilise Ubuntu et jusqu'à présent j'ai ceci
import os
import getpass
import urllib2
y = getpass.getuser()
if not os.access('/home/' + y + '/newdir/', os.F_OK):
print("Making New Directory")
os.mkdir('/home/' + y + '/newdir/')
url = ("http://example.com/Examplefile.ex")
file_name = url.split('/')[-1]
u = urllib2.urlopen(url)
f = open(file_name, 'wb')
meta = u.info()
file_size = int(meta.getheaders("Content-Length")[0])
print "Downloading: %s Bytes: %s" % (file_name, file_size)
file_size_dl = 0
block_sz = 8192
while True:
buffer = u.read(block_sz)
if not buffer:
break
file_size_dl += len(buffer)
f.write(buffer)
status = r"%10d [%3.2f%%]" % (file_size_dl, file_size_dl * 100. / file_size)
status = status + chr(8)*(len(status)+1)
print status,
f.close()
cela télécharge actuellement le fichier dans le même répertoire, comment puis-je changer le répertoire dans lequel il est téléchargé ?
correction du nouveau code :
import os
import getpass
import urllib2
y = getpass.getuser()
if not os.access('/home/' + y + '/newdir/', os.F_OK):
print("Making New Directory")
os.mkdir('/home/' + y + '/newdir/')
os.chdir('/home/'+y+'/newdir/')
url = ("http://example.com/Examplefile.ex")
file_name = url.split('/')[-1]
u = urllib2.urlopen(url)
f = open(file_name, 'wb')
meta = u.info()
file_size = int(meta.getheaders("Content-Length")[0])
print "Downloading: %s Bytes: %s" % (file_name, file_size)
file_size_dl = 0
block_sz = 8192
while True:
buffer = u.read(block_sz)
if not buffer:
break
file_size_dl += len(buffer)
f.write(buffer)
status = r"%10d [%3.2f%%]" % (file_size_dl, file_size_dl * 100. / file_size)
status = status + chr(8)*(len(status)+1)
print status,
f.close()
La solution
Désolé gars, j'étais stupide mais je répondais à la question que j'ai ajoutée
os.chdir('/home/' + y + '/newdir/')
juste après le premier si instruction EX:
import os
import getpass
import urllib2
y = getpass.getuser()
if not os.access('/home/' + y + '/newdir/', os.F_OK):
print("Making New Directory")
os.mkdir('/home/' + y + '/newdir/')
os.chdir('/home/'+y+'/newdir/')
url = ("http://example.com/Examplefile.ex")
file_name = url.split('/')[-1]
u = urllib2.urlopen(url)
f = open(file_name, 'wb')
meta = u.info()
file_size = int(meta.getheaders("Content-Length")[0])
print "Downloading: %s Bytes: %s" % (file_name, file_size)
file_size_dl = 0
block_sz = 8192
while True:
buffer = u.read(block_sz)
if not buffer:
break
file_size_dl += len(buffer)
f.write(buffer)
status = r"%10d [%3.2f%%]" % (file_size_dl, file_size_dl * 100. / file_size)
status = status + chr(8)*(len(status)+1)
print status,
f.close()
Autres conseils
Passez le répertoire à open()
dans le nom du fichier.
Utiliser os.path.join pour ajouter le répertoire à file_name
:
from os.path import join
directory = join('/home/', y, '/newdir/')
# You can now use directory everywhere you used to build the directory name
# and then, later in the script:
file_name = url.split('/')[-1]
file_name = join(directory, file_name)
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow