1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
|
from itertools import combinations
from app import app, D
from flask import render_template,session,request,redirect
from routes.tools import rows2dicts, get_alert, get_nick, csrf_check
def find_best_and_worst(aid, uid):
answers=D.quiz.answers(aid)
alist=rows2dicts( answers, ['q','u','a'] )
questions = set(x['q'] for x in alist)
users = set(x['u'] for x in alist)
data = {}
for q in questions:
data[q]={}
for i in alist:
data[i['q']][i['u']]=i['a']
match = {}
comb = list(combinations(users,2))
if len(comb)<1:
comb=[(uid,uid)]
min, minme, max, maxme = 101, 101, -1, -1
for pair in comb:
sum=0
for q in questions:
sum += 1000 - abs(data[q][pair[0]]-data[q][pair[1]])
match[pair]=int(sum / len(questions) / 10 + 0.5)
if match[pair] < min:
min = match[pair]
min_pair = pair
if match[pair] > max:
max = match[pair]
max_pair = pair
if pair[0]==uid or pair[1]==uid:
if match[pair] < minme:
minme = match[pair]
minme_pair = pair
if match[pair] > maxme:
maxme = match[pair]
maxme_pair = pair
return ( {
'min': min, 'min_u1': min_pair[0], 'min_u2': min_pair[1],
'max': max, 'max_u1': max_pair[0], 'max_u2': max_pair[1],
'minme': minme, 'minme_u1': minme_pair[0], 'minme_u2': minme_pair[1],
'maxme': maxme, 'maxme_u1': maxme_pair[0], 'maxme_u2': maxme_pair[1] })
@app.route("/pages/analyse.html")
def analyse():
if "id" in session:
sid = session["id"]
else:
return render_template(
"analyse.html",
caller="analyse",
alert=get_alert()
)
if "answer_id" in session and D.quiz.user(session["answer_id"],sid):
aid = session["answer_id"]
else:
return render_template(
"analyse.html",
caller="analyse",
alert=get_alert(),
nick=get_nick()
)
uid1 = session["anal_user1"] if "anal_user1" in session else sid
uid1 = sid if uid1 != sid and not D.quiz.user(aid,uid1) else uid1
uid2 = session["anal_user2"] if "anal_user2" in session else sid
uid2 = sid if uid2 != sid and not D.quiz.user(aid,uid2) else uid2
comparable = D.analyse.comparable( aid, uid1, uid2 )
avg=0
for i in range(len(comparable)):
avg += comparable[i][5]
avg//=len(comparable)
return render_template(
"analyse.html",
caller="analyse",
alert=get_alert(),
nick=get_nick(),
code=D.quiz.get_link(aid),
questions = rows2dicts( comparable, ['q','n','p','a1','a2','c'] ),
users = rows2dicts( D.quiz.users(aid), ['id','nick'] ),
user1=int(uid1),
user2=int(uid2),
avg = avg,
best = find_best_and_worst(aid, sid)
)
@app.route("/set/compare",methods=["POST"])
def set_compare():
if csrf_check():
return redirect("/#analyse")
session["anal_user1"] = request.form["user1"]
session["anal_user2"] = request.form["user2"]
return redirect("/#analyse")
|