You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
120 lines
2.9 KiB
120 lines
2.9 KiB
#!/usr/bin/python -u
|
|
#
|
|
# Processing of the queries results
|
|
#
|
|
import sys
|
|
import index
|
|
import time
|
|
import traceback
|
|
import string
|
|
|
|
if index.openMySQL(verbose = 0) < 0:
|
|
print "Failed to connect to the MySQL database"
|
|
sys.exit(1)
|
|
|
|
DB = index.DB
|
|
|
|
def getTopQueriesDB(base = "Queries", number = 50):
|
|
global DB
|
|
|
|
try:
|
|
import os
|
|
os.mkdir("searches")
|
|
except:
|
|
pass
|
|
|
|
date = time.strftime("%Y%m%d")
|
|
f = open("searches/%s-%s.xml" % (base, date), "w")
|
|
c = DB.cursor()
|
|
try:
|
|
ret = c.execute("""select sum(Count) from %s""" % (base))
|
|
row = c.fetchone()
|
|
total = int(row[0])
|
|
ret = c.execute("""select count(*) from %s""" % (base))
|
|
row = c.fetchone()
|
|
uniq = int(row[0])
|
|
ret = c.execute(
|
|
"""select * from %s ORDER BY Count DESC LIMIT %d""" % (base, number))
|
|
i = 0;
|
|
f.write("<queries total='%d' uniq='%d' nr='%d' date='%s'>\n" % (
|
|
total, uniq, number, date))
|
|
while i < ret:
|
|
row = c.fetchone()
|
|
f.write(" <query count='%d'>%s</query>\n" % (int(row[2]), row[1]))
|
|
i = i + 1
|
|
f.write("</queries>\n")
|
|
except:
|
|
print "getTopQueries %s %d failed\n" % (base, number)
|
|
print sys.exc_type, sys.exc_value
|
|
return -1
|
|
f.close()
|
|
|
|
def getTopQueries(number = 50):
|
|
return getTopQueriesDB(base = "Queries", number = number)
|
|
|
|
def getAllTopQueries(number = 50):
|
|
return getTopQueriesDB(base = "AllQueries", number = number)
|
|
|
|
def increaseTotalCount(Value, count):
|
|
global DB
|
|
|
|
c = DB.cursor()
|
|
try:
|
|
ret = c.execute("""select ID,Count from AllQueries where Value='%s'""" %
|
|
(Value))
|
|
row = c.fetchone()
|
|
id = row[0]
|
|
cnt = int(row[1]) + count
|
|
ret = c.execute("""UPDATE AllQueries SET Count = %d where ID = %d""" %
|
|
(cnt, id))
|
|
except:
|
|
ret = c.execute(
|
|
"""INSERT INTO AllQueries (Value, Count) VALUES ('%s', %d)""" %
|
|
(Value, count))
|
|
|
|
|
|
def checkString(str):
|
|
if string.find(str, "'") != -1 or \
|
|
string.find(str, '"') != -1 or \
|
|
string.find(str, "\\") != -1 or \
|
|
string.find(str, " ") != -1 or \
|
|
string.find(str, "\t") != -1 or \
|
|
string.find(str, "\n") != -1 or \
|
|
string.find(str, "\r") != -1:
|
|
return 0
|
|
return 1
|
|
def addCounts(frmtable):
|
|
global DB
|
|
|
|
i = 0
|
|
c = DB.cursor()
|
|
entries=[]
|
|
try:
|
|
ret = c.execute("""select Value,Count from %s""" % (frmtable))
|
|
while i < ret:
|
|
i = i + 1
|
|
row = c.fetchone()
|
|
if checkString(row[0]):
|
|
entries.append((row[0], int(row[1])))
|
|
else:
|
|
entries.append((None, int(row[1])))
|
|
|
|
for row in entries:
|
|
if row[0] != None:
|
|
increaseTotalCount(row[0], row[1])
|
|
except:
|
|
print "addCounts %s failed" % (frmtable)
|
|
print sys.exc_type, sys.exc_value
|
|
traceback.print_exc(file=sys.stdout)
|
|
|
|
try:
|
|
c.execute("""DELETE from %s""" % (frmtable))
|
|
except:
|
|
pass
|
|
|
|
|
|
|
|
getTopQueries()
|
|
addCounts('Queries')
|
|
getAllTopQueries()
|