Python讀取指定日期郵件的實例
背景:9月份有部分?jǐn)?shù)據(jù)缺失,這部分?jǐn)?shù)據(jù)在郵箱里,需要重新拉取,但是每天幾百封郵件,總共有6、7萬封郵件,使用stat()和retr(which)結(jié)合遍歷很
耗時
基于如上背景,初始大致思路為:
使用二分法獲取到需要恢復(fù)數(shù)據(jù)時間范圍內(nèi)的中間一個值,也就是第幾封郵件,然后分兩頭遍歷,
讀取到所有需要的郵件
算法函數(shù):
1、獲取到郵件的時間,由于可能收到格林威治時間郵件,所以這里做了相應(yīng)的處理
def getTimeStamp(cn): messages=mailServer.retr(cn)[1] mail = email.message_from_bytes('\n'.encode('utf-8').join(messages)) date=email.header.decode_header(mail.get('date')) utcstr = date[0][0].replace('+00:00','') global utcdatetime try: utcdatetime = datetime.datetime.strptime(utcstr, '%a, %d %b %Y %H:%M:%S +0000 (GMT)') localdatetime = utcdatetime + datetime.timedelta(hours=+8) localtimestamp = localdatetime.timestamp() except: utcdatetime = datetime.datetime.strptime(utcstr, '%a, %d %b %Y %H:%M:%S +0800') localtimestamp = utcdatetime.timestamp() return localtimestamp
2、二分法
bu_daytimestamp yesterdaytimestamp兩個是需要補數(shù)據(jù)的時間戳
key_nums=0 mid2=mailCount while 1==1: mid=getTimeStamp(round(mailCount)) mid2=round(mid2/2) if mid >bu_daytimestamp: mailCount=mailCount-mid2 elif mid<yesterdaytimestamp: mailCount=mailCount+mid2 elif mid <=bu_daytimestamp and mid >=yesterdaytimestamp: key_nums=mailCount break print(mailCount) print(key_nums)
這里只記錄算法,后續(xù)遍歷比較簡單,就不展示了
解釋下部分參數(shù):
mailServer:登錄后的郵箱
mailCount:總的郵件數(shù)量,來源于mailServer.stat()第二個參數(shù)
以上這篇Python讀取指定日期郵件的實例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python3讀寫Excel文件(使用xlrd,xlsxwriter,openpyxl3種方式讀寫實例與優(yōu)劣)
這篇文章主要介紹了Python3讀寫Excel文件,使用xlrd,xlsxwriter,openpyxl3種方式讀寫實例與優(yōu)劣,需要的朋友可以參考下2020-02-02解析python調(diào)用函數(shù)加括號和不加括號的區(qū)別
這篇文章主要介紹了python調(diào)用函數(shù)加括號和不加括號的區(qū)別,不帶括號時,調(diào)用的是這個函數(shù)本身 ,是整個函數(shù)體,是一個函數(shù)對象,不須等該函數(shù)執(zhí)行完成,具體實例代碼跟隨小編一起看看吧2021-10-10Python算法輸出1-9數(shù)組形成的結(jié)果為100的所有運算式
這篇文章主要介紹了Python算法輸出1-9數(shù)組形成的結(jié)果為100的所有運算式,然后介紹了另外一個相關(guān)實例,具體內(nèi)容請參閱正文,需要的朋友可以參考下。2017-11-11Python可變參數(shù)會自動填充前面的默認(rèn)同名參數(shù)實例
今天小編就為大家分享一篇Python可變參數(shù)會自動填充前面的默認(rèn)同名參數(shù)實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11