我是靠谱客的博主 失眠河马,最近开发中收集的这篇文章主要介绍python网站访问日志分析_python实现apahce网站日志分析示例,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

维护脚本一例,写得有点乱,只是作为一个实例,演示如何快速利用工具快速达到目的:

应用到:shell与python数据交互、数据抓取,编码转换

代码如下:

#coding:utf-8

#!/usr/bin/python

'''

程序说明:apache access.log日志分析

分析访问网站IP 来源情况

日期:2014-01-06 17:01

author:gyh9711

程序说明:应用到:shell与python数据交互、数据抓取,编码转换

'''

import os

import json

import httplib

import codecs

LogFile='/var/log/apache2/access.log'

#日志

logMess='/tmp/acc.log'

if os.path.isfile(logMess):

os.system('cp /dev/null %s'% logMess)

file=codecs.open(logMess,'w+',encoding='utf-8')

def cmd(cmd):

return os.popen(cmd).readlines()

'''

def getIp(ip):

return json.loads(os.popen("/usr/bin/curl http://ip.taobao.com/service/getIpInfo.php?ip=%s" % ip).readline())['data']

'''

conn = httplib.HTTPConnection('ip.taobao.com')

def getIpCountry(ip):

conn.request('GET','/service/getIpInfo.php?ip=%s' % ip)

r1=conn.getresponse()

if r1.status == 200:

return json.loads(r1.read())['data']

else:

return "Error"

#将access.log文件进行分析,并转为python数组

file.write(u"字段说明:ip 访问次数据 ip国家 城市的 isp号 省份 所在地区n")

ipDb=[]

for i in cmd('''/usr/bin/awk '{print $1}' %s |sort |uniq -c''' % LogFile):

ip = i.strip().split(' ')

ipDb.append(ip)

#通过taobao 提供接口分析ip地址来源

for i in ipDb:

_tmpD=getIpCountry(i[1])

#格式说明:ip 访问次数据 ip国家 城市的 isp号 省份 所在地区

out="%s%s%s%s%s%s%s"%(i[1].ljust(20),i[0].ljust(10),_tmpD['country'].ljust(20),_tmpD['city'].ljust(16),_tmpD['isp_id'].ljust(16),_tmpD['region'].ljust(16),_tmpD['area'].ljust(16))

print out

file.write("%sn"%out)

conn.close()

file.close()

'''

'''

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

最后

以上就是失眠河马为你收集整理的python网站访问日志分析_python实现apahce网站日志分析示例的全部内容,希望文章能够帮你解决python网站访问日志分析_python实现apahce网站日志分析示例所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(56)

评论列表共有 0 条评论

立即
投稿
返回
顶部