diff options
author | Lilian Teronen <lteronen@local> | 2023-11-27 01:37:03 +0200 |
---|---|---|
committer | Lilian Teronen <lteronen@local> | 2023-11-27 01:37:03 +0200 |
commit | 03b031ea793e91ce2f87cf28c73cefc8ce69a7b5 (patch) | |
tree | 882919559651e1b18904404ccc7c5106d167f1fd /routes/analyse.py | |
parent | d2de3ae10b6f5314bd4b8243218212d2004f35b0 (diff) |
More rework on routes. Best and worst matches. More visuals.
Diffstat (limited to 'routes/analyse.py')
-rw-r--r-- | routes/analyse.py | 60 |
1 files changed, 55 insertions, 5 deletions
diff --git a/routes/analyse.py b/routes/analyse.py index b333e70..3076d99 100644 --- a/routes/analyse.py +++ b/routes/analyse.py @@ -1,19 +1,66 @@ +from itertools import combinations from app import app from flask import render_template,session,request,redirect import db_actions as D from routes.tools import rows2dicts, get_alert, get_nick, red +def find_best_and_worst(aid, uid): + answers=D.get_all_answers_for_quiz(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 red["nick"] + return render_template( + "analyse.html", + caller="analyse", + alert=get_alert() + ) if "answer_id" in session and D.is_user_answered(session["answer_id"],sid): aid = session["answer_id"] else: - return render_template("analyse.html", + return render_template( + "analyse.html", + caller="analyse", alert=get_alert(), nick=get_nick() ) @@ -24,14 +71,16 @@ def analyse(): uid2 = session["anal_user2"] if "anal_user2" in session else sid uid2 = sid if uid2 != sid and not D.is_user_answered(aid,uid2) else uid2 + comparable = D.get_comparable( aid, uid1, uid2 ) avg=0 for i in range(len(comparable)): avg += comparable[i][5] avg//=len(comparable) - - return render_template("analyse.html", + return render_template( + "analyse.html", + caller="analyse", alert=get_alert(), nick=get_nick(), code=D.get_quiz_link(aid), @@ -39,7 +88,8 @@ def analyse(): users = rows2dicts( D.get_users_answered(aid), ['id','nick'] ), user1=int(uid1), user2=int(uid2), - avg = avg + avg = avg, + best = find_best_and_worst(aid, sid) ) @app.route("/set/compare",methods=["POST"]) |