T0nyX1ang/WHU-ScoreChecker

View on GitHub
scorechecker/course/extract.py

Summary

Maintainability
A
0 mins
Test Coverage
"""
Extract information from a score table.

Available functions: convert, extract
"""

from .query import search_start_year, search_stop_year, \
    search_score_come_out, search_min_score, search_max_score, \
    search_min_credit, search_max_credit, \
    search_study_type, search_course_type, \
    search_course_academy, search_course_name


def convert(key):
    """
    Convert keys to their functions.

    Available keys are: start_year, stop_year,
    score_come_out, min_score, max_score, min_credit, max_credit
    study_type, course_type, course_academy, course_name
    """
    lookup_table = {
        'start_year': search_start_year,
        'stop_year': search_stop_year,
        'score_come_out': search_score_come_out,
        'min_score': search_min_score,
        'max_score': search_max_score,
        'min_credit': search_min_credit,
        'max_credit': search_max_credit,
        'study_type': search_study_type,
        'course_type': search_course_type,
        'course_academy': search_course_academy,
        'course_name': search_course_name,
    }
    return lookup_table[key]


def extract(score_table, query_model):
    """
    Extract required information from a score table based on the query model.

    This is the main module, the results will be sent to the result app.
    If you want to use the model separately, you must validate the model first.
    """
    if not query_model.get('display'):
        return score_table

    middle_extract = {}  # store for later use
    for item in query_model['query'].keys():
        temp_score_table = score_table
        for each_key in query_model['query'][item].keys():
            temp_score_table = convert(each_key)(
                temp_score_table, query_model['query'][item][each_key])
        middle_extract[item] = temp_score_table

    return middle_extract[query_model['display']]