仅下载循环的第一个文件

时间:2013-10-08 12:40:02

标签: python oop loops ftp traceback

我编写了一个类,当调用类实例时,从ftp站点(ftp://ladsweb.nascom.nasa.gov/allData/5/MOD11A1/)下载一个文件,给出部分文件名。后来我写了一个for循环并在for循环中集成了类实例,这样我就可以下载多个日期范围内的文件。这是一系列日期,因为文件是根据它们生成的日期命名的。所以有日常文件。运行代码时,系统会要求您输入一系列日期。成功下载了该范围的第一个文件,但是当程序停止并打印出以下错误时:

Traceback (most recent call last):
      File "ftplib04Simplified.py", line 42, in <module>
        FtpDownloader("ladsweb.nascom.nasa.gov","/allData/5/MOD11A1/",a).findFile(10,11)
      File "ftplib04Simplified.py", line 32, in findFile
        self.ftp.retrbinary('RETR %s' % filename, open(filename,'wb').write)
      File "/usr/lib/python3.3/ftplib.py", line 424, in retrbinary
        with self.transfercmd(cmd, rest) as conn:
      File "/usr/lib/python3.3/ftplib.py", line 386, in transfercmd
        return self.ntransfercmd(cmd, rest)[0]
      File "/usr/lib/python3.3/ftplib.py", line 352, in ntransfercmd
        resp = self.sendcmd(cmd)
      File "/usr/lib/python3.3/ftplib.py", line 259, in sendcmd
        return self.getresp()
      File "/usr/lib/python3.3/ftplib.py", line 233, in getresp
        raise error_perm(resp)
    ftplib.error_perm: 550 No such file.

    shell returned 1

我知道纯粹的类设计会让我感到羞耻,但这是我写的完整代码: 附:这是用Python 3编写的。如果你运行代码,当被要求输入时,请在2001年之后输入一个日期。

import ftplib
import math
import datetime as dt
import time
class FtpDownloader:
    """Downloads raster tiles given the date, and tile row and column number"""
    def __init__(self,site,directory,raw_date,ftp=None):
        """logs in to ftp"""
        self.site=site
        self.directory=directory
        self.raw_date=raw_date
        self.ftp=ftplib.FTP(site)
        self.ftp.login()
        self.convert_date()
    def convert_date(self):
        """converts YYYY-MM-DD format to year and day of the year"""
        year=self.raw_date.strftime("%Y")
        day=self.raw_date.strftime("%j")
        self.go_to_folder(year,day)
    def go_to_folder(self,year,day):
        """sets the current FTP directory"""
        self.ftp.cwd(self.directory+"%s/%s/" % (year,day))
    def findFile(self,h,v,fileList=[]):
        """checks for the file containing the given h and h and downloads it using retrbinary"""
        hh= "%02d" % h
        vv= "%02d" % v
        tilename = "h%sv%s" % (hh,vv)
        print ("Image tile %s is downloading..." % tilename)
        self.ftp.retrlines('NLST',fileList.append)
        for filename in fileList:
            if tilename in filename:
                self.ftp.retrbinary('RETR %s' % filename, open(filename,'wb').write)
                print ("File downloaded")
                break
        else:
            print (filename, "not found")
        self.ftp.close()
start=dt.datetime.strptime(input("Enter a start date in YYYY-MM-DD format "),"%Y-%m-%d")
end=dt.datetime.strptime(input("Enter an end date in YYYY-MM-DD format "),"%Y-%m-%d")
for i in range((end-start).days + 1):
    a=(start+dt.timedelta(days=i)).date()
    FtpDownloader("ladsweb.nascom.nasa.gov","/allData/5/MOD11A1/",a).findFile(10,11)

1 个答案:

答案 0 :(得分:-1)

这就是您指示计算机执行的操作:break在下载第一个文件后立即中断下载循环:

def findFile(self,h,v,fileList=[]):
    """checks for the file containing the given h and h and downloads it using retrbinary"""
    hh= "%02d" % h
    vv= "%02d" % v
    tilename = "h%sv%s" % (hh,vv)
    print ("Image tile %s is downloading..." % tilename)
    self.ftp.retrlines('NLST',fileList.append)
    for filename in fileList:
        if tilename in filename:
            self.ftp.retrbinary('RETR %s' % filename, open(filename,'wb').write)
            print ("File downloaded")
            break
    else:
        print (filename, "not found")
    self.ftp.close()

只需替换上面break的{​​{1}}即可。 - 更好的是,因为你的for循环中没有其他语句,所以只需完全删除该行。