2021-08-08 23:24:16 +02:00
|
|
|
from bs4 import BeautifulSoup
|
2021-08-19 20:47:53 +02:00
|
|
|
from functions import config
|
2021-01-24 22:31:09 +01:00
|
|
|
import re
|
2021-01-23 23:40:49 +01:00
|
|
|
from requests import get
|
2021-01-24 22:00:24 +01:00
|
|
|
|
|
|
|
|
|
|
|
def getMatchweek():
|
|
|
|
"""
|
|
|
|
Parses the current JPL matchweek out of Sporza's site
|
|
|
|
"""
|
2021-01-24 22:31:09 +01:00
|
|
|
resp = get("https://sporza.be/nl/categorie/voetbal/jupiler-pro-league/")
|
|
|
|
|
|
|
|
if resp.status_code != 200:
|
|
|
|
return None
|
|
|
|
|
|
|
|
bs = BeautifulSoup(resp.text, "html.parser")
|
|
|
|
matchdays = bs.find_all("section", attrs={"class": "sc-matchdays"})
|
|
|
|
|
2021-08-08 23:06:59 +02:00
|
|
|
if len(matchdays) == 0:
|
2021-01-24 22:31:09 +01:00
|
|
|
return None
|
|
|
|
|
|
|
|
# Table header
|
2021-08-08 23:06:59 +02:00
|
|
|
header = matchdays[0]
|
2021-01-24 22:31:09 +01:00
|
|
|
|
|
|
|
# Regex to find current matchday
|
|
|
|
r = re.compile(r"speeldag\s*\d+", flags=re.I)
|
|
|
|
|
|
|
|
match = r.search(str(header))
|
|
|
|
|
|
|
|
# Something went wrong, just ignore
|
|
|
|
if match is None:
|
|
|
|
return None
|
|
|
|
|
|
|
|
# "Speeldag DD" -> split on space & take second
|
|
|
|
return match[0].split(" ")[1]
|
2021-01-25 00:16:38 +01:00
|
|
|
|
|
|
|
|
|
|
|
def getJPLMatches(week: int):
|
|
|
|
"""
|
|
|
|
JPL matches for a given matchweek
|
|
|
|
"""
|
2021-08-19 20:47:53 +02:00
|
|
|
jpl = config.get("jpl")
|
|
|
|
current_day = get(f"https://api.sporza.be/web/soccer/phases/{jpl}/matchdays/{week}")
|
2021-01-25 00:16:38 +01:00
|
|
|
|
|
|
|
# Something went wrong
|
|
|
|
if current_day.status_code != 200:
|
|
|
|
return None
|
|
|
|
|
|
|
|
return current_day.json()["groupedMatches"][0]["matches"]
|
2021-01-26 21:58:49 +01:00
|
|
|
|
|
|
|
|
|
|
|
def getJPLTable():
|
|
|
|
"""
|
|
|
|
JPL table
|
|
|
|
"""
|
|
|
|
page_html = get("https://sporza.be/nl/categorie/voetbal/jupiler-pro-league/")
|
|
|
|
|
2021-01-26 22:00:20 +01:00
|
|
|
# Something went wrong
|
2021-01-26 21:58:49 +01:00
|
|
|
if page_html.status_code != 200:
|
|
|
|
return None
|
|
|
|
|
|
|
|
bs_parsed = BeautifulSoup(page_html.text, "html.parser")
|
|
|
|
rows = bs_parsed.find(summary="algemeen klassement").find_all("tr")[1:]
|
|
|
|
return rows
|