您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

python脚本实现统计日志文件中的ip访问次数代码分享

5b51 2022/1/14 8:18:14 python 字数 2356 阅读 362 来源 www.jb51.cc/python

适用的日志格式: 106.45.185.214--[06/Aug/2014:07:38:59+0800]\"GET/HTTP/1.0\"20010\"-\"\"-\" 171.104.119.22--[06/Aug/2014:08:55:01+0800]\"GET/HTTP/1.0\"20010\"-\"\"-\"

概述

适用的日志格式:

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],sys.argv[2])
  log.parse()    

总结

以上是编程之家为你收集整理的python脚本实现统计日志文件中的ip访问次数代码分享全部内容,希望文章能够帮你解决python脚本实现统计日志文件中的ip访问次数代码分享所遇到的程序开发问题。


如果您也喜欢它,动动您的小指点个赞吧

除非注明,文章均由 laddyq.com 整理发布,欢迎转载。

转载请注明:
链接:http://laddyq.com
来源:laddyq.com
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


联系我
置顶