Compare commits
18 Commits
ScraperTes
...
7b457475b4
| Author | SHA1 | Date | |
|---|---|---|---|
| 7b457475b4 | |||
| 8fb2a22c2a | |||
| d1f5f8f3f4 | |||
| 56e68ed751 | |||
| f96a3ed1f1 | |||
| 416b2ccfe0 | |||
| 00bbe05b1c | |||
| e373c6b274 | |||
| e80ee6bf8f | |||
| a25be482b0 | |||
| 4e8cb48c82 | |||
| bc82fcd6b8 | |||
| 5d238cb6b8 | |||
| fe4c9aab3d | |||
| 9e8a60dfa1 | |||
| 7fe4e03945 | |||
| ffcfa12d4c | |||
|
|
f7e80811a0 |
@@ -1,23 +1,13 @@
|
||||
from flask import session
|
||||
from lewy_db import baza as ldb
|
||||
from lewy_globals import colors as c
|
||||
from lewy_globals import safeTraverse as safe_traverse
|
||||
import json
|
||||
import lewy_globals
|
||||
import requests
|
||||
import time
|
||||
from sqlalchemy import func
|
||||
|
||||
def safe_traverse(obj: dict, path: list, default=None):
|
||||
result = obj
|
||||
try:
|
||||
for x in path:
|
||||
result = result[x]
|
||||
except KeyError:
|
||||
result = default
|
||||
print(f"safe_traverse: error reading {' -> '.join(path)} - returning: {default}")
|
||||
finally:
|
||||
return result
|
||||
|
||||
class scraper:
|
||||
|
||||
headers = {
|
||||
@@ -59,21 +49,14 @@ class scraper:
|
||||
|
||||
|
||||
def czy_mecz_istnieje(self, zewnetrzne_id_meczu: str):
|
||||
# mecz = db.simple_select_all(ldb.mecze, zewnetrzne_id_meczu=zewnetrzne_id_meczu)
|
||||
# if mecz is not None and mecz != []:
|
||||
# return True
|
||||
# else:
|
||||
# return False
|
||||
return self.__czy_x_istnieje("mecze", zewnetrzne_id_meczu=zewnetrzne_id_meczu)
|
||||
|
||||
def czy_klub_istnieje(self, id_klubu: str):
|
||||
# mecz = db.simple_select_all(ldb.mecze, zewnetrzne_id_meczu=zewnetrzne_id_meczu)
|
||||
# if mecz is not None and mecz != []:
|
||||
# return True
|
||||
# else:
|
||||
# return False
|
||||
return self.__czy_x_istnieje("kluby", id_klubu=id_klubu)
|
||||
|
||||
def czy_nie_trzeba_pobierac_nowych_meczy_zawodnika(self, id_zawodnika: int, zewnetrzne_id_meczu: str):
|
||||
return self.__czy_x_istnieje("sportowcy_w_meczach", id_zawodnika=id_zawodnika, zewnetrzne_id_meczu=zewnetrzne_id_meczu)
|
||||
|
||||
def id_na_imie_nazwisko_urodziny(self, zewnetrzne_id_sportowca: str = "MVC8zHZD"):
|
||||
"""
|
||||
Scraper z dykty xD
|
||||
@@ -109,6 +92,7 @@ class scraper:
|
||||
# TODO: Sprawdź, czy sportowiec istnieje w bazie.
|
||||
# Jeśli nie, dodaj go w podobny sposób, jak
|
||||
# w sample_data_init() (w lewy_db.py).
|
||||
# -- Jednak tego tak nie robimy, ponieważ nie uzyskamy wielu informacji.
|
||||
|
||||
id_zawodnika = self.db.get_id_zawodnika_by_zewnetrzne_id(zewnetrzne_id_sportowca)
|
||||
zawodnik = self.db.simple_select_all("sportowcy", zewnetrzne_id_zawodnika=zewnetrzne_id_sportowca)[0]
|
||||
@@ -131,11 +115,29 @@ class scraper:
|
||||
home_club_id = safe_traverse(match, ["homeParticipantUrl"], default="non-existent-club-id")
|
||||
away_club_id = safe_traverse(match, ["awayParticipantUrl"], default="non-existent-club-id")
|
||||
|
||||
# Sprawdź, czy mecz nie znajduje się już w bazie
|
||||
if self.czy_mecz_istnieje(zewnetrzne_id_meczu=match_id):
|
||||
# ~Sprawdź, czy mecz nie znajduje się już w bazie~
|
||||
#
|
||||
# UWAGA! Nie powinniśmy tego sprawdzać jak w komentarzu poniżej!
|
||||
# To sprawdzenie powinno jedynie służyć zapobieganiu dodania istniejących meczy,
|
||||
# natomiast istniejący mecz nie oznacza, że sportowiec ma już statystykę z niego!
|
||||
# Przerwać scrapowanie należy wtedy, gdy znajdzie się statystykę sportowca
|
||||
# z bieżącego meczu, a nie kiedy znajdzie się bieżący mecz w bazie!
|
||||
#
|
||||
# if self.czy_mecz_istnieje(zewnetrzne_id_meczu=match_id):
|
||||
# stop_scraping = True
|
||||
# break
|
||||
#
|
||||
# Rozwiązanie jest mocno nieefektywne przy scrapowaniu całej bazy od zera,
|
||||
# ale rozwiąże przypadki, w których zawodnicy, których śledzimy, grali przeciwko sobie.
|
||||
if self.czy_nie_trzeba_pobierac_nowych_meczy_zawodnika(id_zawodnika=id_zawodnika, zewnetrzne_id_meczu=match_id):
|
||||
stop_scraping = True
|
||||
break
|
||||
|
||||
if self.czy_mecz_istnieje(zewnetrzne_id_meczu=match_id):
|
||||
# Nie scrapuj istniejących meczy.
|
||||
# Naturalnie, istniejący mecz nie musi oznaczać potrzeby zakończenia scrapowania.
|
||||
continue
|
||||
|
||||
# Sprawdź, czy klub znajduje się już w bazie. Jeśli nie,
|
||||
# trzeba go dodać przed meczem.
|
||||
if not self.czy_klub_istnieje(id_klubu=home_club_id):
|
||||
@@ -151,10 +153,6 @@ class scraper:
|
||||
pelna_nazwa=safe_traverse(match, ["awayParticipantName"]),
|
||||
skrocona_nazwa=safe_traverse(match, ["awayParticipant3CharName"]))
|
||||
|
||||
# TODO: (opcjonalnie) zamień *słownik match* na *obiekt mecz*
|
||||
|
||||
|
||||
|
||||
# TODO: dodaj obiekt mecz do bazy (simple_insert_one(), simple_insert_many())
|
||||
print(f"{c.OKCYAN}Nowy mecz ({match_num}){c.ENDC}: {match}")
|
||||
|
||||
@@ -180,31 +178,33 @@ class scraper:
|
||||
zewnetrzne_id_meczu = safe_traverse(match, ["eventEncodedId"], default="")
|
||||
|
||||
if stats != False: # gdy sportowiec był aktywny w meczu
|
||||
print("todo :)")
|
||||
# # TODO:
|
||||
# self.db.simple_insert_one("sportowcy_w_meczach",
|
||||
# id_zawodnika = id_zawodnika,
|
||||
# zawodnik = zawodnik,
|
||||
# zewnetrzne_id_meczu = zewnetrzne_id_meczu,
|
||||
# # ODTĄD SIĘ NIE POKRYWA!!! POLA POWINNY SIĘ ZGADZAĆ Z TYM, CO JEST W LEWY_DB (konkretnie klasie sportowcy_w_meczach)
|
||||
# ostatni_mecz = self.db.get_id_meczu_by_zewnetrzne_id(zewnetrzne_id_meczu),
|
||||
# ilosc_wystapien = 1 if int(safe_traverse(stats, ["595", "value"], default="0").rstrip("'")) > 0 else 0,
|
||||
# minut_gry = int(safe_traverse(stats, ["595", "value"], default="0").rstrip("'")),
|
||||
# gier_sum = 1 if int(safe_traverse(stats, ["595", "value"], default="0").rstrip("'")) > 0 else 0,
|
||||
# goli_sum = int(safe_traverse(stats, ["596", "value"], default="0")),
|
||||
# asyst_sum = int(safe_traverse(stats, ["541", "value"], default="0")),
|
||||
# interwencji_sum = 0,
|
||||
# nieobronionych_interwencji_sum = 0,
|
||||
# zoltych_kartek_sum = int(safe_traverse(stats, ["599", "value"], default="0")),
|
||||
# czerwonych_kartek_sum = int(safe_traverse(stats, ["600", "value"], default="0")),
|
||||
# wygranych_sum = 1 if safe_traverse(match, ["winLoseShort"], default="") == "Z" else 0,
|
||||
# wynik_sum = safe_traverse(match, ["rating"], default=0),
|
||||
# meczow_do_wynikow_sum = 1 if safe_traverse(match, ["rating"], default=0) not in (0, None) else None
|
||||
# )
|
||||
# print("todo :)")
|
||||
self.db.simple_insert_one("sportowcy_w_meczach",
|
||||
id_zawodnika = id_zawodnika,
|
||||
zawodnik = zawodnik,
|
||||
zewnetrzne_id_meczu = zewnetrzne_id_meczu,
|
||||
# Uwaga! Czasami przygłupy z flashscore zwracają puste pole '' zamiast zera, np. do liczby strzelonych goli.
|
||||
# Dlatego int("0" + "") = int("0"), co zapobiegnie wysypaniu się przy int("").
|
||||
czas_gry = int("0" + safe_traverse(stats, ["595", "value"], default="0").rstrip("'?")),
|
||||
goli = int("0" + safe_traverse(stats, ["596", "value"], default="0")),
|
||||
asyst = int("0" + safe_traverse(stats, ["541", "value"], default="0")),
|
||||
interwencje_bramkarza = 0,
|
||||
suma_interwencji_na_bramke = 0,
|
||||
zolte_kartki = int("0" + safe_traverse(stats, ["599", "value"], default="0")),
|
||||
czerwone_kartki = int("0" + safe_traverse(stats, ["600", "value"], default="0")),
|
||||
wygrana = {"Z": 1, "R": 0, "P": -1}.get(safe_traverse(match, ["winLoseShort"], default=""), 0),
|
||||
wynik = safe_traverse(match, ["rating"], default=0) or 0
|
||||
)
|
||||
|
||||
# # analogicznie zinkrementuj statystyki_sportowcow:
|
||||
# # UWAGA! NIE ZADZIAŁA DLA NIKOGO INNEGO, NIŻ ROBERCIKA (bo nie mamy innych sportowców w bazie, trzeba dodać ich ręcznie w lewy_db sample_data_init())
|
||||
# self.db.simple_insert_one("statystyki_sportowcow",
|
||||
# # aby to zrobić, najpierw pobierz najnowszą statystykę sportowca
|
||||
# # ...
|
||||
#
|
||||
#
|
||||
# # a następnie użyj funkcji w lewy_db do inkrementowania danych
|
||||
# # (póki co jeszcze takiej nie ma)
|
||||
# self.db.simple_increment_data("statystyki_sportowcow",
|
||||
# id = ... # pewnie id się przyda
|
||||
# sportowiec = zawodnik,
|
||||
# ostatni_mecz = self.db.get_id_meczu_by_zewnetrzne_id(zewnetrzne_id_meczu),
|
||||
# ilosc_wystapien = 1 if int(safe_traverse(stats, ["595", "value"], default="0").rstrip("'")) > 0 else 0,
|
||||
@@ -216,29 +216,28 @@ class scraper:
|
||||
# nieobronionych_interwencji_sum = 0,
|
||||
# zoltych_kartek_sum = int(safe_traverse(stats, ["599", "value"], default="0")),
|
||||
# czerwonych_kartek_sum = int(safe_traverse(stats, ["600", "value"], default="0")),
|
||||
# wygranych_sum = 1 if safe_traverse(match, ["winLoseShort"], default="") == "Z" else 0,
|
||||
# wygranych_sum = 1 if safe_traverse(match, ["winloseshort"], default="") == "z" else 0,
|
||||
# wynik_sum = safe_traverse(match, ["rating"], default=0),
|
||||
# meczow_do_wynikow_sum = 1 if safe_traverse(match, ["rating"], default=0) not in (0, None) else None
|
||||
# meczow_do_wynikow_sum = 1 if safe_traverse(match, ["rating"], default=0) not in (0, none) else none
|
||||
# )
|
||||
|
||||
else:
|
||||
print("też todo :)")
|
||||
# print("też todo :)")
|
||||
# # TODO: TU TEŻ TRZEBA POPRAWIĆ ANALOGICZNIE DO TEGO, CO JEST WEWNĄTRZ IF'A
|
||||
# self.db.simple_insert_one("sportowcy_w_meczach", id_zawodnika,
|
||||
# ostatni_mecz = self.db.get_id_meczu_by_zewnetrzne_id(zewnetrzne_id_meczu),
|
||||
# ilosc_wystapien = 0,
|
||||
# minut_gry = 0,
|
||||
# gier_sum = 0,
|
||||
# goli_sum = 0,
|
||||
# asyst_sum = 0,
|
||||
# interwencji_sum = 0,
|
||||
# nieobronionych_interwencji_sum = 0,
|
||||
# zoltych_kartek_sum = 0,
|
||||
# czerwonych_kartek_sum = 0,
|
||||
# wygranych_sum = 1 if safe_traverse(match, ["winLoseShort"], default="") == "Z" else 0,
|
||||
# wynik_sum = safe_traverse(match, ["rating"], default=0),
|
||||
# meczow_do_wynikow_sum = 1 if safe_traverse(match, ["rating"], default=0) not in (0, None) else None
|
||||
# )
|
||||
self.db.simple_insert_one("sportowcy_w_meczach",
|
||||
id_zawodnika = id_zawodnika,
|
||||
zawodnik = zawodnik,
|
||||
zewnetrzne_id_meczu = zewnetrzne_id_meczu,
|
||||
czas_gry = 0, #(lambda v: int(str(v).rstrip("'")) if isinstance(v, (str, int, float)) and str(v).rstrip("'").lstrip("-").isdigit() else 0)(safe_traverse(stats if isinstance(stats, dict) else {}, ["595", "value"], default="0")),
|
||||
goli = int("0" + safe_traverse(stats, ["596", "value"], default="0")),
|
||||
asyst = int("0" + safe_traverse(stats, ["541", "value"], default="0")),
|
||||
interwencje_bramkarza = 0,
|
||||
suma_interwencji_na_bramke = 0,
|
||||
zolte_kartki = int("0" + safe_traverse(stats, ["599", "value"], default="0")),
|
||||
czerwone_kartki = int("0" + safe_traverse(stats, ["600", "value"], default="0")),
|
||||
wygrana = {"Z": 1, "R": 0, "P": -1}.get(safe_traverse(match, ["winLoseShort"], default=""), 0),
|
||||
wynik = safe_traverse(match, ["rating"], default=0) or 0
|
||||
)
|
||||
|
||||
# TODO: Zaktualizuj statystyki sportowca
|
||||
|
||||
@@ -251,7 +250,7 @@ class scraper:
|
||||
# rate limita. - sherl
|
||||
|
||||
page += 1
|
||||
time.sleep(5)
|
||||
#time.sleep(5)
|
||||
|
||||
|
||||
def aktualizuj_dane(self):
|
||||
@@ -259,8 +258,12 @@ class scraper:
|
||||
Pobiera mecze dla każdego sportowca wymienionego
|
||||
w pliku konfiguracyjnym.
|
||||
"""
|
||||
start_time = time.time()
|
||||
|
||||
for id_sportowca in lewy_globals.config['sportsmen']['tracked_ids']:
|
||||
self.aktualizuj_dane_sportowca(zewnetrzne_id_sportowca=id_sportowca)
|
||||
time.sleep(15)
|
||||
time.sleep(5)
|
||||
|
||||
end_time = time.time()
|
||||
|
||||
print(f"Scrapowanie trwało {end_time - start_time}s.")
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
from argparse import ArgumentParser
|
||||
from flask import Flask, Response, render_template
|
||||
from flask_apscheduler import APScheduler
|
||||
from fs_scraper import scraper as scr
|
||||
from fs_scraper import scraper
|
||||
from lewy_globals import colors as c
|
||||
import lewy_api
|
||||
import lewy_db
|
||||
@@ -13,7 +13,7 @@ import time
|
||||
app = Flask(__name__)
|
||||
app_host = "None"
|
||||
app_port = "None"
|
||||
scrape = None
|
||||
scr = None
|
||||
|
||||
def setup():
|
||||
# sanity check: make sure config is set
|
||||
@@ -79,7 +79,7 @@ def setup():
|
||||
app.add_url_rule('/api/<path:received_request>', view_func=lewy_api.api_global_catchall)
|
||||
|
||||
db = lewy_globals.setupDb(app, config)
|
||||
scraper = scr()
|
||||
scr = scraper()
|
||||
|
||||
with app.app_context():
|
||||
db.create_all()
|
||||
@@ -97,8 +97,7 @@ def every5seconds():
|
||||
|
||||
def every2hours():
|
||||
# zaktualizuj bazę danych scrapując FS
|
||||
# ...
|
||||
# scraper.aktualizuj_dane()
|
||||
scr.aktualizuj_dane()
|
||||
return
|
||||
|
||||
@app.route('/<string:val>', methods=['GET'])
|
||||
|
||||
@@ -50,6 +50,16 @@ def not_implemented(data):
|
||||
# TODO: change list to string -> data, not data[0]
|
||||
return 501, f"not recognised/implemented: {data[0]}", []
|
||||
|
||||
def __czy_x_istnieje(typ, **id):
|
||||
rekord = getDb().simple_select_all(typ, **id)
|
||||
if rekord is not None and rekord != []:
|
||||
return True
|
||||
else:
|
||||
return False
|
||||
|
||||
def czy_sportowiec_istnieje(id_zawodnika: str):
|
||||
return __czy_x_istnieje("sportowcy", id_zawodnika=id_zawodnika)
|
||||
|
||||
# GET /api/v1
|
||||
def stub_hello():
|
||||
"""
|
||||
@@ -85,15 +95,42 @@ def stats():
|
||||
return 200, "ok", data_to_send
|
||||
|
||||
# GET /api/v1/matches
|
||||
def get_matches(r):
|
||||
def get_matches(r = None, id_zawodnika: str | None = None, rok: int | None = None):
|
||||
"""
|
||||
TODO: Zwraca mecze.
|
||||
Zwraca mecze.
|
||||
Przykład wywołania:
|
||||
get_matches(r, id_zawodnika=1), tożsame z GET /api/v1/matches?id_zawodnika=1
|
||||
get_matches(r, rok=2024), tożsame z GET /api/v1/matches?rok=2024
|
||||
get_matches(r), tożsame z GET /api/v1/matches
|
||||
"""
|
||||
response_json = []
|
||||
mecze = getDb().simple_select_all("mecze")
|
||||
mecze = None
|
||||
|
||||
if id_zawodnika is None:
|
||||
# Gdy nie podano id wprost, sprawdź, czy podano je przez parametr.
|
||||
id_zawodnika = r.args.get('id_zawodnika', -1)
|
||||
|
||||
if rok is None:
|
||||
# Gdy nie podano roku wprost, sprawdź, czy podano je przez parametr.
|
||||
# Jeśli nie, przyjmij None (2025).
|
||||
rok = r.args.get('rok', None)
|
||||
|
||||
# Sprawdź, czy podano jakiekolwiek ID sportowca. Jeżeli nie, wypisz wszystkie mecze.
|
||||
if id_zawodnika == -1:
|
||||
mecze = getDb().get_sportsman_matches(year=rok)
|
||||
|
||||
# Sprawdź, czy sportowiec o podanym (lub niepodanym) id istnieje.
|
||||
# Jeśli nie istnieje, wypisz wszystkie mecze.
|
||||
elif not czy_sportowiec_istnieje(id_zawodnika=id_zawodnika):
|
||||
return 404, "error", {"error_msg": "This sportsman has not been found in the database. Try: id_zawodnika=1"}
|
||||
|
||||
# Gdy sportowiec istnieje, wypisz jego mecze.
|
||||
else:
|
||||
mecze = getDb().get_sportsman_matches(id_zawodnika=id_zawodnika, year=rok)
|
||||
|
||||
for mecz in mecze:
|
||||
response_json.append(mecz.jsonify())
|
||||
print(response_json)
|
||||
# print(f"zwracam mecze: {response_json}")
|
||||
return 200, "ok", response_json
|
||||
|
||||
# GET /api/v1/debugger_halt?token=XXX...
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
from datetime import datetime
|
||||
from flask_sqlalchemy import SQLAlchemy
|
||||
from functools import wraps
|
||||
from sqlalchemy import ForeignKey, select, insert, update
|
||||
from sqlalchemy import ForeignKey, select, insert, update, extract
|
||||
from sqlalchemy.orm import Mapped, mapped_column, DeclarativeBase, Session, relationship
|
||||
from typing import List
|
||||
import time
|
||||
@@ -70,6 +70,7 @@ class baza():
|
||||
statystyki_id: Mapped[ List[int]] = mapped_column(ForeignKey(f"{tnp}statystyki_sportowcow.id_statystyki"), nullable=True)
|
||||
statystyki: Mapped[List["statystyki_sportowcow"]] = relationship(back_populates="sportowiec")
|
||||
trofea: Mapped[ List["trofea"]] = relationship(back_populates="zawodnik", foreign_keys="[trofea.id_zawodnika]")
|
||||
mecze_zawodnika: Mapped[ List["sportowcy_w_meczach"]] = relationship(back_populates="zawodnik")
|
||||
|
||||
def __repr__(self):
|
||||
return f"<Sportowiec #{self.id_zawodnika} ({self.imie} {self.nazwisko})>"
|
||||
@@ -92,8 +93,9 @@ class baza():
|
||||
__tablename__ = tnp + "sportowcy_w_meczach"
|
||||
id_rekordu: Mapped[ int] = mapped_column(primary_key=True, autoincrement=True)
|
||||
id_zawodnika: Mapped[ int] = mapped_column(ForeignKey(f"{tnp}sportowcy.id_zawodnika"))
|
||||
zawodnik: Mapped[ "sportowcy"] = relationship()
|
||||
zawodnik: Mapped[ "sportowcy"] = relationship(back_populates="mecze_zawodnika")
|
||||
zewnetrzne_id_meczu: Mapped[ str] = mapped_column(ForeignKey(f"{tnp}mecze.zewnetrzne_id_meczu"))
|
||||
mecz: Mapped[ "mecze"] = relationship() # back_populates="zawodnicy_w_meczu", foreign_keys=[zewnetrzne_id_meczu])
|
||||
czas_gry: Mapped[ int] = mapped_column()
|
||||
goli: Mapped[ int] = mapped_column()
|
||||
asyst: Mapped[ int] = mapped_column()
|
||||
@@ -105,7 +107,7 @@ class baza():
|
||||
wynik: Mapped[ float] = mapped_column()
|
||||
|
||||
def __repr__(self):
|
||||
return f"<Sportowiec #{self.id_zawodnika} ({self.imie} {self.nazwisko})>"
|
||||
return f"<{self.zawodnik.imie} {self.zawodnik.nazwisko} w meczu {self.mecz.gospodarze.skrocona_nazwa} vs. {self.mecz.goscie.skrocona_nazwa}>"
|
||||
|
||||
class statystyki_sportowcow(Base):
|
||||
__tablename__ = tnp + "statystyki_sportowcow"
|
||||
@@ -157,6 +159,8 @@ class baza():
|
||||
skrocona_nazwa_turnieju: Mapped[ str] = mapped_column()
|
||||
flaga: Mapped[ int] = mapped_column()
|
||||
|
||||
# zawodnicy_w_meczu: Mapped[ List["sportowcy_w_meczach"]] = relationship(back_populates="mecz")
|
||||
|
||||
def __repr__(self):
|
||||
return f"<Mecz #{self.id_meczu} ({self.zewnetrzne_id_meczu}, {self.gospodarze.skrocona_nazwa} vs. {self.goscie.skrocona_nazwa})>"
|
||||
|
||||
@@ -167,8 +171,10 @@ class baza():
|
||||
"data": self.data.strftime("%Y-%m-%d"),
|
||||
"gospodarze_id": self.gospodarze_id,
|
||||
"gospodarze": self.gospodarze.skrocona_nazwa,
|
||||
"gospodarze_pelna_nazwa": self.gospodarze.pelna_nazwa,
|
||||
"goscie_id": self.goscie_id,
|
||||
"goscie": self.goscie.skrocona_nazwa,
|
||||
"goscie_pelna_nazwa": self.goscie.pelna_nazwa,
|
||||
"gosp_wynik": self.gosp_wynik,
|
||||
"gosc_wynik": self.gosc_wynik,
|
||||
"sezon": self.sezon,
|
||||
@@ -486,6 +492,67 @@ class baza():
|
||||
self.session.commit()
|
||||
return 0
|
||||
|
||||
@exit_gracefully
|
||||
def get_sportowcy_w_meczach_by_sportsman_id(self, id_zawodnika = None, zewnetrzne_id_zawodnika = None, order = "DESC"):
|
||||
|
||||
if zewnetrzne_id_zawodnika is not None:
|
||||
id_zawodnika = self.get_id_zawodnika_by_zewnetrzne_id(zewnetrzne_id_zawodnika)
|
||||
|
||||
# Aliasy (dla czytelności)
|
||||
SportowcyWMeczach = self.entities["sportowcy_w_meczach"]
|
||||
Sportowcy = self.entities["sportowcy"]
|
||||
query = self.session.query(
|
||||
SportowcyWMeczach
|
||||
).join(
|
||||
SportowcyWMeczach.zawodnik
|
||||
).filter(
|
||||
Sportowcy.id_zawodnika == id_zawodnika
|
||||
)
|
||||
|
||||
# print(f"get_sportowcy_w_meczach_by_sportsman_id: {query}")
|
||||
|
||||
if order.lower() == "desc":
|
||||
query = query.order_by(SportowcyWMeczach.id_rekordu.desc())
|
||||
|
||||
return query.all()
|
||||
|
||||
@exit_gracefully
|
||||
def get_sportsman_matches(self, id_zawodnika = None, zewnetrzne_id_zawodnika = None, order = "DESC", year = None):
|
||||
|
||||
# Spróbuj otrzymać id zawodnika z zewnętrznego id.
|
||||
if zewnetrzne_id_zawodnika is not None:
|
||||
id_zawodnika = self.get_id_zawodnika_by_zewnetrzne_id(zewnetrzne_id_zawodnika)
|
||||
|
||||
# Aliasy
|
||||
Mecze = self.entities["mecze"]
|
||||
SportowcyWMeczach = self.entities["sportowcy_w_meczach"]
|
||||
Sportowcy = self.entities["sportowcy"]
|
||||
|
||||
query = self.session.query(
|
||||
Mecze
|
||||
).join(
|
||||
SportowcyWMeczach, Mecze.zewnetrzne_id_meczu == SportowcyWMeczach.zewnetrzne_id_meczu
|
||||
)
|
||||
|
||||
if id_zawodnika is not None:
|
||||
query = query.join(
|
||||
Sportowcy, SportowcyWMeczach.id_zawodnika == Sportowcy.id_zawodnika
|
||||
).filter(
|
||||
Sportowcy.id_zawodnika == id_zawodnika
|
||||
)
|
||||
|
||||
if year is not None:
|
||||
query = query.filter(
|
||||
extract("year", Mecze.data) == year
|
||||
)
|
||||
|
||||
if order.lower() == "desc":
|
||||
query = query.order_by(Mecze.data.desc())
|
||||
|
||||
# print(f"get_sportsman_matches: {query}")
|
||||
|
||||
return query.all()
|
||||
|
||||
@exit_gracefully
|
||||
def sample_data_init(self, override_safety_check=False):
|
||||
"""
|
||||
@@ -523,36 +590,46 @@ class baza():
|
||||
nazwa_turnieju="Nieznany turniej",
|
||||
skrocona_nazwa_turnieju="N/A",
|
||||
flaga=0)
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=0,
|
||||
minut_gry=0,
|
||||
gier_sum=0,
|
||||
goli_sum=0,
|
||||
asyst_sum=0,
|
||||
interwencji_sum=0,
|
||||
nieobronionych_interwencji_sum=0,
|
||||
zoltych_kartek_sum=0,
|
||||
czerwonych_kartek_sum=0,
|
||||
wygranych_sum=0,
|
||||
przegranych_sum=0,
|
||||
remisow_sum=0,
|
||||
wynik_sum=0,
|
||||
meczow_do_wynikow_sum=0)
|
||||
|
||||
|
||||
# Robercik
|
||||
self.simple_insert_one(kluby,
|
||||
id_klubu="barcelona",
|
||||
pelna_nazwa="Barcelona",
|
||||
skrocona_nazwa="BAR"
|
||||
)
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=487,
|
||||
minut_gry=0, # Brak danych
|
||||
gier_sum=487,
|
||||
goli_sum=381,
|
||||
asyst_sum=44,
|
||||
interwencji_sum=0,
|
||||
nieobronionych_interwencji_sum=0,
|
||||
zoltych_kartek_sum=2,
|
||||
czerwonych_kartek_sum=0,
|
||||
wygranych_sum=0, # Brak danych
|
||||
przegranych_sum=0, # Brak danych
|
||||
remisow_sum=0, # Brak danych
|
||||
wynik_sum=0, # Brak danych
|
||||
meczow_do_wynikow_sum=0 # Brak danych
|
||||
)
|
||||
sportowiec = sportowcy(
|
||||
zewnetrzne_id_zawodnika="MVC8zHZD",
|
||||
imie="Robert",
|
||||
nazwisko="Lewandowski",
|
||||
data_urodzenia="21.08.1988",
|
||||
czy_aktywny=True,
|
||||
klub_id="undefined",
|
||||
narodowosc="PL",
|
||||
ilosc_trofeow=0,
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=1,
|
||||
wycena=64_940_000)
|
||||
zewnetrzne_id_zawodnika="MVC8zHZD",
|
||||
imie="Robert",
|
||||
nazwisko="Lewandowski",
|
||||
data_urodzenia="21.08.1988",
|
||||
czy_aktywny=True,
|
||||
klub_id="barcelona",
|
||||
narodowosc="PL",
|
||||
ilosc_trofeow=0, # Brak danych na Flashscore
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=1,
|
||||
wycena=67_000_000 # Wartość rynkowa: €15.3 mln
|
||||
)
|
||||
|
||||
trofeum = trofea(
|
||||
nazwa="Nieznane trofeum",
|
||||
sezon="0000-0000",
|
||||
@@ -600,6 +677,514 @@ class baza():
|
||||
# statystyki_id=2, # itd...
|
||||
# wycena=...) # w złotówkach
|
||||
|
||||
# Ronaldo
|
||||
self.simple_insert_one(kluby,
|
||||
id_klubu="al-nassr",
|
||||
pelna_nazwa="Al Nassr Riyadh",
|
||||
skrocona_nazwa="ANR" #?
|
||||
)
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=702,
|
||||
minut_gry=0, # Brak danych
|
||||
gier_sum=702,
|
||||
goli_sum=569,
|
||||
asyst_sum=81,
|
||||
interwencji_sum=0,
|
||||
nieobronionych_interwencji_sum=0,
|
||||
zoltych_kartek_sum=92,
|
||||
czerwonych_kartek_sum=8,
|
||||
wygranych_sum=0, # Brak danych
|
||||
przegranych_sum=0, # Brak danych
|
||||
remisow_sum=0, # Brak danych
|
||||
wynik_sum=0, # Brak danych
|
||||
meczow_do_wynikow_sum=0 # Brak danych
|
||||
)
|
||||
self.simple_insert_one(sportowcy,
|
||||
zewnetrzne_id_zawodnika="WGOY4FSt",
|
||||
imie="Cristiano",
|
||||
nazwisko="Ronaldo",
|
||||
data_urodzenia="05.02.1985",
|
||||
czy_aktywny=True,
|
||||
klub_id="al-nassr",
|
||||
narodowosc="PT",
|
||||
ilosc_trofeow=0, # Brak danych na Flashscore
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=2,
|
||||
wycena=55_000_000 # Wartość rynkowa: €12.1 mln
|
||||
)
|
||||
|
||||
# Messi
|
||||
self.simple_insert_one(kluby,
|
||||
id_klubu="inter-miami",
|
||||
pelna_nazwa="Inter Miami",
|
||||
skrocona_nazwa="INM"
|
||||
)
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=619,
|
||||
minut_gry=0, # Brak danych o łącznym czasie gry
|
||||
gier_sum=619,
|
||||
goli_sum=528,
|
||||
asyst_sum=53,
|
||||
interwencji_sum=0,
|
||||
nieobronionych_interwencji_sum=0,
|
||||
zoltych_kartek_sum=0,
|
||||
czerwonych_kartek_sum=0,
|
||||
wygranych_sum=0, # Brak danych
|
||||
przegranych_sum=0, # Brak danych
|
||||
remisow_sum=0, # Brak danych
|
||||
wynik_sum=0, # Brak danych
|
||||
meczow_do_wynikow_sum=0 # Brak danych
|
||||
)
|
||||
self.simple_insert_one(sportowcy,
|
||||
zewnetrzne_id_zawodnika="vgOOdZbd",
|
||||
imie="Lionel",
|
||||
nazwisko="Messi",
|
||||
data_urodzenia="24.06.1987",
|
||||
czy_aktywny=True,
|
||||
klub_id="inter-miami",
|
||||
narodowosc="AR",
|
||||
ilosc_trofeow=0, # Brak danych na Flashscore
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=3,
|
||||
wycena=67_000_000 # Wartość rynkowa: €15.3 mln
|
||||
)
|
||||
|
||||
# Mbappe
|
||||
self.simple_insert_one(kluby,
|
||||
id_klubu="real-madryt",
|
||||
pelna_nazwa="Real Madryt",
|
||||
skrocona_nazwa="RMA"
|
||||
)
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=280,
|
||||
minut_gry=0, # Brak danych o łącznym czasie gry
|
||||
gier_sum=280,
|
||||
goli_sum=222,
|
||||
asyst_sum=67,
|
||||
interwencji_sum=0,
|
||||
nieobronionych_interwencji_sum=0,
|
||||
zoltych_kartek_sum=38,
|
||||
czerwonych_kartek_sum=2,
|
||||
wygranych_sum=0, # Brak danych
|
||||
przegranych_sum=0, # Brak danych
|
||||
remisow_sum=0, # Brak danych
|
||||
wynik_sum=0, # Brak danych
|
||||
meczow_do_wynikow_sum=0 # Brak danych
|
||||
)
|
||||
self.simple_insert_one(sportowcy,
|
||||
zewnetrzne_id_zawodnika="Wn6E2SED",
|
||||
imie="Kylian",
|
||||
nazwisko="Mbappé",
|
||||
data_urodzenia="20.12.1998",
|
||||
czy_aktywny=True,
|
||||
klub_id="real-madryt",
|
||||
narodowosc="FR",
|
||||
ilosc_trofeow=0, # Brak danych na Flashscore
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=4,
|
||||
wycena=185_700_000 # Wartość rynkowa: €185.7 mln
|
||||
)
|
||||
|
||||
# Zlatan
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=519,
|
||||
minut_gry=0, # Brak danych o łącznym czasie gry
|
||||
gier_sum=519,
|
||||
goli_sum=355,
|
||||
asyst_sum=63,
|
||||
interwencji_sum=0,
|
||||
nieobronionych_interwencji_sum=0,
|
||||
zoltych_kartek_sum=87,
|
||||
czerwonych_kartek_sum=9,
|
||||
wygranych_sum=0, # Brak danych
|
||||
przegranych_sum=0, # Brak danych
|
||||
remisow_sum=0, # Brak danych
|
||||
wynik_sum=0, # Brak danych
|
||||
meczow_do_wynikow_sum=0 # Brak danych
|
||||
)
|
||||
self.simple_insert_one(sportowcy,
|
||||
zewnetrzne_id_zawodnika="AiH2zDve",
|
||||
imie="Zlatan",
|
||||
nazwisko="Ibrahimović",
|
||||
data_urodzenia="03.10.1981",
|
||||
czy_aktywny=False,
|
||||
klub_id="undefined",
|
||||
narodowosc="SE",
|
||||
ilosc_trofeow=0, # Brak danych na Flashscore
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=5,
|
||||
wycena=0 # Zakończył karierę
|
||||
)
|
||||
|
||||
# Suarez
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=608,
|
||||
minut_gry=0, # Brak danych o łącznym czasie gry
|
||||
gier_sum=608,
|
||||
goli_sum=399,
|
||||
asyst_sum=122,
|
||||
interwencji_sum=0,
|
||||
nieobronionych_interwencji_sum=0,
|
||||
zoltych_kartek_sum=0,
|
||||
czerwonych_kartek_sum=0,
|
||||
wygranych_sum=0, # Brak danych
|
||||
przegranych_sum=0, # Brak danych
|
||||
remisow_sum=0, # Brak danych
|
||||
wynik_sum=0, # Brak danych
|
||||
meczow_do_wynikow_sum=0 # Brak danych
|
||||
)
|
||||
self.simple_insert_one(sportowcy,
|
||||
zewnetrzne_id_zawodnika="dUShzrBp",
|
||||
imie="Luis",
|
||||
nazwisko="Suárez",
|
||||
data_urodzenia="24.01.1987",
|
||||
czy_aktywny=True,
|
||||
klub_id="inter-miami",
|
||||
narodowosc="UY",
|
||||
ilosc_trofeow=0, # Brak danych na Flashscore
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=6,
|
||||
wycena=8_800_000 # Wartość rynkowa: €2.0 mln
|
||||
)
|
||||
|
||||
# Haaland
|
||||
self.simple_insert_one(kluby,
|
||||
id_klubu="manchester-city",
|
||||
pelna_nazwa="Manchester City",
|
||||
skrocona_nazwa="MCI"
|
||||
)
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=235,
|
||||
minut_gry=0, # Brak danych o łącznym czasie gry
|
||||
gier_sum=235,
|
||||
goli_sum=178,
|
||||
asyst_sum=41,
|
||||
interwencji_sum=0,
|
||||
nieobronionych_interwencji_sum=0,
|
||||
zoltych_kartek_sum=18,
|
||||
czerwonych_kartek_sum=0,
|
||||
wygranych_sum=0, # Brak danych
|
||||
przegranych_sum=0, # Brak danych
|
||||
remisow_sum=0, # Brak danych
|
||||
wynik_sum=0, # Brak danych
|
||||
meczow_do_wynikow_sum=0 # Brak danych
|
||||
)
|
||||
self.simple_insert_one(sportowcy,
|
||||
zewnetrzne_id_zawodnika="UmV9iQmE",
|
||||
imie="Erling",
|
||||
nazwisko="Haaland",
|
||||
data_urodzenia="21.07.2000",
|
||||
czy_aktywny=True,
|
||||
klub_id="manchester-city",
|
||||
narodowosc="NO",
|
||||
ilosc_trofeow=0, # Brak danych
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=7,
|
||||
wycena=777_500_000 # ~€178.7 mln
|
||||
)
|
||||
|
||||
# Karim Benzema
|
||||
self.simple_insert_one(kluby,
|
||||
id_klubu="al-ittihad",
|
||||
pelna_nazwa="Al-Ittihad FC", #?
|
||||
skrocona_nazwa="RMA" #?
|
||||
)
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=589,
|
||||
minut_gry=0, # Brak danych
|
||||
gier_sum=589,
|
||||
goli_sum=305,
|
||||
asyst_sum=0,
|
||||
interwencji_sum=0,
|
||||
nieobronionych_interwencji_sum=0,
|
||||
zoltych_kartek_sum=14,
|
||||
czerwonych_kartek_sum=0,
|
||||
wygranych_sum=0, # Brak danych
|
||||
przegranych_sum=0,
|
||||
remisow_sum=0,
|
||||
wynik_sum=0,
|
||||
meczow_do_wynikow_sum=0
|
||||
)
|
||||
self.simple_insert_one(sportowcy,
|
||||
zewnetrzne_id_zawodnika="tpV0VX0S",
|
||||
imie="Karim",
|
||||
nazwisko="Benzema",
|
||||
data_urodzenia="19.12.1987",
|
||||
czy_aktywny=True,
|
||||
klub_id="al-ittihad",
|
||||
narodowosc="FR",
|
||||
ilosc_trofeow=0, # Flashscore nie podaje
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=8,
|
||||
wycena=31_950_000 # €7.1 mln
|
||||
)
|
||||
|
||||
# Sergio Aguero
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=443,
|
||||
minut_gry=0, # Brak danych o czasie gry
|
||||
gier_sum=443,
|
||||
goli_sum=254,
|
||||
asyst_sum=38,
|
||||
interwencji_sum=0,
|
||||
nieobronionych_interwencji_sum=0,
|
||||
zoltych_kartek_sum=47,
|
||||
czerwonych_kartek_sum=2,
|
||||
wygranych_sum=0, # Brak danych
|
||||
przegranych_sum=0, # Brak danych
|
||||
remisow_sum=0, # Brak danych
|
||||
wynik_sum=0, # Brak danych
|
||||
meczow_do_wynikow_sum=0 # Brak danych
|
||||
)
|
||||
self.simple_insert_one(sportowcy,
|
||||
zewnetrzne_id_zawodnika="vw8ZV7HC",
|
||||
imie="Sergio",
|
||||
nazwisko="Agüero",
|
||||
data_urodzenia="02.06.1988",
|
||||
czy_aktywny=False,
|
||||
klub_id="undefined",
|
||||
narodowosc="AR",
|
||||
ilosc_trofeow=0, # Brak danych
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=9,
|
||||
wycena=0 # Zakończył karierę
|
||||
)
|
||||
|
||||
# Edinson Cavani
|
||||
self.simple_insert_one(kluby,
|
||||
id_klubu="boca-juniors",
|
||||
pelna_nazwa="Boca Juniors", #?
|
||||
skrocona_nazwa="CAB" #?
|
||||
)
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=507,
|
||||
minut_gry=0, # Brak danych o czasie gry
|
||||
gier_sum=507,
|
||||
goli_sum=273,
|
||||
asyst_sum=62,
|
||||
interwencji_sum=0,
|
||||
nieobronionych_interwencji_sum=0,
|
||||
zoltych_kartek_sum=3,
|
||||
czerwonych_kartek_sum=0,
|
||||
wygranych_sum=0, # Brak danych
|
||||
przegranych_sum=0, # Brak danych
|
||||
remisow_sum=0, # Brak danych
|
||||
wynik_sum=0, # Brak danych
|
||||
meczow_do_wynikow_sum=0 # Brak danych
|
||||
)
|
||||
self.simple_insert_one(sportowcy,
|
||||
zewnetrzne_id_zawodnika="Qgx2trzH",
|
||||
imie="Edinson",
|
||||
nazwisko="Cavani",
|
||||
data_urodzenia="14.02.1987",
|
||||
czy_aktywny=True,
|
||||
klub_id="boca-juniors",
|
||||
narodowosc="UY",
|
||||
ilosc_trofeow=0,
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=10,
|
||||
wycena=4_212_000 # PLN
|
||||
)
|
||||
|
||||
# Radamel Falcao
|
||||
self.simple_insert_one(kluby,
|
||||
id_klubu="millonarios",
|
||||
pelna_nazwa="Millonarios",
|
||||
skrocona_nazwa="MLA" #?
|
||||
)
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=360,
|
||||
minut_gry=0, # brak danych o czasie gry
|
||||
gier_sum=360,
|
||||
goli_sum=170,
|
||||
asyst_sum=17,
|
||||
interwencji_sum=54,
|
||||
nieobronionych_interwencji_sum=1,
|
||||
zoltych_kartek_sum=0, # brak danych
|
||||
czerwonych_kartek_sum=0,
|
||||
wygranych_sum=0,
|
||||
przegranych_sum=0,
|
||||
remisow_sum=0,
|
||||
wynik_sum=0,
|
||||
meczow_do_wynikow_sum=0
|
||||
)
|
||||
self.simple_insert_one(sportowcy,
|
||||
zewnetrzne_id_zawodnika="2oMimkAU",
|
||||
imie="Radamel",
|
||||
nazwisko="Falcao",
|
||||
data_urodzenia="10.02.1986",
|
||||
czy_aktywny=True,
|
||||
klub_id="millonarios",
|
||||
narodowosc="CO",
|
||||
ilosc_trofeow=0, # brak danych
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=11,
|
||||
wycena=1_084_500 #PLN
|
||||
)
|
||||
|
||||
# Wayne Rooney
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=568,
|
||||
minut_gry=0, # brak danych o czasie gry
|
||||
gier_sum=568,
|
||||
goli_sum=234,
|
||||
asyst_sum=47,
|
||||
interwencji_sum=0, # brak danych
|
||||
nieobronionych_interwencji_sum=0, # brak danych
|
||||
zoltych_kartek_sum=105,
|
||||
czerwonych_kartek_sum=4,
|
||||
wygranych_sum=0, # brak danych
|
||||
przegranych_sum=0,
|
||||
remisow_sum=0,
|
||||
wynik_sum=0,
|
||||
meczow_do_wynikow_sum=0
|
||||
)
|
||||
self.simple_insert_one(sportowcy,
|
||||
zewnetrzne_id_zawodnika="WfXv1DCa",
|
||||
imie="Wayne",
|
||||
nazwisko="Rooney",
|
||||
data_urodzenia="24.10.1985",
|
||||
czy_aktywny=False, # zakończył karierę
|
||||
klub_id="undefined",
|
||||
narodowosc="ENG",
|
||||
ilosc_trofeow=0, # brak danych
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=12,
|
||||
wycena=0 # brak wyceny
|
||||
)
|
||||
|
||||
# Robin van Persie
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=374,
|
||||
minut_gry=0, # brak danych o czasie gry
|
||||
gier_sum=374,
|
||||
goli_sum=190,
|
||||
asyst_sum=16,
|
||||
interwencji_sum=0, # brak danych
|
||||
nieobronionych_interwencji_sum=0, # brak danych
|
||||
zoltych_kartek_sum=54,
|
||||
czerwonych_kartek_sum=3,
|
||||
wygranych_sum=0, # brak danych
|
||||
przegranych_sum=0,
|
||||
remisow_sum=0,
|
||||
wynik_sum=0,
|
||||
meczow_do_wynikow_sum=0
|
||||
)
|
||||
self.simple_insert_one(sportowcy,
|
||||
zewnetrzne_id_zawodnika="0vgcq6un",
|
||||
imie="Robin",
|
||||
nazwisko="van Persie",
|
||||
data_urodzenia="06.08.1983",
|
||||
czy_aktywny=False,
|
||||
klub_id="undefined", # zakończył karierę
|
||||
narodowosc="NED",
|
||||
ilosc_trofeow=0, # brak danych
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=13,
|
||||
wycena=0 # zakończył karierę
|
||||
)
|
||||
|
||||
# Harry Kane
|
||||
self.simple_insert_one(kluby,
|
||||
id_klubu="bayern",
|
||||
pelna_nazwa="Bayern Monachium",
|
||||
skrocona_nazwa="BAY"
|
||||
)
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=439,
|
||||
minut_gry=0, # brak danych o czasie gry
|
||||
gier_sum=439,
|
||||
goli_sum=295,
|
||||
asyst_sum=64,
|
||||
interwencji_sum=0, # brak danych
|
||||
nieobronionych_interwencji_sum=0,
|
||||
zoltych_kartek_sum=48,
|
||||
czerwonych_kartek_sum=1,
|
||||
wygranych_sum=0, # brak danych
|
||||
przegranych_sum=0,
|
||||
remisow_sum=0,
|
||||
wynik_sum=0,
|
||||
meczow_do_wynikow_sum=0
|
||||
)
|
||||
self.simple_insert_one(sportowcy,
|
||||
zewnetrzne_id_zawodnika="v5HSlEAa",
|
||||
imie="Harry",
|
||||
nazwisko="Kane",
|
||||
data_urodzenia="28.07.1993",
|
||||
czy_aktywny=True,
|
||||
klub_id="bayern",
|
||||
narodowosc="ENG",
|
||||
ilosc_trofeow=0, # brak danych
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=14,
|
||||
wycena=344_700_000 # PLN
|
||||
)
|
||||
|
||||
# Ciro Immobile
|
||||
self.simple_insert_one(kluby,
|
||||
id_klubu="besiktas",
|
||||
pelna_nazwa="Besiktas",
|
||||
skrocona_nazwa="BES"
|
||||
)
|
||||
self.simple_insert_one(statystyki_sportowcow,
|
||||
ostatni_mecz=1,
|
||||
ilosc_wystapien=455,
|
||||
minut_gry=0, # brak danych o czasie gry
|
||||
gier_sum=455,
|
||||
goli_sum=250,
|
||||
asyst_sum=51,
|
||||
interwencji_sum=0, # brak danych
|
||||
nieobronionych_interwencji_sum=0,
|
||||
zoltych_kartek_sum=71,
|
||||
czerwonych_kartek_sum=3,
|
||||
wygranych_sum=0,
|
||||
przegranych_sum=0,
|
||||
remisow_sum=0,
|
||||
wynik_sum=0,
|
||||
meczow_do_wynikow_sum=0
|
||||
)
|
||||
self.simple_insert_one(sportowcy,
|
||||
zewnetrzne_id_zawodnika="4S9fNUYh",
|
||||
imie="Ciro",
|
||||
nazwisko="Immobile",
|
||||
data_urodzenia="20.02.1990",
|
||||
czy_aktywny=True,
|
||||
klub_id="besiktas",
|
||||
narodowosc="IT",
|
||||
ilosc_trofeow=0, # brak danych
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=15,
|
||||
wycena=12_600_000 # PLN
|
||||
)
|
||||
|
||||
|
||||
session.commit()
|
||||
return 0
|
||||
|
||||
|
||||
@@ -23,9 +23,9 @@ def safeTraverse(obj: dict, path: list, default=None):
|
||||
try:
|
||||
for x in path:
|
||||
result = result[x]
|
||||
except KeyError:
|
||||
except (KeyError, TypeError):
|
||||
result = default
|
||||
# print(f"error reading: {' -> '.join(path)} - returning: {default}")
|
||||
print(f"error reading: {' -> '.join(path)} - returning: {default}")
|
||||
finally:
|
||||
return result
|
||||
|
||||
|
||||
@@ -2,13 +2,14 @@ from flask import render_template, request, make_response
|
||||
import lewy_api_v1
|
||||
import lewy_db
|
||||
import lewy_globals
|
||||
|
||||
import json
|
||||
from lewy_api_v1 import get_matches
|
||||
def get_lewy_stats():
|
||||
return {
|
||||
'all_time_stats': {
|
||||
'goals': 589+78,
|
||||
'assists':154+21,
|
||||
'matches': 791+136,
|
||||
'goals': 589+85,
|
||||
'assists':154+35,
|
||||
'matches': 791+158,
|
||||
},
|
||||
'club_stats': {
|
||||
'goals': 589,
|
||||
@@ -16,9 +17,9 @@ def get_lewy_stats():
|
||||
'matches': 791,
|
||||
},
|
||||
'nation_stats': {
|
||||
'goals': 78,
|
||||
'assists': 21,
|
||||
'matches': 136,
|
||||
'goals': 85,
|
||||
'assists': 35,
|
||||
'matches': 158,
|
||||
},
|
||||
'international_cups': {
|
||||
'goals': 110,
|
||||
@@ -58,30 +59,16 @@ def index():
|
||||
|
||||
def mecze():
|
||||
# Możesz dostarczyć szczegóły dotyczące meczów
|
||||
selected_date = request.args.get("date", 2024)
|
||||
matches = [
|
||||
{'date': '2024-10-12', 'opponent': 'Real Madrid', 'goals': 2, 'assists': 1, 'minutes': 90},
|
||||
{'date': '2024-10-19', 'opponent': 'Valencia', 'goals': 1, 'assists': 0, 'minutes': 85},
|
||||
{'date': '2023-10-19', 'opponent': 'Valencia', 'goals': 1, 'assists': 0, 'minutes': 85},
|
||||
{'date': '2023-10-19', 'opponent': 'Valencia', 'goals': 1, 'assists': 0, 'minutes': 85},
|
||||
{'date': '2023-10-19', 'opponent': 'Valencia', 'goals': 1, 'assists': 0, 'minutes': 85},
|
||||
{'date': '2022-10-19', 'opponent': 'Valencia', 'goals': 1, 'assists': 0, 'minutes': 85},
|
||||
{'date': '2022-10-19', 'opponent': 'Valencia', 'goals': 1, 'assists': 0, 'minutes': 85},
|
||||
{'date': '2022-10-19', 'opponent': 'Valencia', 'goals': 1, 'assists': 0, 'minutes': 85},
|
||||
{'date': '2022-10-19', 'opponent': 'Valencia', 'goals': 1, 'assists': 0, 'minutes': 85},
|
||||
{'date': '2021-10-19', 'opponent': 'Valencia', 'goals': 1, 'assists': 0, 'minutes': 85},
|
||||
{'date': '2021-10-19', 'opponent': 'Valencia', 'goals': 1, 'assists': 0, 'minutes': 85},
|
||||
{'date': '2021-10-19', 'opponent': 'Valencia', 'goals': 1, 'assists': 0, 'minutes': 85},
|
||||
{'date': '2021-10-19', 'opponent': 'Valencia', 'goals': 1, 'assists': 0, 'minutes': 85},
|
||||
{'date': '2020-10-19', 'opponent': 'Valencia', 'goals': 1, 'assists': 0, 'minutes': 85},
|
||||
{'date': '2020-10-19', 'opponent': 'Valencia', 'goals': 1, 'assists': 0, 'minutes': 85},
|
||||
{'date': '2020-10-19', 'opponent': 'Valencia', 'goals': 1, 'assists': 0, 'minutes': 85},
|
||||
{'date': '2019-10-19', 'opponent': 'Valencia', 'goals': 1, 'assists': 0, 'minutes': 85},
|
||||
{'date': '2019-10-19', 'opponent': 'Valencia', 'goals': 1, 'assists': 0, 'minutes': 85},
|
||||
{'date': '2019-10-19', 'opponent': 'Valencia', 'goals': 1, 'assists': 0, 'minutes': 85},
|
||||
|
||||
]
|
||||
return render_template('matches.html', matches=matches)
|
||||
selected_date = request.args.get("date", '2025')
|
||||
try:
|
||||
selected_date = int(selected_date)
|
||||
except:
|
||||
selected_date = 2025
|
||||
#with open("static/lewandowski_matches.json", "r") as file:
|
||||
# data = json.load(file)
|
||||
status, msg, matches = get_matches(None, id_zawodnika=1, rok=selected_date)
|
||||
|
||||
return render_template('matches.html', matches=matches, selected_date=selected_date)
|
||||
|
||||
def statystyki():
|
||||
dane=get_lewy_stats()
|
||||
@@ -114,13 +101,83 @@ def compare():
|
||||
selected_player = request.args.get("player","Leo Messi")
|
||||
lewy=get_lewy_stats()
|
||||
player2 = [
|
||||
{'name':'Leo Messi','goals': 34,'assists': 12},
|
||||
{'name':'Leo Messi','goals': 865,'assists': 384,'matches':1103},
|
||||
{'name':'Cristiano Ronaldo','goals': 937,'assists': 257,'matches':1280},
|
||||
{'name':'Kylian Mbappé','goals': 330,'assists': 187,'matches':436},
|
||||
{'name':'Zlatan Ibrahimović','goals': 573,'assists': 200,'matches':988},
|
||||
{'name':'Luis Suárez','goals': 511,'assists': 277,'matches':858},
|
||||
{'name':'Erling Haaland','goals': 276,'assists': 49,'matches':342},
|
||||
{'name':'Karim Benzema','goals': 438,'assists': 160,'matches':820},
|
||||
{'name':'Sergio Agüero','goals': 385,'assists': 118,'matches':685},
|
||||
]
|
||||
return render_template('compare.html',player2=player2, selected_player=selected_player,**lewy, )
|
||||
def trophies():
|
||||
trophy = [
|
||||
{'name': 'asdasd', 'year': 2023},
|
||||
{'name': 'ssss', 'sezon': '2022/2023'},
|
||||
{'name': 'Piłkarz Roku FIFA', 'year':'2021'},
|
||||
{'name': 'Piłkarz Roku FIFA', 'year':'2020'},
|
||||
{'name': 'UEFA Best Player in Europe', 'year':'2020'},
|
||||
{'name': 'Zdobywca Złotego Buta (Europe)', 'sezon':'2021/2022'},
|
||||
{'name': 'Zdobywca Złotego Buta (Europe)', 'sezon':'2020/2021'},
|
||||
{'name': 'Piłkarz roku', 'sezon':'2021'},
|
||||
{'name': 'Piłkarz roku', 'sezon':'2021'},
|
||||
{'name': 'Piłkarz roku', 'sezon':'2020'},
|
||||
{'name': 'Piłkarz roku', 'sezon':'2020'},
|
||||
{'name': 'Piłkarz roku', 'sezon':'2019'},
|
||||
{'name': 'Piłkarz roku', 'sezon':'2017'},
|
||||
{'name': 'Piłkarz roku', 'sezon':'2016'},
|
||||
{'name': 'Piłkarz roku', 'sezon':'2015'},
|
||||
{'name': 'Piłkarz roku', 'sezon':'2014'},
|
||||
{'name': 'Piłkarz roku', 'sezon':'2013'},
|
||||
{'name': 'Piłkarz roku', 'sezon':'2012'},
|
||||
{'name': 'Piłkarz roku', 'sezon':'2011'},
|
||||
{'name': 'Król strzelców', 'sezon':'2022/2023'},
|
||||
{'name': 'Król strzelców', 'sezon':'2021/2022'},
|
||||
{'name': 'Król strzelców', 'sezon':'2020/2021'},
|
||||
{'name': 'Król strzelców', 'sezon':'2019/2020'},
|
||||
{'name': 'Król strzelców', 'sezon':'2019/2020'},
|
||||
{'name': 'Król strzelców', 'sezon':'2018/2019'},
|
||||
{'name': 'Król strzelców', 'sezon':'2018/2019'},
|
||||
{'name': 'Król strzelców', 'sezon':'2017/2018'},
|
||||
{'name': 'Król strzelców', 'sezon':'2017/2018'},
|
||||
{'name': 'Król strzelców', 'sezon':'2016/2017'},
|
||||
{'name': 'Król strzelców', 'sezon':'2016/2017'},
|
||||
{'name': 'Król strzelców', 'sezon':'2015/2016'},
|
||||
{'name': 'Król strzelców', 'sezon':'2015/2016'},
|
||||
{'name': 'Król strzelców', 'sezon':'2013/2014'},
|
||||
{'name': 'Król strzelców', 'sezon':'2011/2012'},
|
||||
{'name': 'Król strzelców', 'sezon':'2009/2010'},
|
||||
{'name': 'Zdobywca Ligi Mistrzów', 'sezon':'2019/2020'},
|
||||
{'name': 'Zdobywca Klubowych Mistrzostw Świata', 'sezon':'2021'},
|
||||
{'name': 'Mistrz Hiszpanii', 'sezon':'2024/2025'},
|
||||
{'name': 'Mistrz Hiszpanii', 'sezon':'2022/2023'},
|
||||
{'name': 'Mistrz Niemiec', 'sezon':'2021/2022'},
|
||||
{'name': 'Mistrz Niemiec', 'sezon':'2020/2021'},
|
||||
{'name': 'Mistrz Niemiec', 'sezon':'2019/2020'},
|
||||
{'name': 'Mistrz Niemiec', 'sezon':'2018/2019'},
|
||||
{'name': 'Mistrz Niemiec', 'sezon':'2017/2018'},
|
||||
{'name': 'Mistrz Niemiec', 'sezon':'2016/2017'},
|
||||
{'name': 'Mistrz Niemiec', 'sezon':'2015/2016'},
|
||||
{'name': 'Mistrz Niemiec', 'sezon':'2014/2015'},
|
||||
{'name': 'Mistrz Niemiec', 'sezon':'2011/2012'},
|
||||
{'name': 'Mistrz Niemiec', 'sezon':'2010/2011'},
|
||||
{'name': 'Mistrz Niemiec', 'sezon':'2020/2021'},
|
||||
{'name': 'Zdobywca Superpucharu UEFA', 'sezon':'2020/2021'},
|
||||
{'name': 'Zdobywca Pucharu Niemiec', 'sezon':'2019/2020'},
|
||||
{'name': 'Zdobywca Pucharu Niemiec', 'sezon':'2018/2019'},
|
||||
{'name': 'Zdobywca Pucharu Niemiec', 'sezon':'2015/2016'},
|
||||
{'name': 'Zdobywca Pucharu Niemiec', 'sezon':'2011/2012'},
|
||||
{'name': 'Zdobywca Pucharu Hiszpanii', 'sezon':'2024/2025'},
|
||||
{'name': 'Zdobywca Superpucharu Niemiec', 'sezon':'2021/2022'},
|
||||
{'name': 'Zdobywca Superpucharu Niemiec', 'sezon':'2020/2021'},
|
||||
{'name': 'Zdobywca Superpucharu Niemiec', 'sezon':'2018/2019'},
|
||||
{'name': 'Zdobywca Superpucharu Niemiec', 'sezon':'2017/2018'},
|
||||
{'name': 'Zdobywca Superpucharu Niemiec', 'sezon':'2016/2017'},
|
||||
{'name': 'Zdobywca Superpucharu Niemiec', 'sezon':'2013/2014'},
|
||||
{'name': 'Zdobywca Superpucharu Hiszpanii', 'sezon':'2024/2025'},
|
||||
{'name': 'Zdobywca Superpucharu Hiszpanii', 'sezon':'2022/2023'},
|
||||
{'name': 'Mistrz Polski', 'sezon':'2009/2010'},
|
||||
{'name': 'Zdobywca Superpucharu Polski', 'sezon': '2009/2010'},
|
||||
{'name': 'Zdobywca Pucharu Polski', 'sezon': '2008/2009'},
|
||||
]
|
||||
return render_template('trophies.html',trophy=trophy)
|
||||
|
||||
|
||||
11421
FlaskWebProject/FlaskWebProject/static/lewandowski_matches.json
Normal file
11421
FlaskWebProject/FlaskWebProject/static/lewandowski_matches.json
Normal file
File diff suppressed because it is too large
Load Diff
@@ -386,6 +386,34 @@ header button {
|
||||
display: none;
|
||||
}
|
||||
}
|
||||
@media (max-width: 600px){
|
||||
.section__matches
|
||||
{
|
||||
font-size: 10px;
|
||||
}
|
||||
.section__matches th{
|
||||
padding: 3px;
|
||||
}
|
||||
.club-stats-grid
|
||||
{
|
||||
grid-template-columns: 1fr 1fr !important;
|
||||
}
|
||||
.club-stats-grid .stat-box
|
||||
{
|
||||
width: 100%;
|
||||
}
|
||||
.section-stats-center .section-stats .stats
|
||||
{
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
align-items: center;
|
||||
}
|
||||
.section-stats-center .section-stats .stats .stat-box
|
||||
{
|
||||
width: 100%;
|
||||
padding: 0;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
@@ -716,6 +744,26 @@ body.poland-mode .general-stats-section .grid article:nth-child(2){background-co
|
||||
body.poland-mode .general-stats-section .grid article:nth-child(3){background-color: var(--barca-blue);}
|
||||
body.poland-mode .about-section-image::after{
|
||||
background:var(--polska-red-dark);
|
||||
}
|
||||
body.poland-mode .section__matches
|
||||
{
|
||||
background-color: white;
|
||||
}
|
||||
body.poland-mode .section__matches h2
|
||||
{
|
||||
background-color: var(--polska-red);
|
||||
color: white;
|
||||
}
|
||||
body.poland-mode .section__matches th
|
||||
{
|
||||
color: var(--barca-red)
|
||||
}
|
||||
body.poland-mode .section__matches tr:hover:has(:not(th))
|
||||
{
|
||||
background-color: #ff5959;
|
||||
}
|
||||
body.poland-mode select{
|
||||
background:var(--section-color);
|
||||
}
|
||||
/* Przyciski i elementy */
|
||||
|
||||
@@ -733,6 +781,13 @@ body.poland-mode .about-section-image::after{
|
||||
margin-bottom: 10px;
|
||||
width: 100%;
|
||||
}
|
||||
.section-stats h1{
|
||||
font-size: 34px;
|
||||
color: var(--barca-red);
|
||||
}
|
||||
body.poland-mode .section-stats h1{
|
||||
color: white;
|
||||
}
|
||||
.section-stats-center
|
||||
{
|
||||
display: grid;
|
||||
@@ -851,4 +906,32 @@ select
|
||||
background-color: var(--barca-blue);
|
||||
border-radius: 10px;
|
||||
border: 2px solid white;
|
||||
}
|
||||
@media (max-width: 600px){
|
||||
.sectionmatches
|
||||
{
|
||||
font-size: 10px;
|
||||
}
|
||||
.sectionmatches th{
|
||||
padding: 3px;
|
||||
}
|
||||
.club-stats-grid
|
||||
{
|
||||
grid-template-columns: 1fr 1fr !important;
|
||||
}
|
||||
.club-stats-grid .stat-box
|
||||
{
|
||||
width: 100%;
|
||||
}
|
||||
.section-stats-center .section-stats .stats
|
||||
{
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
align-items: center;
|
||||
}
|
||||
.section-stats-center .section-stats .stats .stat-box
|
||||
{
|
||||
width: 100%;
|
||||
padding: 0;
|
||||
}
|
||||
}
|
||||
@@ -6,13 +6,19 @@
|
||||
<select onchange="location = this.value;">
|
||||
<option disabled selected>Wybierz zawodnika</option>
|
||||
<option value="{{ url_for('compare', player='Leo Messi') }}">Leo Messi</option>
|
||||
<option value="{{ url_for('compare', player='Ronaldo') }}">Cristiano Ronaldo</option>
|
||||
<option value="{{ url_for('compare', player='Neymar') }}">Neymar</option>
|
||||
<option value="{{ url_for('compare', player='Cristiano Ronaldo') }}">Cristiano Ronaldo</option>
|
||||
<option value="{{ url_for('compare', player='Kylian Mbappé') }}">Kylian Mbappé</option>
|
||||
<option value="{{ url_for('compare', player='Zlatan Ibrahimović') }}">Zlatan Ibrahimović</option>
|
||||
<option value="{{ url_for('compare', player='Luis Suárez') }}">Luis Suárez</option>
|
||||
<option value="{{ url_for('compare', player='Erling Haaland') }}">Erling Haaland</option>
|
||||
<option value="{{ url_for('compare', player='Karim Benzema') }}">Karim Benzema</option>
|
||||
<option value="{{ url_for('compare', player='Sergio Agüero') }}">Sergio Agüero</option>
|
||||
</select>
|
||||
|
||||
{%for player in player2 %}
|
||||
{% if player.name == selected_player %}
|
||||
<section class="section-stats">
|
||||
<h1>Robert Lewandowski VS {{selected_player}}</h1>
|
||||
<h2>Gole</h2>
|
||||
<div class="stats">
|
||||
<div class="stat-box">
|
||||
@@ -41,26 +47,15 @@
|
||||
<h2>Wystąpienia</h2>
|
||||
<div class="stats">
|
||||
<div class="stat-box">
|
||||
<h3>{{ all_time_stats.assists }}</h3>
|
||||
<h3>{{ all_time_stats.matches }}</h3>
|
||||
|
||||
</div>
|
||||
<div class="stat-box">
|
||||
<h3>{{ player.assists}}</h3>
|
||||
<h3>{{ player.matches}}</h3>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<h2>Minuty zagrane</h2>
|
||||
<div class="stats">
|
||||
<div class="stat-box">
|
||||
<h3>{{ all_time_stats.assists }}</h3>
|
||||
|
||||
</div>
|
||||
<div class="stat-box">
|
||||
<h3>{{ player.assists}}</h3>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
</section>
|
||||
{% endif %}
|
||||
{% endfor%}
|
||||
|
||||
@@ -10,27 +10,27 @@
|
||||
<article class="article__how-it-works">
|
||||
<h3>Jak to działa?</h3>
|
||||
<h4>Pobieranie statystyk</h4>
|
||||
<p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Ratione harum minus hic, voluptate perspiciatis laborum? Alias maxime, voluptate reprehenderit iusto dolorem officiis porro voluptatibus repellat dicta doloribus, blanditiis similique accusantium.</p>
|
||||
<p>Tu znajdziesz najświeższe statystyki, aktualizowane zaraz po zakończeniu meczu Lewego</p>
|
||||
<h4>Porównywanie zawodników</h4>
|
||||
<p>Lorem, ipsum dolor sit amet consectetur adipisicing elit. Fuga, in perspiciatis. Sequi laborum et animi quas sit voluptatibus alias sed ad molestias nulla vel cum, consectetur commodi odio aliquam officia.</p>
|
||||
<p>Robert Lewandowski jest uznawany za jednego z najlepszych zawodników na świecie, zobacz jak wypada w porównaniu do innych czołowych zawodników i sprawdź czy zasługuje na miano jednego z najlepszych napastników świata.</p>
|
||||
</article>
|
||||
<div class="about-section-image">
|
||||
<img src="{{ url_for('static', filename='gigabuła.png') }}">
|
||||
</div>
|
||||
<article>
|
||||
<h3>Mecze</h3>
|
||||
<p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Soluta ullam iusto ex? Quo amet officia aliquam odio sint harum nam eaque nihil ipsa quos aliquid, illum voluptatum, numquam, magnam omnis?</p>
|
||||
<p>Nie oglądałeś ostatniego meczu Barcelony? Wypadło Ci coś i nie widziałeś najnowszego spotkania reprezentacji Polski? Wejdź i sprawdź jak poradził sobie Robert.</p>
|
||||
<a href="/mecze">Zobacz mecze</a>
|
||||
</article>
|
||||
<article>
|
||||
<h3>Statystyki</h3>
|
||||
<p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Temporibus dolore tenetur nulla sint recusandae illo dolores aspernatur ducimus, omnis vitae ipsam neque animi voluptates eos porro, nihil iusto veniam commodi!</p>
|
||||
<p>Jesteś zainteresowany jak Robert radzi sobie na przestrzeni tylu lat gry? Jesteś ciekaw czy napastnik oprócz strzelania bramek lubi kolekcjonować kartki? Sprawdź u nas jak wygląda kariera Roberta Lewandowskiego na podstawie jego gry w kadrze Polski, klubach oraz Pucharach ligowych i międzynarodowych.</p>
|
||||
<a href="/statystyki">Zobacz statystyki</a>
|
||||
</article>
|
||||
<article>
|
||||
<h3>Osiągnięcia</h3>
|
||||
<p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Quod dicta veritatis quibusdam eligendi corrupti. Expedita delectus assumenda ipsum illum molestias a voluptates, voluptas quia reprehenderit, quod non, eum veritatis tenetur!</p>
|
||||
<a href="/club">Zobacz osiągnięcia</a>
|
||||
<h3>Trofea</h3>
|
||||
<p>Zastanawia Cie jakie było ostatnie trofeum Roberta? A może z kolegami sprawdzacie, który lepiej pamięta złote chwile w karierze naszego idola? Rozwiejcie wasze wątpliwości i zobaczcie wielką kolekcji zdobyczy pucharowych najlepszego polskiego zawodnika.</p>
|
||||
<a href="/club">Zobacz trofea</a>
|
||||
</article>
|
||||
</section>
|
||||
<!--
|
||||
@@ -57,5 +57,7 @@
|
||||
{% endblock %}
|
||||
|
||||
{% block footer %}
|
||||
<!--
|
||||
{{ commit_in_html | safe }}
|
||||
-->
|
||||
{% endblock %}
|
||||
@@ -3,35 +3,50 @@
|
||||
{% block title %}Lista meczów{% endblock %}
|
||||
|
||||
{% block content %}
|
||||
<select>
|
||||
<select onchange="location = this.value;">
|
||||
<option disabled selected>Wybierz rok</option>
|
||||
<option value="{{ url_for('compare', player='Leo Messi') }}">2024/2025</option>
|
||||
<option value="{{ url_for('compare', player='Ronaldo') }}">2023/2024</option>
|
||||
<option value="{{ url_for('compare', player='Neymar') }}">2022/2023</option>
|
||||
<option value="{{ url_for('compare', player='Neymar') }}">2021/2022</option>
|
||||
<option value="{{ url_for('compare', player='Neymar') }}">2020/2021</option>
|
||||
<option value="{{ url_for('compare', player='Neymar') }}">2019/2020</option>
|
||||
<option value="{{ url_for('compare', player='Neymar') }}">2018/2019</option>
|
||||
<option value="{{ url_for('compare', player='Neymar') }}">2017/2018</option>
|
||||
<option value="{{ url_for('compare', player='Neymar') }}">2016/2017</option>
|
||||
<option value="{{ url_for('mecze', date='2025') }}">2025</option>
|
||||
<option value="{{ url_for('mecze', date='2024') }}">2024</option>
|
||||
<option value="{{ url_for('mecze', date='2023') }}">2023</option>
|
||||
<option value="{{ url_for('mecze', date='2022') }}">2022</option>
|
||||
<option value="{{ url_for('mecze', date='2021') }}">2021</option>
|
||||
<option value="{{ url_for('mecze', date='2020') }}">2020</option>
|
||||
<option value="{{ url_for('mecze', date='2019') }}">2019</option>
|
||||
<option value="{{ url_for('mecze', date='2018') }}">2018</option>
|
||||
<option value="{{ url_for('mecze', date='2017') }}">2017</option>
|
||||
<option value="{{ url_for('mecze', date='2016') }}">2016</option>
|
||||
<option value="{{ url_for('mecze', date='2015') }}">2015</option>
|
||||
<option value="{{ url_for('mecze', date='2014') }}">2014</option>
|
||||
</select>
|
||||
<section class="section__matches">
|
||||
<h2>📅 Mecze Roberta</h2>
|
||||
<table>
|
||||
<tr>
|
||||
<th>Data</th>
|
||||
|
||||
<!--
|
||||
<th>Przeciwnik</th>
|
||||
<th>Gole</th>
|
||||
<th>Asysty</th>
|
||||
<th>Minuty</th>
|
||||
-->
|
||||
<th>Gospodarze</th>
|
||||
<th>Wynik</th>
|
||||
<th>Goście</th>
|
||||
<th></th>
|
||||
</tr>
|
||||
{% for match in matches %}
|
||||
<tr>
|
||||
<td>{{ match.date }}</td>
|
||||
<td>{{ match.opponent }}</td>
|
||||
<td>{{ match.data }}</td>
|
||||
|
||||
<td>{{ match.gospodarze_pelna_nazwa }}</td>
|
||||
<td>{{ match.gosp_wynik }} : {{ match.gosc_wynik }}</td>
|
||||
<td>{{ match.goscie_pelna_nazwa }}</td>
|
||||
<!--
|
||||
<td>{{ match.goals }}</td>
|
||||
<td>{{ match.assists }}</td>
|
||||
<td>{{ match.minutes }}</td>
|
||||
-->
|
||||
</tr>
|
||||
{% endfor %}
|
||||
</table>
|
||||
|
||||
@@ -14,7 +14,7 @@
|
||||
<p>Asysty:</p> <span class="stat-box-special"> {{ nation_stats.assists }} </span>
|
||||
</div>
|
||||
<div class="stat-box">
|
||||
<p>Występy:</p> <span class="stat-box-special"> {{ nation_stats.goals }} </span>
|
||||
<p>Występy:</p> <span class="stat-box-special"> {{ nation_stats.matches }} </span>
|
||||
</div>
|
||||
<div class="stat-box">
|
||||
<p>Łączny czas gry:</p> <span class="stat-box-special"> {{ nation_stats.minutes_played }}</span>
|
||||
|
||||
@@ -4,7 +4,7 @@
|
||||
|
||||
{% block content %}
|
||||
<section class="section__matches">
|
||||
<h2>📅 Trofea</h2>
|
||||
<h2>🏆 Trofea</h2>
|
||||
<table>
|
||||
<tr>
|
||||
<th>Nazwa</th>
|
||||
|
||||
Reference in New Issue
Block a user