live premier league

This commit is contained in:
Justin 2023-01-09 17:34:12 +08:00 committed by GitHub
parent dcf8485a2d
commit 497f0945bc
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

193
live_pl.py Normal file
View File

@ -0,0 +1,193 @@
from datetime import datetime, timedelta
from time import sleep
import pytz
import json
import requests
import sys
def sortevents(leaguedata, league):
games = []
haslive = False
for event in leaguedata['events']:
event_desc = event['status']['type']['shortDetail'] # use this to display time and quarter on ticker
event_date = event['date'].split('T')[0]
event_liveOrNot = event['status']['type']['state'] # use this to determine if game has ended or not
if event_liveOrNot == 'in':
haslive = True
has_live = 'has_live'
no_upcoming = 'no_upcoming'
for home_away in event['competitions']:
for home_away2 in home_away['competitors']:
if home_away2['homeAway'] == 'away':
if home_away2['team']['displayName'] == 'Washington Commanders':
away_team = 'Washington'
else:
away_team = home_away2['team']['displayName']
away_score = home_away2['score']
else:
if home_away2['team']['displayName'] == 'Washington Commanders':
home_team = 'Washington'
else:
home_team = home_away2['team']['displayName']
home_score = home_away2['score']
if datetime.now(pytz.utc).strftime("%Y-%m-%d") == event['date'].split('T')[0] or event['date'].split('T')[0] <= (datetime.strptime(datetime.now(pytz.utc).strftime("%Y-%m-%dT%H:%MZ"), "%Y-%m-%dT%H:%MZ") + timedelta(days=1)).strftime("%Y-%m-%dT%H:%MZ").split('T')[0]:
games.append({
'home_team': home_team,
'home_score': home_score,
'away_team': away_team,
'away_score': away_score,
'time': event_desc,
'date': event_date,
'isLive': event_liveOrNot
})
return games, haslive, has_live, no_upcoming
f = open('csv/live_pl.json', 'r')
all_settings = json.load(f)
f.close()
pl_url = "https://site.api.espn.com/apis/site/v2/sports/soccer/eng.1/scoreboard"
time_now = datetime.now(pytz.utc)
time_now2 = time_now.strftime("%Y-%m-%dT%H:%MZ")
pl_live_now = False
pl_games_today = False
pl_events = []
pl_fifteenmin = False
games_happened = False
try:
pl_response = requests.get(pl_url)
pl_data = pl_response.json()
except:
sleep(120)
pl_response = requests.get(pl_url)
pl_data = pl_response.json()
for event in pl_data['events']:
if event['status']['type']['state'] == 'in':
pl_live_now = True
if time_now2.split('T')[0] <= event['date'].split('T')[0] and event['date'].split('T')[0] <= (datetime.strptime(time_now2, "%Y-%m-%dT%H:%MZ") + timedelta(days=1)).strftime("%Y-%m-%dT%H:%MZ").split('T')[0]:
pl_events.append(event['date'])
pl_games_today = True
if pl_live_now is False and ((datetime.strptime(event['date'], "%Y-%m-%dT%H:%MZ") + timedelta(minutes=20)).strftime("%Y-%m-%dT%H:%MZ") >= datetime.now(pytz.utc).strftime("%Y-%m-%dT%H:%MZ")) and (event['date'] <= datetime.now(pytz.utc).strftime("%Y-%m-%dT%H:%MZ")):
pl_fifteenmin = True
while True:
f = open('csv/live_pl.json', 'r')
all_settings = json.load(f)
f.close()
if pl_live_now:
try:
pl_response = requests.get(pl_url)
pl_data = pl_response.json()
pl_sorted = sortevents(pl_data, 'PREMIERLEAGUE')
all_settings['leagues']['PREMIERLEAGUE'] = pl_sorted
games_happened = True
if pl_sorted[1]:
pl_live_now = True
else:
pl_live_now = False
f = open('csv/live_pl.json', 'w+')
json.dump(all_settings, f)
f.close()
sleep(120)
except:
sleep(120)
elif pl_fifteenmin:
for _ in range (10):
try:
pl_response = requests.get(pl_url)
pl_data = pl_response.json()
pl_sorted = sortevents(pl_data, 'PREMIERLEAGUE')
all_settings['leagues']['PREMIERLEAGUE'] = pl_sorted
f = open('csv/live_pl.json', 'w+')
json.dump(all_settings, f)
f.close()
sleep(120)
except:
sleep(120)
if pl_sorted[1]:
pl_live_now = True
pl_fifteenmin = False
games_happened = True
else:
pl_live_now = False
pl_fifteenmin = False
else:
pl_events2 = []
try:
for event in pl_events:
if event >= datetime.now(pytz.utc).strftime("%Y-%m-%dT%H:%MZ"):
pl_events2.append(event)
pl_games_today = True
next_pl = min(pl_events2)
d = datetime.strptime(next_pl, "%Y-%m-%dT%H:%MZ")
pl_time_left = (d - (datetime.strptime(datetime.now(pytz.utc).strftime("%Y-%m-%dT%H:%MZ"), "%Y-%m-%dT%H:%MZ"))).total_seconds()
all_settings['leagues']['PREMIERLEAGUE'][3] = next_pl
f = open('csv/live_pl.json', 'w+')
json.dump(all_settings, f)
f.close()
except:
pl_games_today = False
next_pl = []
all_settings['leagues']['PREMIERLEAGUE'][3] = 'no_upcoming'
f = open('csv/live_pl.json', 'w+')
json.dump(all_settings, f)
f.close()
pass
if pl_games_today:
sleep(pl_time_left)
pl_fifteenmin = True
if pl_live_now is False and pl_games_today is False and games_happened is True:
sleep(7200)
all_settings['leagues']['PREMIERLEAGUE'][2] = 'no_live'
all_settings['leagues']['PREMIERLEAGUE'][3] = 'no_upcoming'
f = open('csv/live_pl.json', 'w+')
json.dump(all_settings, f)
f.close()
break
if pl_live_now is False and pl_games_today is False and games_happened is False:
all_settings['leagues']['PREMIERLEAGUE'][2] = 'no_live'
all_settings['leagues']['PREMIERLEAGUE'][3] = 'no_upcoming'
f = open('csv/live_pl.json', 'w+')
json.dump(all_settings, f)
f.close()
break