Python讀取Pickle文件信息并計(jì)算與當(dāng)前時(shí)間間隔的方法分析
本文實(shí)例講述了Python讀取Pickle文件信息并計(jì)算與當(dāng)前時(shí)間間隔的方法。分享給大家供大家參考,具體如下:
python—–讀取Pickle文件信息計(jì)算出與當(dāng)前的時(shí)間間隔
生成h_dic.pkl文件信息
root@kali:~/python/snmp# cat snmpserver.py #!/usr/bin/python # --*-- coding:utf-8 --*-- import datetime#導(dǎo)入時(shí)間戳 import SocketServer import pickle pfile = 'h_dic.pkl'#定義pickle文件,并生成h_dic.pkl文件 #讀取目錄下的celie.txt文件 host_status = {}#新建字典,使用IP地址作為KEY值。作用是來(lái)判斷每個(gè)客戶端IP多久與服務(wù)器通信一次的 f = open('celie.txt')#調(diào)用策略文檔,在里面的ip地址就可以通過(guò),并發(fā)送信息 while True: line = f.readline().split() if len(line) == 0:break print line[0]#打印第一個(gè)IP地址信息 host_status[line[0]] = []#給字典第一個(gè)設(shè)置為空,這樣后面只要直接追加值就ok了 f.close() class myMonitorHandler(SocketServer.BaseRequestHandler): '''This is the Monitor server''' def handle(self): recv_data = self.request.recv(1024)#接收客戶端數(shù)據(jù) if self.client_address[0] == '192.168.72.130':#如果IP為本機(jī)IP地址,就重新寫(xiě)入pickle文件信息 f2 = file(pfile,'w')#使用pickle模塊可寫(xiě)模式打開(kāi)文件f2 pickle.dump(host_status,f2)#使用pickle帶參數(shù)為字典名與文件名 f2.close()#關(guān)閉文件f2 if self.client_address[0] in host_status.keys():#如果存在字典中的ip地址信息,就返回對(duì)應(yīng)客戶端發(fā)送的Ip、時(shí)間戳、信息 #self.client_address為數(shù)組('192.168.72.129', 49109)的值。只要當(dāng)中的IP地址,因此取self.client_address[0] #把host_status字典中的self.client_address[0]值即IP地址值賦值有兩個(gè)值,因此新建個(gè)列表,存取兩個(gè)值時(shí)間戳與接收的信息 #如:{'192.168.72.129': [(datetime.datetime(2017, 8, 20, 21, 29, 59, 415054), 'up')]} #host_status[self.client_address[0]] = [(datetime.datetime.now(),recv_data)] #直接把元組append進(jìn)字典 host_status[self.client_address[0]].append((datetime.datetime.now(),recv_data)) print 'From %s : %s %s' %(self.client_address,datetime.datetime.now(),recv_data)#打印客戶端地址、操作的時(shí)間戳值與接收的數(shù)據(jù) #print host_status else:#不存在字典中,則如下提示信息 print "sorry, ip %s is not in the monitor list" % self.client_address[0] #打印出192.168.72.129 [(datetime.datetime(2017, 8, 20, 22, 1, 6, 705498), 'up')] for t,m in host_status.items(): print t,m if __name__ == "__main__":#當(dāng)自己運(yùn)行時(shí)調(diào)用什么什么;當(dāng)被其他程序調(diào)用時(shí)調(diào)用什么什么,如果被其他程序調(diào)用了,下面代碼不執(zhí)行 host,port = '',18000 server = SocketServer.ThreadingTCPServer((host,port),myMonitorHandler)#調(diào)用TCP的多線程 server.serve_forever() root@kali:~/python/snmp#
pickle文件信息
root@kali:~/python/snmp# ls celie.txt h_dic.pkl m_handle.py snmpclient2.py snmpserver.py tab.py tab.pyc root@kali:~/python/snmp# cat h_dic.pkl (dp0 S'192.168.72.129' p1 (lp2 (cdatetime datetime p3 (S'\x07\xe1\x08\x16\x149\x1b\x02\xd0F' p4 tp5 Rp6 S'up' p7 tp8 a(g3 (S'\x07\xe1\x08\x16\x149#\x03\xeag' p9 tp10 Rp11 S'up' p12 tp13 a(g3 (S'\x07\xe1\x08\x16\x149*\x01Fd' p14 tp15 Rp16 S'up' p17 tp18 a(g3 (S"\x07\xe1\x08\x16\x14:'\x06\x9di" p19 tp20 Rp21 S'up' p22 tp23 a(g3 (S'\x07\xe1\x08\x16\x15\x0c\x16\x00=\x9f' p24 tp25 Rp26 S'up' p27 tp28 a(g3 (S'\x07\xe1\x08\x16\x15\x0c\x16\te\x8c' p29 tp30 Rp31 S'up' p32 tp33 as.root@kali:~/python/snmp#
調(diào)用h_dic.pkl文件m_handle.py的代碼
運(yùn)行情況1
root@kali:~/python/snmp# cat m_handle.py #!/usr/bin/python # --*-- coding:utf-8 --*-- from datetime import datetime#導(dǎo)入時(shí)間模塊 import pickle#導(dǎo)入pickle模塊 f = file('h_dic.pkl','rb')#使用rb讀取模式打開(kāi)pickle文件 host_status = pickle.load(f)#使用pickle的load方式打開(kāi)文件,變成字典 for h,m in host_status.items():#在字典中循環(huán)元素 if len(m) != 0:#如果時(shí)間值不為空,則進(jìn)入 print h,m[-1] root@kali:~/python/snmp# python m_handle.py 192.168.72.129 (datetime.datetime(2017, 8, 22, 21, 12, 22, 615820), 'up') root@kali:~/python/snmp#
運(yùn)行情況2
root@kali:~/python/snmp# cat m_handle.py #!/usr/bin/python # --*-- coding:utf-8 --*-- from datetime import datetime#導(dǎo)入時(shí)間模塊 import pickle#導(dǎo)入pickle模塊 f = file('h_dic.pkl','rb')#使用rb讀取模式打開(kāi)pickle文件 host_status = pickle.load(f)#使用pickle的load方式打開(kāi)文件,變成字典 for h,m in host_status.items():#在字典中循環(huán)元素 if len(m) != 0:#如果時(shí)間值不為空,則進(jìn)入 old_time = m[-1][0]#取時(shí)間值出來(lái) print h,(datetime.now() - old_time).seconds#打印主機(jī)ip,當(dāng)前時(shí)間減去從pickle文件中讀取的值 root@kali:~/python/snmp#
運(yùn)行情況
root@kali:~/python/snmp# python m_handle.py 192.168.72.129 1007 root@kali:~/python/snmp#
運(yùn)行情況2
root@kali:~/python/snmp# cat m_handle.py #!/usr/bin/python # --*-- coding:utf-8 --*-- from datetime import datetime#導(dǎo)入時(shí)間模塊 import pickle#導(dǎo)入pickle模塊 f = file('h_dic.pkl','rb')#使用rb讀取模式打開(kāi)pickle文件 host_status = pickle.load(f)#使用pickle的load方式打開(kāi)文件,變成字典 for h,m in host_status.items():#在字典中循環(huán)元素 if len(m) != 0:#如果時(shí)間值不為空,則進(jìn)入 old_time = m[-1][0]#取時(shí)間值出來(lái) time_diff = (datetime.now() - old_time).seconds#當(dāng)前時(shí)間減去從pickle文件中讀取的值,為時(shí)間差值 if time_diff > 30:#如果時(shí)間差大于30秒,則進(jìn)入 print 'No data received from %s for %s ,please check!' %(h,time_diff) else: print h,(datetime.now() - old_time).seconds#打印主機(jī)ip,時(shí)間差值 root@kali:~/python/snmp# root@kali:~/python/snmp# python m_handle.py No data received from 192.168.72.129 for 494 ,please check! root@kali:~/python/snmp#
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python文件與目錄操作技巧匯總》、《Python文本文件操作技巧匯總》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》及《Python入門(mén)與進(jìn)階經(jīng)典教程》
希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。
相關(guān)文章
如何使用Tkinter進(jìn)行窗口的管理與設(shè)置
Tkinter是Python的標(biāo)準(zhǔn)GUI庫(kù),它實(shí)際是建立在Tk技術(shù)上的。在大多數(shù)Unix平臺(tái)以及Windows系統(tǒng)上都可用2021-06-06Python3 用matplotlib繪制sigmoid函數(shù)的案例
這篇文章主要介紹了Python3 用matplotlib繪制sigmoid函數(shù)的案例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-12-12Python變量名詳細(xì)規(guī)則詳細(xì)變量值介紹
這篇文章主要介紹了Python變量名詳細(xì)規(guī)則詳細(xì)變量值,Python需要使用標(biāo)識(shí)符給變量命名,其實(shí)標(biāo)識(shí)符就是用于給程序中變量、類(lèi)、方法命名的符號(hào)(簡(jiǎn)單來(lái)說(shuō),標(biāo)識(shí)符就是合法的名稱,下面葛小編一起進(jìn)入文章里哦阿姐更多詳細(xì)內(nèi)容吧2022-01-01Pipenv輕量級(jí)虛擬環(huán)境管理工具使用指南
這篇文章主要為大家介紹了Pipenv輕量級(jí)虛擬環(huán)境管理工具使用指南,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02jetson上安裝pycharm的詳細(xì)過(guò)程
Pycharm是一個(gè)非常優(yōu)秀的代碼編輯、調(diào)試,開(kāi)發(fā)軟件,我平時(shí)在Windows系統(tǒng)學(xué)習(xí)編程時(shí)也比較喜歡使用Pycharm,這篇文章主要介紹了jetson上安裝pycharm的過(guò)程,需要的朋友可以參考下2022-07-07python 中值濾波,椒鹽去噪,圖片增強(qiáng)實(shí)例
今天小編就為大家分享一篇python 中值濾波,椒鹽去噪,圖片增強(qiáng)實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-12-12Python實(shí)現(xiàn)貪吃蛇小游戲(雙人模式)
這篇文章主要為大家詳細(xì)介紹了Python實(shí)現(xiàn)雙人模式的貪吃蛇小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09Tensorflow加載Vgg預(yù)訓(xùn)練模型操作
這篇文章主要介紹了Tensorflow加載Vgg預(yù)訓(xùn)練模型操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-05-05