我已经搜索了几天,但还没有找到答案。
我试图从 FTP 下载视频文件,我的脚本检查服务器,将 nlist() 与从文本文件解析的已下载文件列表进行比较,然后创建一个新的文件列表以获取并迭代它下载每个文件,断开与服务器的连接并重新连接下一个文件(我认为服务器超时可能是一个问题,所以我在每次文件下载后退出()连接)。
这适用于前几个文件,但是一旦我遇到一个耗时超过 5 分钟的文件,fitlib 就会在传输结束时挂起(我可以在资源管理器中看到文件大小正确,因此下载已经完成,但是它似乎没有收到消息并继续下一个文件)
任何帮助将不胜感激,我的代码如下:
newPath = "Z:\\pathto\\downloads\\"
for f in getFiles:
print("Getting " + f)
for f in getFiles:
fil = f.rstrip()
ext = os.path.splitext(fil)[1]
if ext in validExtensions:
print("Downloading new file: " + fil)
downloadFile(fil, newPath)
这是下载.py
from ftplib import FTP
def downloadFile(filename, folder):
myhost = 'host'
myuser = 'user'
passw = 'pass'
#login
ftp = FTP(myhost,myuser,passw)
localfile = open(folder + filename, 'wb')
ftp.retrbinary("RETR " + filename, localfile.write, 1024)
print("Downloaded " + filename)
localfile.close()
ftp.quit()