如果超过 1 天,则根据上次修改日期下载文件将失败



下面是一个代码片段,它根据服务器和本地之间的上次修改日期下载文件。

try:
    url = "https://10.10.10.10/version.ini"
    local_ini = ".//config/version.ini"
    filetime = (time.strftime('%a, %d %b %Y %X GMT', time.gmtime(os.path.getmtime(local_ini))))
    print("File Last Modified: {0}".format(filetime))
    r = requests.get(url,stream=True)
    meta = r.headers['last-modified']
    logging.info("Web  Last Modified: {0}".format(meta))
    if filetime < meta:
        print("Newer file found! Downloading...")
        if r != False:
            try:
                fileName = os.path.basename(urlparse.urlsplit(r.url)[2])
                with open(".//config/version.ini"e, 'wb') as f:
                     shutil.copyfileobj(r.raw,f)    
            finally:
                r.close()
    else:
        logging.info('No new version found. You got the latest file!') 
except requests.exceptions.RequestException as e:  
    logging.info(e)    

当我在同一天修改文件时,我得到正确的结果:

File Last Modified: Thu, 12 Jan 2017 03:42:23 GMT
Web  Last Modified: Thu, 12 Jan 2017 03:44:22 GMT
Newer file found! Downloading...

但是当我修改文件时,一天后我得到错误的结果:

File Last Modified: Wed, 11 Jan 2017 08:38:38 GMT
Web  Last Modified: Thu, 12 Jan 2017 02:44:45 GMT
No new version found. You got the latest file!

为什么时间戳比较给出错误的结果?

在你的例子中,meta是一个字符串,而不是一个time对象。 如果你比较两个datetime对象,你会有更好的运气:

if (dt.datetime.strptime(filetime, '%a, %d %b %Y %X GMT') < 
        dt.datetime.strptime(meta, '%a, %d %b %Y %X GMT')):

您将需要:

 import datetime as dt

最新更新