python脚本实现统计日志文件中的ip访问次数代码分享
作者:junjie 时间:2021-03-17 08:40:08
适用的日志格式:
106.45.185.214 - - [06/Aug/2014:07:38:59 +0800] "GET / HTTP/1.0" 200 10 "-" "-"
171.104.119.22 - - [06/Aug/2014:08:55:01 +0800] "GET / HTTP/1.0" 200 10 "-" "-"
27.31.238.242 - - [06/Aug/2014:09:43:19 +0800] "GET / HTTP/1.0" 200 10 "-" "-"
218.65.202.131 - - [06/Aug/2014:10:33:59 +0800] "GET / HTTP/1.0" 200 10 "-" "-"
以上为nginx的日志,本程序只适合用于IP在开头并用空格分开的这种格式。
实例代码:
import sys
class Log:
def __init__(self, filename,dic,count):
self.filename = filename
self.dic=dic
self.count=count
def parse(self):
i=1
f=file(self.filename)
while True:
line=f.readline()
if len(line)==0:
break
ip=line.split(' ')
if ip[0] in dic:
self.dic[ip[0]]=self.dic[ip[0]]+1
else:
self.dic[ip[0]]=i
soredic=sorted(self.dic.items(), key=lambda d:d[1],reverse=True)
counts=0;
for item in soredic:
if counts==int(self.count):
break
print("IP:%s Total Times: %s"%(item[0],item[1]))
counts=counts+1
f.close()
if __name__=="__main__":
if len(sys.argv)<3:
print('usage:log.py log.log toptimes\nexample log.py log.log 20\ncode by iswin')
sys.exit()
dic={}
log=Log(sys.argv[1],dic,sys.argv[2])
log.parse()
标签:python,统计,ip
0
投稿
猜你喜欢
python 爬虫百度地图的信息界面的实现方法
2021-11-10 20:29:35
Python包管理工具pip的15 个使用小技巧
2023-08-30 17:30:51
asp如何做一个看他爱不爱你的小测验?
2010-07-11 21:16:00
淘宝首页代码调整
2011-04-22 12:44:00
弹出网页窗口全详细攻略
2008-04-18 12:10:00
浅谈numpy广播机制
2023-08-25 22:07:51
Python序列对象与String类型内置方法详解
2023-09-22 13:25:18
ASP编程入门进阶(十一):Chat聊天程序
2008-05-12 07:06:00
ASP开发中有用的函数(function)集合(3)
2008-10-14 17:20:00
详解python学习笔记之解释器
2023-09-15 15:28:26
python绘制地震散点图
2021-12-21 13:09:08
深度解读Python如何实现dbscan算法
2023-12-22 01:31:50
python 实现图片特效处理
2021-04-20 05:34:22
Python urllib 入门使用详细教程
2023-03-02 10:48:35
在SQL Server 2008中安装安全审计
2009-02-24 17:22:00
数据库技巧——MySQL十大优化技巧
2011-01-31 16:44:00
python数据分析之单因素分析线性拟合及地理编码
2021-02-09 06:46:20
使用python os模块复制文件到指定文件夹的方法
2022-01-06 13:23:01
Bootbox将后台JSON数据填充Form表单的实例代码
2023-08-22 22:01:21
python实现sm2和sm4国密(国家商用密码)算法的示例
2021-11-17 08:02:13