Python读取Pickle文件信息并计算与当前时间间隔的方法分析
本文实例讲述了Python读取Pickle文件信息并计算与当前时间间隔的方法。分享给大家供大家参考,具体如下:
python—–读取Pickle文件信息计算出与当前的时间间隔
生成h_dic.pkl文件信息
root@kali:~/python/snmp#catsnmpserver.py #!/usr/bin/python #--*--coding:utf-8--*-- importdatetime#导入时间戳 importSocketServer importpickle pfile='h_dic.pkl'#定义pickle文件,并生成h_dic.pkl文件 #读取目录下的celie.txt文件 host_status={}#新建字典,使用IP地址作为KEY值。作用是来判断每个客户端IP多久与服务器通信一次的 f=open('celie.txt')#调用策略文档,在里面的ip地址就可以通过,并发送信息 whileTrue: line=f.readline().split() iflen(line)==0:break printline[0]#打印第一个IP地址信息 host_status[line[0]]=[]#给字典第一个设置为空,这样后面只要直接追加值就ok了 f.close() classmyMonitorHandler(SocketServer.BaseRequestHandler): '''ThisistheMonitorserver''' defhandle(self): recv_data=self.request.recv(1024)#接收客户端数据 ifself.client_address[0]=='192.168.72.130':#如果IP为本机IP地址,就重新写入pickle文件信息 f2=file(pfile,'w')#使用pickle模块可写模式打开文件f2 pickle.dump(host_status,f2)#使用pickle带参数为字典名与文件名 f2.close()#关闭文件f2 ifself.client_address[0]inhost_status.keys():#如果存在字典中的ip地址信息,就返回对应客户端发送的Ip、时间戳、信息 #self.client_address为数组('192.168.72.129',49109)的值。只要当中的IP地址,因此取self.client_address[0] #把host_status字典中的self.client_address[0]值即IP地址值赋值有两个值,因此新建个列表,存取两个值时间戳与接收的信息 #如:{'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进字典 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)#打印客户端地址、操作的时间戳值与接收的数据 #printhost_status else:#不存在字典中,则如下提示信息 print"sorry,ip%sisnotinthemonitorlist"%self.client_address[0] #打印出192.168.72.129[(datetime.datetime(2017,8,20,22,1,6,705498),'up')] fort,minhost_status.items(): printt,m if__name__=="__main__":#当自己运行时调用什么什么;当被其他程序调用时调用什么什么,如果被其他程序调用了,下面代码不执行 host,port='',18000 server=SocketServer.ThreadingTCPServer((host,port),myMonitorHandler)#调用TCP的多线程 server.serve_forever() root@kali:~/python/snmp#
pickle文件信息
root@kali:~/python/snmp#ls celie.txth_dic.pklm_handle.pysnmpclient2.pysnmpserver.pytab.pytab.pyc root@kali:~/python/snmp#cath_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#
调用h_dic.pkl文件m_handle.py的代码
运行情况1
root@kali:~/python/snmp#catm_handle.py #!/usr/bin/python #--*--coding:utf-8--*-- fromdatetimeimportdatetime#导入时间模块 importpickle#导入pickle模块 f=file('h_dic.pkl','rb')#使用rb读取模式打开pickle文件 host_status=pickle.load(f)#使用pickle的load方式打开文件,变成字典 forh,minhost_status.items():#在字典中循环元素 iflen(m)!=0:#如果时间值不为空,则进入 printh,m[-1] root@kali:~/python/snmp#pythonm_handle.py 192.168.72.129(datetime.datetime(2017,8,22,21,12,22,615820),'up') root@kali:~/python/snmp#
运行情况2
root@kali:~/python/snmp#catm_handle.py #!/usr/bin/python #--*--coding:utf-8--*-- fromdatetimeimportdatetime#导入时间模块 importpickle#导入pickle模块 f=file('h_dic.pkl','rb')#使用rb读取模式打开pickle文件 host_status=pickle.load(f)#使用pickle的load方式打开文件,变成字典 forh,minhost_status.items():#在字典中循环元素 iflen(m)!=0:#如果时间值不为空,则进入 old_time=m[-1][0]#取时间值出来 printh,(datetime.now()-old_time).seconds#打印主机ip,当前时间减去从pickle文件中读取的值 root@kali:~/python/snmp#
运行情况
root@kali:~/python/snmp#pythonm_handle.py 192.168.72.1291007 root@kali:~/python/snmp#
运行情况2
root@kali:~/python/snmp#catm_handle.py #!/usr/bin/python #--*--coding:utf-8--*-- fromdatetimeimportdatetime#导入时间模块 importpickle#导入pickle模块 f=file('h_dic.pkl','rb')#使用rb读取模式打开pickle文件 host_status=pickle.load(f)#使用pickle的load方式打开文件,变成字典 forh,minhost_status.items():#在字典中循环元素 iflen(m)!=0:#如果时间值不为空,则进入 old_time=m[-1][0]#取时间值出来 time_diff=(datetime.now()-old_time).seconds#当前时间减去从pickle文件中读取的值,为时间差值 iftime_diff>30:#如果时间差大于30秒,则进入 print'Nodatareceivedfrom%sfor%s,pleasecheck!'%(h,time_diff) else: printh,(datetime.now()-old_time).seconds#打印主机ip,时间差值 root@kali:~/python/snmp# root@kali:~/python/snmp#pythonm_handle.py Nodatareceivedfrom192.168.72.129for494,pleasecheck! root@kali:~/python/snmp#
更多关于Python相关内容感兴趣的读者可查看本站专题:《Python文件与目录操作技巧汇总》、《Python文本文件操作技巧汇总》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python入门与进阶经典教程》
希望本文所述对大家Python程序设计有所帮助。