From 03b031ea793e91ce2f87cf28c73cefc8ce69a7b5 Mon Sep 17 00:00:00 2001 From: Lilian Teronen Date: Mon, 27 Nov 2023 01:37:03 +0200 Subject: More rework on routes. Best and worst matches. More visuals. --- routes/analyse.py | 60 ++++++++++++++++++++++++++++++++++++++++++++++++++----- 1 file changed, 55 insertions(+), 5 deletions(-) (limited to 'routes/analyse.py') 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"]) -- cgit v1.2.3