Compare commits
6 Commits
scraper_te
...
c2568c86ef
| Author | SHA1 | Date | |
|---|---|---|---|
| c2568c86ef | |||
|
|
13f6e2e3b9 | ||
|
|
9a007f504c | ||
|
|
b5fdbb3230 | ||
| 35db71b8cc | |||
| bdfa31c8ea |
@@ -1,9 +1,11 @@
|
||||
from flask import session
|
||||
from lewy_db import baza as ldb
|
||||
from lewy_globals import colors as c
|
||||
import json
|
||||
import lewy_globals
|
||||
import requests
|
||||
import time
|
||||
from sqlalchemy import func
|
||||
|
||||
def safe_traverse(obj: dict, path: list, default=None):
|
||||
result = obj
|
||||
@@ -12,7 +14,7 @@ def safe_traverse(obj: dict, path: list, default=None):
|
||||
result = result[x]
|
||||
except KeyError:
|
||||
result = default
|
||||
# print(f"error reading: {' -> '.join(path)} - returning: {default}")
|
||||
print(f"safe_traverse: error reading {' -> '.join(path)} - returning: {default}")
|
||||
finally:
|
||||
return result
|
||||
|
||||
@@ -45,6 +47,17 @@ class scraper:
|
||||
else:
|
||||
return False
|
||||
|
||||
def to_iso_compatible_date(self, dmy_date: str):
|
||||
"""
|
||||
Zamienia datę z formatu DD.MM.YY na YYYY-MM-DD
|
||||
|
||||
:param dmy_date: Data w formacie DD.MM.YY
|
||||
:type dmy_date: str
|
||||
"""
|
||||
day, month, year = dmy_date.split(".")
|
||||
return f"{2000 + int(year)}-{month}-{day}"
|
||||
|
||||
|
||||
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 != []:
|
||||
@@ -61,18 +74,44 @@ class scraper:
|
||||
# return False
|
||||
return self.__czy_x_istnieje("kluby", id_klubu=id_klubu)
|
||||
|
||||
def id_na_imie_nazwisko_urodziny(self, zewnetrzne_id_sportowca: str = "MVC8zHZD"):
|
||||
"""
|
||||
Scraper z dykty xD
|
||||
Pobiera imiona, nazwiska i dni urodzin sportowców z zewnętrznego id.
|
||||
Działa na słowo honoru.
|
||||
|
||||
:param zewnetrzne_id_sportowca: Zewnętrzne id sportowca
|
||||
:type zewnetrzne_id_sportowca: str
|
||||
"""
|
||||
if len(zewnetrzne_id_sportowca) != 8:
|
||||
raise ValueError("Zewnętrzne ID sportowca powinno być długości 8!")
|
||||
r = requests.get(f'https://www.flashscore.pl/?r=4:{zewnetrzne_id_sportowca}')
|
||||
page = r.text
|
||||
|
||||
name_start_pos = page.find("data-testid=\"wcl-scores-heading-02\">") + 36
|
||||
name_end_pos = page.find("</", name_start_pos)
|
||||
name = page[name_start_pos:name_end_pos].strip().split(' ')
|
||||
|
||||
# Tak wiem... można by było użyć beautifulsoup4, ale nie ma sensu dodawać nowych zależności dla tylko jednej metody.
|
||||
birthday_start_pos_1 = page.find("data-testid=\"wcl-scores-simpleText-01\">", name_end_pos) + 39
|
||||
birthday_start_pos_2 = page.find("data-testid=\"wcl-scores-simpleText-01\">", birthday_start_pos_1) + 39
|
||||
birthday_start_pos_3 = page.find("data-testid=\"wcl-scores-simpleText-01\">", birthday_start_pos_2) + 39
|
||||
birthday_start_pos = page.find("data-testid=\"wcl-scores-simpleText-01\">", birthday_start_pos_3) + 39
|
||||
birthday_end_pos = page.find("</", birthday_start_pos) - 1
|
||||
birthday = None if birthday_end_pos - birthday_start_pos > 20 else page[birthday_start_pos:birthday_end_pos].strip(" ()")
|
||||
|
||||
return name, birthday
|
||||
|
||||
def aktualizuj_dane_sportowca(self, zewnetrzne_id_sportowca: str = "MVC8zHZD"):
|
||||
stop_scraping = False
|
||||
matches_to_add = []
|
||||
|
||||
# TODO: Sprawdź, czy sportowiec istnieje w bazie.
|
||||
if not self.__czy_x_istnieje("sportowcy", zewnetrzne_id_sportowca=zewnetrzne_id_sportowca):
|
||||
print(f"{c.OKCYAN}Dodaję nowego sportowca do bazy danych{c.ENDC}")
|
||||
self.db.simple_insert_one("sportowcy",
|
||||
zewnetrzne_id_sportowca=zewnetrzne_id_sportowca,
|
||||
imie="Robert",
|
||||
nazwisko="Lewandowski"
|
||||
)
|
||||
# Jeśli nie, dodaj go w podobny sposób, jak
|
||||
# w sample_data_init() (w lewy_db.py).
|
||||
|
||||
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]
|
||||
|
||||
page = 0
|
||||
match_num = 0
|
||||
@@ -88,14 +127,17 @@ class scraper:
|
||||
retrieved_matches = safe_traverse(retrieved_page, ["lastMatches"], default=[])
|
||||
for match in retrieved_matches:
|
||||
|
||||
match_id = safe_traverse(match, ["eventEncodedId"], default="non-existent-match-id")
|
||||
match_id = safe_traverse(match, ["eventEncodedId"], default="non-existent-match-id")
|
||||
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):
|
||||
stop_scraping = True
|
||||
break
|
||||
|
||||
# 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):
|
||||
print(f"{c.OKCYAN}Nowy klub{c.ENDC}: {home_club_id}")
|
||||
self.db.simple_insert_one("kluby",
|
||||
@@ -109,40 +151,107 @@ class scraper:
|
||||
pelna_nazwa=safe_traverse(match, ["awayParticipantName"]),
|
||||
skrocona_nazwa=safe_traverse(match, ["awayParticipant3CharName"]))
|
||||
|
||||
# TODO: Zamień słownik match na obiekt mecz
|
||||
mecz = {
|
||||
"zewnetrzne_id_meczu": match_id,
|
||||
"data": safe_traverse(match, ["startTimeTimestamp"], default=0),
|
||||
"id_klubu_gospodarzy": home_club_id,
|
||||
"id_klubu_gosci": away_club_id,
|
||||
"gole_gospodarzy": safe_traverse(match, ["homeScore", "current"], default=0),
|
||||
"gole_gosci": safe_traverse(match, ["awayScore", "current"], default=0),
|
||||
"rozgrywki": safe_traverse(match, ["tournament", "name"], default="Brak"),
|
||||
"zewnetrzne_id_sportowca": zewnetrzne_id_sportowca
|
||||
}
|
||||
# TODO: (opcjonalnie) zamień *słownik match* na *obiekt mecz*
|
||||
|
||||
# TODO: Dodaj obiekt mecz do bazy
|
||||
self.db.simple_insert_one("mecze", **mecz)
|
||||
|
||||
print(f"{c.OKCYAN}Nowy mecz ({match_num}){c.ENDC}: {match_id}")
|
||||
|
||||
# TODO: dodaj obiekt mecz do bazy (simple_insert_one(), simple_insert_many())
|
||||
print(f"{c.OKCYAN}Nowy mecz ({match_num}){c.ENDC}: {match}")
|
||||
|
||||
iso_converted_date = self.to_iso_compatible_date(safe_traverse(match, ["eventStartTime"], default="1970-01-01"))
|
||||
|
||||
self.db.simple_insert_one("mecze",
|
||||
zewnetrzne_id_meczu = safe_traverse(match, ["eventEncodedId"], default=""),
|
||||
data = iso_converted_date,
|
||||
gospodarze_id = home_club_id,
|
||||
gospodarze = self.db.simple_select_all("kluby", id_klubu=home_club_id)[0],
|
||||
goscie_id = away_club_id,
|
||||
goscie = self.db.simple_select_all("kluby", id_klubu=away_club_id)[0],
|
||||
gosp_wynik = safe_traverse(match, ["homeScore"], default=0),
|
||||
gosc_wynik = safe_traverse(match, ["awayScore"], default=0),
|
||||
sezon = safe_traverse(match, ["tournamentSeason"], default=""),
|
||||
nazwa_turnieju = safe_traverse(match, ["tournamentTitle"], default=""),
|
||||
skrocona_nazwa_turnieju = safe_traverse(match, ["tournamentTemplateShortCode"], default=""),
|
||||
flaga = safe_traverse(match, ["flagId"], default=0),
|
||||
)
|
||||
match_num += 1
|
||||
|
||||
# TODO: Zaktualizuj statystyki sportowca
|
||||
# np. zlicz gole RL9
|
||||
strzelcy = safe_traverse(match, ["goals"], default=[])
|
||||
liczba_goli = 0
|
||||
for gol in strzelcy:
|
||||
if gol.get("playerId") == zewnetrzne_id_sportowca:
|
||||
liczba_goli += 1
|
||||
stats = safe_traverse(match, ["stats"], default="")
|
||||
zewnetrzne_id_meczu = safe_traverse(match, ["eventEncodedId"], default="")
|
||||
|
||||
if liczba_goli > 0:
|
||||
# zwiększamy liczbę goli zawodnika
|
||||
print(f"{c.OKBLUE}Zwiększam gole Lewandowskiego o {liczba_goli}{c.ENDC}")
|
||||
self.db.increment_stat("sportowcy", {"zewnetrzne_id_sportowca": zewnetrzne_id_sportowca}, "gole", liczba_goli)
|
||||
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
|
||||
# )
|
||||
|
||||
# # 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",
|
||||
# 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,
|
||||
# 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
|
||||
# )
|
||||
|
||||
else:
|
||||
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
|
||||
# )
|
||||
|
||||
# TODO: Zaktualizuj statystyki sportowca
|
||||
|
||||
|
||||
# Opcjonalnie: odczekaj kilka sekund (?)
|
||||
# Problem w tym, że time.sleep() jest blokujące,
|
||||
# a asyncio i flask nie idą ze sobą w parze.
|
||||
# Można to załatwić osobnym skryptem, ale
|
||||
# martwmy się tym dopiero, gdy dostaniemy
|
||||
# rate limita. - sherl
|
||||
|
||||
page += 1
|
||||
time.sleep(15)
|
||||
|
||||
#time.sleep(15)
|
||||
|
||||
|
||||
def aktualizuj_dane(self):
|
||||
|
||||
@@ -89,7 +89,12 @@ def get_matches(r):
|
||||
"""
|
||||
TODO: Zwraca mecze.
|
||||
"""
|
||||
pass
|
||||
response_json = []
|
||||
mecze = getDb().simple_select_all("mecze")
|
||||
for mecz in mecze:
|
||||
response_json.append(mecz.jsonify())
|
||||
print(response_json)
|
||||
return 200, "ok", response_json
|
||||
|
||||
# GET /api/v1/debugger_halt?token=XXX...
|
||||
@require_authentication
|
||||
@@ -142,7 +147,7 @@ def lookup(data, request):
|
||||
case 'halt':
|
||||
return debugger_halt(r = request)
|
||||
case 'matches':
|
||||
get_matches(r = request)
|
||||
return get_matches(r = request)
|
||||
case _:
|
||||
increment_bad_requests()
|
||||
return not_implemented(data)
|
||||
@@ -36,9 +36,6 @@ class baza():
|
||||
self.db = self.initDB(self.app, config)
|
||||
self.refresh_session()
|
||||
|
||||
def __repr__(self):
|
||||
return f"<Obiekt bazodanowy baza ({len(self.entities)} encji)>"
|
||||
|
||||
def initDB(self, app, config):
|
||||
global sportowcy, trofea, sportowcy_w_meczach, statystyki_sportowcow, kluby, mecze
|
||||
tnp = config['general']['db_prefix'] + "_lewangoalski_"
|
||||
@@ -223,10 +220,8 @@ class baza():
|
||||
:param string: Zapis tekstowy
|
||||
:type string: str
|
||||
"""
|
||||
try:
|
||||
table_str, column_str = string.split('.')
|
||||
except:
|
||||
raise ValueError("Nieprawidłowe dane - podaj zarówno tabelę, jak i kolumnę, np.: \"kluby.id_klubu\".")
|
||||
table_str = string[:string.find('.')]
|
||||
column_str = string[string.find('.') + 1:]
|
||||
if hasattr(self.entities[table_str], column_str):
|
||||
return getattr(self.entities[table_str], column_str)
|
||||
return None
|
||||
@@ -246,60 +241,27 @@ class baza():
|
||||
if not isinstance(entity_type, str):
|
||||
entity_type = entity_type.__name__
|
||||
|
||||
query_params, special_args = self.extract_special_args(kwargs)
|
||||
|
||||
print(f"[{round(time.time())}] SELECT {entity_type}")
|
||||
|
||||
results = (
|
||||
self.session.
|
||||
query(self.entities[entity_type]).
|
||||
filter_by(**query_params)
|
||||
)
|
||||
|
||||
# Obsługuje "ORDER_BY", "LIMIT", itp. itd.
|
||||
results = self.manipulate_results(results, special_args)
|
||||
|
||||
results_objs = results.all()
|
||||
print(f"[{round(time.time())}] SELECT RESULTS: {results_objs}")
|
||||
|
||||
return results_objs
|
||||
|
||||
def extract_special_args(self, dictionary: dict):
|
||||
"""
|
||||
Zwraca krotkę składającą się ze słowników z:
|
||||
- parametrami wyszukiwania
|
||||
- specjalnymi argumentami
|
||||
|
||||
:param dictionary: Słownik wejściowy
|
||||
:type dictionary: dict
|
||||
"""
|
||||
|
||||
# Save special arguments received with kwargs,
|
||||
# that are meant for SQL operations to special_args,
|
||||
# and delete from the rest, that will be passed
|
||||
# directly to filter_by().
|
||||
# They will not be passed as search query, but serve
|
||||
# as an additional search parameter.
|
||||
dictionary = dictionary.copy()
|
||||
|
||||
special_keywords = ("ORDER_BY", "ORDER_BY_DESC", "LIMIT")
|
||||
special_args = {}
|
||||
|
||||
for arg in special_keywords:
|
||||
if arg in dictionary:
|
||||
special_args[arg] = dictionary[arg]
|
||||
del dictionary[arg]
|
||||
if arg in kwargs:
|
||||
special_args[arg] = kwargs[arg]
|
||||
del kwargs[arg]
|
||||
|
||||
return dictionary, special_args
|
||||
print(f"[{round(time.time())}] SELECT {entity_type}")
|
||||
|
||||
def manipulate_results(self, results, special_args: dict):
|
||||
"""
|
||||
Wykonuje specjalne operacje na rezultatach wyszukiwania.
|
||||
|
||||
:param results: Wyniki wyszukiwania (ORM)
|
||||
:param special_args: Specjalne operacje
|
||||
:type special_args: dict
|
||||
"""
|
||||
results = (
|
||||
self.session.
|
||||
query(self.entities[entity_type]).
|
||||
filter_by(**kwargs)
|
||||
)
|
||||
|
||||
if "ORDER_BY" in special_args:
|
||||
column = self.str_to_column(special_args["ORDER_BY"])
|
||||
@@ -314,7 +276,10 @@ class baza():
|
||||
if "LIMIT" in special_args:
|
||||
results = results.limit(special_args["LIMIT"])
|
||||
|
||||
return results
|
||||
results_objs = results.all()
|
||||
print(f"[{round(time.time())}] SELECT RESULTS: {results_objs}")
|
||||
|
||||
return results_objs
|
||||
|
||||
@exit_gracefully
|
||||
def simple_insert_one(self, entity_type, **kwargs):
|
||||
@@ -523,41 +488,36 @@ class baza():
|
||||
nazwa_turnieju="Nieznany turniej",
|
||||
skrocona_nazwa_turnieju="N/A",
|
||||
flaga=0)
|
||||
|
||||
|
||||
#Robercik
|
||||
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,
|
||||
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=2,
|
||||
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
|
||||
)
|
||||
wygranych_sum=0,
|
||||
przegranych_sum=0,
|
||||
remisow_sum=0,
|
||||
wynik_sum=0,
|
||||
meczow_do_wynikow_sum=0)
|
||||
|
||||
sportowiec = sportowcy(
|
||||
zewnetrzne_id_zawodnika="MVC8zHZD",
|
||||
imie="Robert",
|
||||
nazwisko="Lewandowski",
|
||||
data_urodzenia="21.08.1988",
|
||||
czy_aktywny=True,
|
||||
klub_id="Barcelona",
|
||||
klub_id="undefined",
|
||||
narodowosc="PL",
|
||||
ilosc_trofeow=0, # Brak danych na Flashscore
|
||||
ilosc_trofeow=0,
|
||||
pierwszy_mecz_id=1,
|
||||
ostatni_gol_dla_id="undefined",
|
||||
statystyki_id=1,
|
||||
wycena=67_000_000 # Wartość rynkowa: €15.3 mln
|
||||
)
|
||||
|
||||
wycena=64_940_000)
|
||||
trofeum = trofea(
|
||||
nazwa="Nieznane trofeum",
|
||||
sezon="0000-0000",
|
||||
@@ -605,462 +565,6 @@ class baza():
|
||||
# statystyki_id=2, # itd...
|
||||
# wycena=...) # w złotówkach
|
||||
|
||||
#Ronaldo
|
||||
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
|
||||
)
|
||||
sportowiec = sportowcy(
|
||||
zewnetrzne_id_zawodnika="WGOY4FSt",
|
||||
imie="Cristiano",
|
||||
nazwisko="Ronaldo",
|
||||
data_urodzenia="05.02.1985",
|
||||
czy_aktywny=True,
|
||||
klub_id="Al Nassr Riyadh",
|
||||
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(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
|
||||
)
|
||||
sportowiec = 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(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
|
||||
)
|
||||
sportowiec = 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
|
||||
)
|
||||
sportowiec = 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
|
||||
)
|
||||
sportowiec = 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(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
|
||||
)
|
||||
sportowiec = 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(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
|
||||
)
|
||||
|
||||
sportowiec = 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
|
||||
)
|
||||
|
||||
sportowiec = sportowcy(
|
||||
zewnetrzne_id_zawodnika="vw8ZV7HC",
|
||||
imie="Sergio",
|
||||
nazwisko="Agüero",
|
||||
data_urodzenia="02.06.1988",
|
||||
czy_aktywny=False,
|
||||
klub_id="retired",
|
||||
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(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
|
||||
)
|
||||
|
||||
sportowiec = 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(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
|
||||
)
|
||||
sportowiec = 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
|
||||
)
|
||||
sportowiec = 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
|
||||
)
|
||||
sportowiec = 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(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
|
||||
)
|
||||
sportowiec = sportowcy(
|
||||
zewnetrzne_id_zawodnika="v5HSlEAa",
|
||||
imie="Harry",
|
||||
nazwisko="Kane",
|
||||
data_urodzenia="28.07.1993",
|
||||
czy_aktywny=True,
|
||||
klub_id="Bayern Monachium",
|
||||
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(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
|
||||
)
|
||||
sportowiec = 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
|
||||
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
from git import Repo # hash ostatniego commitu
|
||||
#from git import Repo # hash ostatniego commitu
|
||||
import os
|
||||
import time
|
||||
import toml
|
||||
|
||||
BIN
FlaskWebProject/instance/lewangoalski.sqlite
Normal file
BIN
FlaskWebProject/instance/lewangoalski.sqlite
Normal file
Binary file not shown.
Reference in New Issue
Block a user