Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
25 changes: 19 additions & 6 deletions backend/lesson_info.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
import logging
import re
import typing
import spacy # spacy for language analysis

from .vplan_utils import (
parse_periods, _parse_form_pattern, ParsedForm, parsed_forms_to_str, forms_to_str,
Expand All @@ -14,6 +15,8 @@
from . import teacher as teacher_model, blocks, typography_fixer
from . import models

nlp = spacy.load("de_core_news_sm") # load german language model


# Nicht verfügbare Räume: 1302 (1-2,7-10), 1306 (1-2,4,6)

Expand Down Expand Up @@ -818,9 +821,9 @@ def process_additional_info_line(text: str, parsed_existing_forms: list[ParsedFo
# TODO: Dates, Rooms

funcs = (
lambda s: add_fuzzy_teacher_links(s, teachers, date),
lambda s: add_fuzzy_form_links(s, parsed_existing_forms, date),
lambda s: add_fuzzy_room_links(s, rooms, date)
lambda s: add_fuzzy_teacher_links(s, text, teachers, date),
lambda s: add_fuzzy_form_links(s, text, parsed_existing_forms, date),
lambda s: add_fuzzy_room_links(s, text, rooms, date)
)

segments = [LessonInfoTextSegment(text)]
Expand Down Expand Up @@ -866,7 +869,7 @@ def add_fuzzy_with_validator(
return segments


def add_fuzzy_form_links(text: str, parsed_existing_forms: list[ParsedForm], date: datetime.date
def add_fuzzy_form_links(text: str, _, parsed_existing_forms: list[ParsedForm], date: datetime.date
) -> list[LessonInfoTextSegment]:
def validator(match: re.Match) -> list[LessonInfoTextSegment] | None:
parsed_forms = ParsedForm.from_form_match(match)
Expand Down Expand Up @@ -907,8 +910,18 @@ def validator(match: re.Match) -> list[LessonInfoTextSegment] | None:
return add_fuzzy_with_validator(text, [_loose_parse_form_pattern], validator)


def add_fuzzy_teacher_links(text: str, teachers: teacher_model.Teachers, date: datetime.date):
def add_fuzzy_teacher_links(text: str, context: str, teachers: teacher_model.Teachers, date: datetime.date):
def validator(match: re.Match) -> list[LessonInfoTextSegment] | None:
# check if word can be teacher (by grammar rules)
doc = nlp(context) # analyze info line
# find teacher in info
for i in doc:
if doc[i].text == text:
# check part of speach of suspected teacher
# has to be proper noun to be accepted
if doc[i].pos_ != "PROPN":
return None

surname_or_abbreviation = match.group()

replacements = {
Expand Down Expand Up @@ -938,7 +951,7 @@ def validator(match: re.Match) -> list[LessonInfoTextSegment] | None:
return add_fuzzy_with_validator(text, [re.compile(_InfoParsers._teacher), re.compile(r"\b\w+\b")], validator)


def add_fuzzy_room_links(text: str, rooms: set[str], date: datetime.date):
def add_fuzzy_room_links(text: str, _, rooms: set[str], date: datetime.date):
def validator(match: re.Match) -> list[LessonInfoTextSegment] | None:
room = match.group()
return [
Expand Down
4 changes: 2 additions & 2 deletions client/package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

3 changes: 2 additions & 1 deletion requirements.txt
Original file line number Diff line number Diff line change
Expand Up @@ -13,4 +13,5 @@ brotlicffi~=1.1.0.0
pywebpush~=1.14.0
py-vapid~=1.9.0
aiohttp~=3.9.3
icalendar~=6.0.0a0
icalendar~=6.0.0a0
spacy~=3.8.4
1 change: 0 additions & 1 deletion server.py
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,6 @@
app.register_blueprint(api)
app.register_blueprint(stats, url_prefix="/stats")


@app.after_request
def after_request(resp):
if request.path.startswith("/public"):
Expand Down