Example #1
0
def parse_list(sheet: Worksheet):
    cards = []
    for row in sheet.get_all_values():
        if row[0] and row[0] != 'ID' and row[2]:
            cards.append(Card(row))

    sorted_cards = sorted(cards, key=lambda e: e.id)
    return sorted_cards
Example #2
0
def parse_competences(wsh : gspread.Worksheet):
    ll = wsh.get_all_values()  # type: List[List[str]]
    comp = []  # type: List[Tuple[str, int, COMP_LEVEL]]
    for line in range(2, 10):
        comp.append((ll[line][COMP_NAME_COLUMN].strip().lower(), int(ll[line][COMP_SCORE_MAIN]), COMP_LEVEL.NORMAL))
    comp_level = COMP_LEVEL.NORMAL
    line = 13
    while ll[line][COMP_NAME_COLUMN] and ll[line][COMP_SCORE_XPABLE]:
        if not ll[line][COMP_SCORE_XPABLE].isnumeric():
            try:
                comp_level = STR_TO_COMP_LEVEL[ll[line][COMP_SCORE_XPABLE]]
            except KeyError:
                raise BotError(
                    f"Unexcepted value when parsing comp score, got \"{ll[line][COMP_SCORE_XPABLE]}\" at line {line} ({ll[line][COMP_NAME_COLUMN]})")
        else:
            comp.append((ll[line][COMP_NAME_COLUMN].strip().lower(), int(ll[line][COMP_SCORE_XPABLE]), comp_level))
        line += 1
    return comp
Example #3
0
def write(sheet: gspread.Worksheet, df: pd.DataFrame) -> None:
    cells = sheet.get_all_values()
    set_with_dataframe(sheet, df, include_index=False,
                       include_column_header=False, row=len(cells) + 1, resize=False)
Example #4
0
def get_player_data(gsheet: gspread.Worksheet):
    """ Converts Google sheet data to a Pandas DataFrame.
    Note: This script assumes that your data contains a header file on the first row!
    Also note that the Google API returns 'none' from empty cells - in order for the code
    below to work, you'll need to make sure your sheet doesn't contain empty cells,
    or update the code to account for such instances.
    """

    Division.objects.get_or_create(name="Mixed")
    Division.objects.get_or_create(name="Open")
    query = dbsafe_encode(Person.objects.filter(sex="f").query)
    Division.objects.get_or_create(name="Women", eligible_person_query=query)

    admin_user = User.objects.get(username="******")
    data = gsheet.get_all_values()
    h = data[2]  # Assumes first line is header!
    for row in data[3:]:
        user_data = {
            "username": row[1],
            "email": row[h.index("e-mail")],
        }

        try:
            user = User.objects.update_or_create(**user_data)[0]
        except django.db.utils.IntegrityError:
            logger.info("spieler doppelt gemeldet.")
            continue

        person_data = {
            "firstname": row[h.index("firstname")],
            "lastname": row[h.index("lastname")],
            "sex": row[h.index("sex")].lower(),
            "birthdate": f"{row[h.index('birthdate (year)')]}-01-01",
            "user": user,
        }
        try:
            person = Person.objects.update_or_create(**person_data)[0]
        except django.core.exceptions.ValidationError:
            logger.info("keine geburtsdatum angegeben wird auf 2019 gesetzt.")
            person_data["birthdate"] = "2019-01-01"
            person = Person.objects.update_or_create(**person_data)[0]
        except django.db.utils.IntegrityError:
            logger.info("person existiert.")
            continue

        club_data = {
            "name": row[h.index("club_membership_name")],
            "founded_on": "2000-01-01"
        }
        try:
            club = Club.objects.update_or_create(**club_data)[0]
        except django.db.utils.IntegrityError:
            logger.info("club existiert.")
            continue

        role = row[h.index("club_membership_role")]
        if role == "":
            role = "Member"

        person_to_club_membership_data = {
            "valid_from": f"{row[h.index('Entry OEFSV (year)')]}-01-01",
            "role": role,
            "person": person,
            "club": club,
            "approved_by": admin_user,
            "reporter": admin_user,
        }

        try:
            personToClubMembership = PersonToClubMembership.objects.update_or_create(
                **person_to_club_membership_data)[0]
        except django.core.exceptions.ValidationError:
            logger.info(
                "keine Eintritsjahr angegeben eben wird auf 2019 gesetzt.")
            person_to_club_membership_data["valid_from"] = "2019-01-01"
            personToClubMembership = PersonToClubMembership.objects.update_or_create(
                **person_to_club_membership_data)[0]
        except django.db.utils.IntegrityError:
            logger.info("mitgliedschaft besteht bereits.")
            continue

        for team in TEAMS:
            tournament = Tournament.objects.get_or_create(
                name=team["turnier"],
                start="2019-02-02 19:00",
                end="2019-02-01 19:00")[0]
            tournament_divisions = []
            for division in team["divisions"]:
                div = Division.objects.filter(name=division)[0]
                td = TournamentDivision.objects.get_or_create(
                    tournament=tournament, division=div)[0]
                tournament_divisions.append(td)

            if row[h.index(team["name"])] != "":
                team_data = {
                    "founded_on": "2000-01-01",
                    "name": row[h.index(team["name"])],
                    "club_membership": club
                }
                try:
                    teams_ = Team.objects.filter(name=team_data["name"])
                    if teams_:
                        team_ = teams_[0]
                        logger.info(f"team '{team_.name}'' existiert bereits.")
                    else:
                        team_ = Team.objects.update_or_create(**team_data)[0]
                except django.db.utils.IntegrityError:
                    logger.info(f"team '{team['name']}' existiert.")
                    continue

                try:
                    if person.sex == "f" and len(tournament_divisions) > 1:
                        tv = tournament_divisions[1]
                    else:
                        tv = tournament_divisions[0]

                    rosters_ = Roster.objects.filter(team=team_,
                                                     tournament_division=tv)
                    if rosters_:
                        roster = rosters_[0]
                        logger.info(f"roster '{roster}' existiert bereits.")
                    else:
                        roster = Roster.objects.update_or_create(
                            team=team_, tournament_division=tv)[0]
                except django.db.utils.IntegrityError:
                    logger.info(f"Roster '{roster[0]}' existiert.")
                    continue

                role = (row[h.index(team["role"])], )
                if role == "":
                    role = "Player"

                person_to_roster_membership_data = {
                    "role": role,
                    "number": row[h.index(team["number"])],
                    "person": person,
                    "roster": roster,
                    "approved_by": admin_user,
                    "reporter": admin_user,
                }

                try:
                    personToRosterRelationship = PersonToRosterRelationship.objects.update_or_create(
                        **person_to_roster_membership_data)[0]
                except ValueError:
                    logger.info("keine Nummer vergeben wird auf 0 gesetzt.")
                    person_to_roster_membership_data["number"] = 0
                    try:
                        PersonToRosterRelationship.objects.update_or_create(
                            **person_to_roster_membership_data)[0]
                    except django.db.utils.IntegrityError:
                        logger.info(
                            "Spieler {person} bereits auf roster {roster}.")
                    continue
                except django.db.utils.IntegrityError:
                    logger.info(
                        "Spieler {person} bereits auf roster {roster}.")
                    continue
Example #5
0
 def __init__(self, worksheet: gspread.Worksheet):
     self.gsheet = worksheet
     self.data_list = worksheet.get_all_values()
     self.is_empty = True if len(self.data_list) == 0 else False