国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

python實現apahce網站日志分析示例

2019-11-25 18:27:57
字體:
來源:轉載
供稿:網友

維護腳本一例,寫得有點亂,只是作為一個實例,演示如何快速利用工具快速達到目的:
應用到: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("%s/n"%out)

conn.close()
file.close()

'''

'''

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 孟连| 井研县| 台州市| 海门市| 梓潼县| 通城县| 色达县| 南郑县| 西乡县| 阿克陶县| 岐山县| 泾川县| 中阳县| 芜湖市| 金溪县| 莱芜市| 万安县| 伊金霍洛旗| 罗山县| 贵德县| 双流县| 乌拉特前旗| 攀枝花市| 定结县| 进贤县| 蓬溪县| 淮北市| 儋州市| 柞水县| 琼结县| 长宁县| 溆浦县| 抚州市| 盖州市| 三亚市| 宝坻区| 昌图县| 丹东市| 唐山市| 天峻县| 马边|