api call limits and transitions

This commit is contained in:
Neythen 2021-06-27 12:07:47 +01:00
parent 2bee635511
commit 54edfb0d1b
26 changed files with 278 additions and 241 deletions

View File

@ -96,8 +96,13 @@ def updateUpdate(NY_time):
f.write(NY_str + '\n') f.write(NY_str + '\n')
f.close() f.close()
def updateStockPrices(symbols): def updateStockPrices():
finnhubsandboxAPIkey = "sandbox_c24qddqad3ickpckgg8g" #Finnhub
finnhubAPIkey = "c24qddqad3ickpckgg80" #Finnhub
finnhubClient = finnhub.Client(api_key=finnhubAPIkey)
symbols, stock_info = readCSV('csv/tickers.csv', max_stocks)
try: try:
quotes = [finnhubClient.quote(symbol) for symbol in symbols] quotes = [finnhubClient.quote(symbol) for symbol in symbols]
current_prices = [quote['c'] for quote in quotes] current_prices = [quote['c'] for quote in quotes]
@ -120,7 +125,11 @@ def updateStockPrices(symbols):
apiCalledError = True apiCalledError = True
def updateStockPricesIEX(symbols): def updateStockPricesIEX():
iexAPIkey = 'pk_68ef6a15902c41f887f0b544a0ca17cf' #IEX
iexSandboxAPIkey = 'Tpk_0078dff413ef4f979137f7111452dc4b'
max_stocks = 200
symbols, stock_info = readCSV('csv/tickers.csv', max_stocks)
try: try:
symbols_str = ','.join(symbols) symbols_str = ','.join(symbols)
method = 'GET' method = 'GET'
@ -179,7 +188,10 @@ def updateStockPricesIEX(symbols):
print(e) print(e)
def updateCrypto(coins, coin_info, unique_bases): def updateCrypto():
coingecko_client = CoinGeckoAPI()
coins, coin_info, unique_bases = readCryptoCSV('csv/crypto.csv', max_crypto)
try: try:
response = coingecko_client.get_price(ids=','.join(coins), vs_currencies = unique_bases, include_24hr_change=True) response = coingecko_client.get_price(ids=','.join(coins), vs_currencies = unique_bases, include_24hr_change=True)
@ -225,7 +237,9 @@ def updateNews():
except Exception as e: except Exception as e:
print(e) print(e)
def updateWeather(api_key): def updateWeather():
api_key = 'bd5d5096a5ba30bbcfb57ead42ab3fee'
try: try:
f = open( "csv/weather_location.txt", 'r' ) f = open( "csv/weather_location.txt", 'r' )
location = f.read() location = f.read()
@ -277,8 +291,8 @@ def updateWeather(api_key):
print(e) print(e)
def updateCurrencies(api_key): def updateForex():
api_key = '862dbb6d1101ce0c5136'
try: try:
base = 'USD' base = 'USD'
yesterday = datetime.now() - timedelta(1) yesterday = datetime.now() - timedelta(1)
@ -401,105 +415,96 @@ def updateLeagueEvents(api_key, league_id, time):
json.dump(events, open( "csv/sports/{}/{}_games.json".format(league, time), 'w+' )) json.dump(events, open( "csv/sports/{}/{}_games.json".format(league, time), 'w+' ))
def updateSports():
#read user settings to decide which sprots to update
api_key = '97436974'
def updateSports(api_key):
prem_id = '4328' #prem prem_id = '4328' #prem
NHL_id = '4380' NHL_id = '4380'
NBA_id = '4387' #prem NBA_id = '4387' #prem
NFL_id = '4391' NFL_id = '4391'
for i in [NHL_id, NBA_id, NFL_id]: for i in [NHL_id]:
updateLeagueEvents(api_key, i, 'live') updateLeagueEvents(api_key, i, 'live')
updateLeagueEvents(api_key, i, 'past') updateLeagueEvents(api_key, i, 'past')
updateLeagueEvents(api_key, i, 'future') updateLeagueEvents(api_key, i, 'future')
updateLeagueTable(api_key, NHL_id)
updateLeagueTable(api_key, prem_id) updateLeagueTable(api_key, prem_id)
'https://www.thesportsdb.com/api/v1/json/{}/eventsnext.php?id=133602'.format(api_key) # next five events by team ID (paid) use this for upcoming team games 'https://www.thesportsdb.com/api/v1/json/{}/eventsnext.php?id=133602'.format(api_key) # next five events by team ID (paid) use this for upcoming team games
#url = 'https://www.thesportsdb.com/api/v1/json/{}/eventsseason.php?id=4328&s=2020-2021'.format(api_key) # all past events in premier league #url = 'https://www.thesportsdb.com/api/v1/json/{}/eventsseason.php?id=4328&s=2020-2021'.format(api_key) # all past events in premier league
url = 'https://www.thesportsdb.com/api/v2/json/{}/livescore.php?l=4380'.format(api_key) #live scores url = 'https://www.thesportsdb.com/api/v2/json/{}/livescore.php?l=4380'.format(api_key) #live scores
def checkStocks(last_update, update_frequency):
NY_time = datetime.now(NY_zone).replace(tzinfo=None)
opening = NY_time.replace(hour=9, minute=30, second=0, microsecond=0).replace(tzinfo=None)
closing = NY_time.replace(hour=16, minute=0, second=0, microsecond=0).replace(tzinfo=None)
symbols, stock_info = readCSV('csv/tickers.csv', max_stocks)
updated = False
diff = (NY_time - last_update).total_seconds()/60 #minutes
if opening < NY_time < closing and datetime.today().weekday() < 5: # we need to do real time updating
if diff >= update_frequency:
updated = True
updateStockPrices()
elif emptyInfo(symbols, stock_info): # if theres any empty stocks
updated = True
updateStockPrices()
else:
# update if last update was before the previous days closing
yday_closing = closing - dt.timedelta(days=1)
yday_str = yday_closing.strftime("%d/%m/%Y %H:%M:%S")
yday_closing = datetime.strptime(yday_str, "%d/%m/%Y %H:%M:%S")
if last_update < yday_closing:
updated = True
updateStockPrices(symbols)
return updated
if __name__ == '__main__': if __name__ == '__main__':
newsapi = NewsApiClient(api_key='cf08652bd17647b89aaf469a1a8198a9')
finnhubAPIkey = "c24qddqad3ickpckgg80" #Finnhub
finnhubsandboxAPIkey = "sandbox_c24qddqad3ickpckgg8g" #Finnhub
stock_time = 2 #minutes
crypto_time = 10 #minutes
news_time = 30 #minutes
weather_time = 10 #minutes
# TODO: different update times for stocks, weather and news
finnhubClient = finnhub.Client(api_key=finnhubAPIkey)
max_stocks = 200 max_stocks = 200
max_crypto = 100 max_crypto = 100
iexAPIkey = 'pk_68ef6a15902c41f887f0b544a0ca17cf' #IEX newsapi = NewsApiClient(api_key='cf08652bd17647b89aaf469a1a8198a9')
iexSandboxAPIkey = 'Tpk_0078dff413ef4f979137f7111452dc4b'
#updateStockPricesIEX(symbols) update_frequencies = {'stocks':2, 'crypto':10, 'news':60, 'weather': 10} #minutes
finnhubClient = finnhub.Client(api_key=finnhubAPIkey)
coingecko_client = CoinGeckoAPI()
NY_zone = pytz.timezone('America/New_York') NY_zone = pytz.timezone('America/New_York')
CET_zone = pytz.timezone('Europe/Berlin')
NY_time = datetime.now(NY_zone)
opening = NY_time.replace(hour=9, minute=30, second=0, microsecond=0)
closing = NY_time.replace(hour=16, minute=0, second=0, microsecond=0)
NY_time = datetime.now(NY_zone) NY_time = datetime.now(NY_zone)
symbols, stock_info = readCSV('csv/tickers.csv', max_stocks) CET_time = datetime.now(CET_zone)
updateStockPrices(symbols)
updateUpdate(NY_time)
coins, coin_info, unique_bases = readCryptoCSV('csv/crypto.csv', max_crypto)
weather_key = 'bd5d5096a5ba30bbcfb57ead42ab3fee' NY_str = NY_time.strftime("%d/%m/%Y %H:%M:%S")
CET_str = NY_time.strftime("%d/%m/%Y %H:%M:%S")
currency_key = '862dbb6d1101ce0c5136' #f = open('csv/last_updates.json', 'w+')
sports_key = '97436974' #update_times = {'stocks':NY_str, 'crypto':NY_str, 'news':NY_str, 'weather': NY_str, 'forex': CET_str} # all in NY time apart from forex in CET
#json.dump(update_times, f)
#f.close()
updateSports(sports_key) f = open('csv/last_updates.json', 'r')
last_updates = json.load(f)
f.close()
updateCurrencies(currency_key)
updateWeather( weather_key)
updateCrypto(coins, coin_info, unique_bases)
updateNews()
t = time.time() t = time.time()
@ -508,55 +513,66 @@ if __name__ == '__main__':
try: try:
while True: while True:
NY_time = datetime.now(NY_zone).replace(tzinfo=None)
msg = getInput() msg = getInput()
if msg == 'R' or time.time() - t > stock_time*60:
#stocks
stock_time = datetime.strptime(last_updates['stocks'], "%d/%m/%Y %H:%M:%S")
stock_frequency = update_frequencies['stocks']
if checkStocks(stock_time, stock_frequency):
stock_time = NY_time.strftime("%d/%m/%Y %H:%M:%S")
last_updates['stocks'] = stock_time
# crypto
crypto_time = datetime.strptime(last_updates['crypto'], "%d/%m/%Y %H:%M:%S")
crypto_frequency = update_frequencies['crypto']
NY_time = datetime.now(NY_zone).replace(tzinfo=None)
diff = (NY_time - crypto_time).total_seconds()/60 #minutes
if diff >= update_frequencies['crypto']:
crypto_time = NY_time.strftime("%d/%m/%Y %H:%M:%S")
updateCrypto()
last_updates['crypto'] = crypto_time
# weather
weather_time = datetime.strptime(last_updates['weather'], "%d/%m/%Y %H:%M:%S")
weather_frequency = update_frequencies['weather']
NY_time = datetime.now(NY_zone).replace(tzinfo=None)
diff = (NY_time - weather_time).total_seconds()/60 #minutes
if diff >= update_frequencies['weather']:
weather_time = NY_time.strftime("%d/%m/%Y %H:%M:%S")
updateWeather()
last_updates['weather'] = weather_time
coins, coin_info, unique_bases = readCryptoCSV('csv/crypto.csv', max_stocks) # weather
news_time = datetime.strptime(last_updates['news'], "%d/%m/%Y %H:%M:%S")
news_frequency = update_frequencies['news']
updateCrypto(coins, coin_info, unique_bases) NY_time = datetime.now(NY_zone).replace(tzinfo=None)
updateCurrencies(currency_key) diff = (NY_time - weather_time).total_seconds()/60 #minutes
if diff >= update_frequencies['news']:
news_time = NY_time.strftime("%d/%m/%Y %H:%M:%S")
updateNews() updateNews()
updateWeather(weather_location, weather_key) last_updates['news'] = news_time
updateSports(sports_key)
NY_time = datetime.now(NY_zone) #forex updates once every 24hours at 1700 CET
symbols, stock_info = readCSV('csv/tickers.csv', max_stocks)
if opening < NY_time < closing and datetime.today().weekday() < 5: # we need to do real time updating
print('market open')
updateStockPrices(symbols) # update if last update was before the previous days closing
updateUpdate(NY_time) forex_time = datetime.strptime(last_updates['forex'], "%d/%m/%Y %H:%M:%S")
CET_time = datetime.now(CET_zone)
yday_update = (CET_time.replace(hour=17, minute=00, second=0, microsecond=0) - dt.timedelta(days=1)).replace(tzinfo=None)
elif emptyInfo(symbols, stock_info): # if theres any empty stocks if forex_time < yday_update:
forex_time = CET_time.strftime("%d/%m/%Y %H:%M:%S")
last_updates['forex'] = forex_time
updateForex()
updateStockPrices(symbols)
updateUpdate(NY_time)
else:
# update if last update was before the previous days closing
f = open('csv/last_update.csv', 'r')
CSV = csv.reader(f)
last_update_str = next(CSV)[0]
last_update = datetime.strptime(last_update_str, "%d/%m/%Y %H:%M:%S")
yday_closing = closing - dt.timedelta(days=1)
yday_str = yday_closing.strftime("%d/%m/%Y %H:%M:%S")
yday_closing = datetime.strptime(yday_str, "%d/%m/%Y %H:%M:%S")
if last_update < yday_closing:
updateStockPrices(symbols)
updateUpdate(NY_time)
t = time.time()
except Exception as e: except Exception as e:
logf.write(srt(e)) logf.write(str(e))
print(e)

View File

@ -1,3 +1,3 @@
symbol,name,base,current,24hr change symbol,name,base,current,24hr change
BTC,bitcoin,usd,32955,0.18795236810340699 BTC,bitcoin,usd,32675,3.7239980392362217
ETH,ethereum,gbp,1388.1,-1.2416916112022245 ETH,ethereum,gbp,1317.79,1.854985374746106

1 symbol name base current 24hr change
2 BTC bitcoin usd 32955 32675 0.18795236810340699 3.7239980392362217
3 ETH ethereum gbp 1388.1 1317.79 -1.2416916112022245 1.854985374746106

View File

@ -1 +1 @@
{"main_weather": "Clouds", "description": "overcast clouds", "temp": 26.64, "min_temp": 25.58, "max_temp": 27.4, "feels_like": 26.64, "humidity": 90, "clouds": 100, "wind_speed": 0.45, "wind_direction": 135, "visibility": 10000, "uv": 0, "rain_chance": 1} {"main_weather": "Rain", "description": "heavy intensity rain", "temp": 29.82, "min_temp": 28.3, "max_temp": 31.03, "feels_like": 36.82, "humidity": 86, "clouds": 100, "wind_speed": 0.45, "wind_direction": 16, "visibility": 10000, "uv": 0.45, "rain_chance": 0.39}

View File

@ -1 +1 @@
[{"main_weather": "Rain", "description": "heavy intensity rain", "min_temp": 24.83, "max_temp": 27.8}, {"main_weather": "Rain", "description": "moderate rain", "min_temp": 25.07, "max_temp": 26.83}, {"main_weather": "Rain", "description": "moderate rain", "min_temp": 26.55, "max_temp": 29}, {"main_weather": "Rain", "description": "light rain", "min_temp": 27.75, "max_temp": 29.78}, {"main_weather": "Rain", "description": "moderate rain", "min_temp": 27.93, "max_temp": 29.4}, {"main_weather": "Rain", "description": "moderate rain", "min_temp": 26.61, "max_temp": 28.14}, {"main_weather": "Rain", "description": "moderate rain", "min_temp": 27.57, "max_temp": 28.14}, {"main_weather": "Rain", "description": "moderate rain", "min_temp": 26.69, "max_temp": 28.13}] [{"main_weather": "Rain", "description": "heavy intensity rain", "min_temp": 28.09, "max_temp": 29.87}, {"main_weather": "Rain", "description": "moderate rain", "min_temp": 28.22, "max_temp": 28.97}, {"main_weather": "Rain", "description": "moderate rain", "min_temp": 28.19, "max_temp": 29.57}, {"main_weather": "Rain", "description": "moderate rain", "min_temp": 28.21, "max_temp": 29.37}, {"main_weather": "Rain", "description": "moderate rain", "min_temp": 28.28, "max_temp": 29.31}, {"main_weather": "Rain", "description": "moderate rain", "min_temp": 28.27, "max_temp": 29.43}, {"main_weather": "Rain", "description": "moderate rain", "min_temp": 28.03, "max_temp": 29.7}, {"main_weather": "Clouds", "description": "overcast clouds", "min_temp": 27.9, "max_temp": 29.98}]

View File

@ -1 +1 @@
22/06/2021 15:05:29 27/06/2021 06:04:41

1 22/06/2021 15:05:29 27/06/2021 06:04:41

1
csv/last_updates.json Normal file
View File

@ -0,0 +1 @@
{"stocks": "27/06/2021 07:05:39", "crypto": "27/06/2021 07:05:39", "news": "27/06/2021 07:05:39", "weather": "27/06/2021 07:05:39", "forex": "27/06/2021 07:05:39"}

1
csv/league.txt Normal file
View File

@ -0,0 +1 @@
NHL

View File

@ -1,21 +1,21 @@
headline,source,date,time headline,source,date,time
I am not a vector: Oireachtas committee hears from children affected by the pandemic - TheJournal.ie,TheJournal.ie,2021-06-22,18:30:00Z China's Zhurong rover returns landing footage and sounds from Mars - SpaceNews,SpaceNews,2021-06-27,08:42:29Z
Liability conceded in case of couple wrongly advised to terminate pregnancy - The Irish Times,The Irish Times,2021-06-22,18:15:58Z Jammu Airport Blasts LIVE Updates: NIA Likely to Probe Case^ Flight Ops Normal; IAF Stations in Punjab & Srinagar on High Alert - News18,News18,2021-06-27,08:41:51Z
Delta COVID-19 variant greatest threat to US pandemic response - Fauci - GMA News Online,GMA News,2021-06-22,18:10:22Z Lacson bares what he expects to hear from Duterte's final SONA - GMA News Online,GMA News,2021-06-27,08:37:03Z
LIVE WTC Final IND vs NZ Live Cricket Score^ Today Match DAY 5 Updates: Kohli-Pujara in; India Lead New Zeala - India.com,India.com,2021-06-22,18:08:55Z A-League grand final LIVE updates: Red-hot City lead 2-1 over 10-man Sydney FC - The Sydney Morning Herald,The Sydney Morning Herald,2021-06-27,08:30:20Z
Prime Day headphone deals you shouldn't miss on AirPods^ Bose^ Beats^ Sony^ Samsung and more - CNET,CNET,2021-06-22,18:03:00Z Why most people who now die with Covid in England have been vaccinated - The Guardian,The Guardian,2021-06-27,08:22:00Z
Jack Grealish^ Bukayo Saka and Harry Maguire start for England against Czech Republic - Sky Sports,Sky Sports,2021-06-22,18:01:14Z Some families frustrated by pace of search and rescue efforts in Florida building collapse - CNN ,CNN,2021-06-27,08:11:00Z
Mother's gestational diabetes is an independent risk factor for fetal hypoxia during labor - News-Medical.Net,News-Medical.Net,2021-06-22,18:01:00Z PHs COVID-19 cases nears 1.4 million-mark with 6^096 new infections - INQUIRER.net,Inquirer.net,2021-06-27,08:04:00Z
Amazon sees Prime Day sales boost amid supply chain snags - CNA,CNA,2021-06-22,18:00:37Z How to use Alexa Whisper Mode on an Amazon Echo - TechRadar,TechRadar,2021-06-27,08:00:00Z
Twitter opens applications for Ticketed Spaces and Super Follows test - The Verge,The Verge,2021-06-22,18:00:00Z Low vitamin D can raise death risk from Covid by 20% - ETHealthworld.com,The Times of India,2021-06-27,07:58:20Z
Mastercard Foundation Appoints Robin Washington to Board of Directors - Guardian,Guardian Nigeria,2021-06-22,18:00:00Z M5.0 quake strikes near Surigao del Sur - SunStar Philippines,Sunstar.com.ph,2021-06-27,07:56:05Z
Trudeau says border restrictions will be further relaxed 'in the coming weeks' if all goes well - CBC.ca,CBC News,2021-06-22,17:58:29Z Statesmen think of the next generation^ not the next election - Rafidah blasts MCO inconsistency - Malaysiakini,Malaysiakini,2021-06-27,07:54:50Z
Euro 2020 LIVE: Grealish and Maguire start for England^ Mount and Chilwell out of Czech Republic clash^... - talkSPORT.com,TalkSport,2021-06-22,17:47:23Z Long Covid: 'I've blood clots^ a braced leg and damaged heart... but I'm home' - The Samford Crimson,Samfordcrimson.com,2021-06-27,07:54:34Z
Quarter of a million children in England missed school last week due to Covid - The Guardian,The Guardian,2021-06-22,17:46:00Z Guns of the west: Hot Dogs dominate Eagles in Perth - AFL,Afl.com.au,2021-06-27,07:53:00Z
'I am appalled': Billie Eilish apologizes for mouthing racial slur in resurfaced video - CBC.ca,CBC News,2021-06-22,17:45:46Z China releases videos of rover on Mars - Yahoo News,Yahoo Entertainment,2021-06-27,07:53:00Z
U.S. to narrowly miss Bidens July 4 vaccination goal^ White House says - The Washington Post,The Washington Post,2021-06-22,17:45:00Z Five dead^ 156 still missing in Florida building collapse as searchers race against time - News24,News24,2021-06-27,07:44:27Z
Vin Diesel explains feud with Dwayne Johnson: 'A lot of tough love' - Fox News,Fox News,2021-06-22,17:41:14Z Singapore detects 14 new COVID-19 cases; 12 in community - Yahoo Singapore News,Yahoo Entertainment,2021-06-27,07:44:23Z
Todays coronavirus news: Two-thirds of Canadians say governments shouldnt lift all restrictions; Construction complete on new vaccine-manufacturing plant in Montreal; Ontario reporting 296 cases - Toronto Star,Toronto Star,2021-06-22,17:37:30Z Indonesia commends JTF Tawi-Tawi for rescue of 4 kidnap victims - GMA News Online,GMA News,2021-06-27,07:41:53Z
Tembisa 10: Piet Rampedi pens apology to Independent Media staff for baby saga - News24,News24,2021-06-22,17:33:26Z Don't copy Bollywood: Imran Khan's advice to Pakistani filmmakers - Hindustan Times,Hindustan Times,2021-06-27,07:41:00Z
Stinging secret: research reveals how venom from Australian caterpillars could be used in medicines - The Guardian,The Guardian,2021-06-22,17:31:00Z Rugby league: New Zealand Warriors to lose Euan Aitken and Josh Curran for two weeks after Covid-19 scare - New Zealand Herald,New Zealand Herald,2021-06-27,07:39:23Z
Doc Rivers not giving up on Ben Simmons^ says 76ers have a plan in place to improve his shooting struggles - CBS Sports,CBS Sports,2021-06-22,17:28:00Z Watch the incredible moment Massey High School player sinks wild three-point buzzer-beater - Stuff.co.nz,Stuff.co.nz,2021-06-27,07:39:00Z

1 headline source date time
2 ‘I am not a vector’: Oireachtas committee hears from children affected by the pandemic - TheJournal.ie China's Zhurong rover returns landing footage and sounds from Mars - SpaceNews TheJournal.ie SpaceNews 2021-06-22 2021-06-27 18:30:00Z 08:42:29Z
3 Liability conceded in case of couple ‘wrongly advised’ to terminate pregnancy - The Irish Times Jammu Airport Blasts LIVE Updates: NIA Likely to Probe Case^ Flight Ops Normal; IAF Stations in Punjab & Srinagar on High Alert - News18 The Irish Times News18 2021-06-22 2021-06-27 18:15:58Z 08:41:51Z
4 Delta COVID-19 variant greatest threat to US pandemic response - Fauci - GMA News Online Lacson bares what he expects to hear from Duterte's final SONA - GMA News Online GMA News 2021-06-22 2021-06-27 18:10:22Z 08:37:03Z
5 LIVE WTC Final IND vs NZ Live Cricket Score^ Today Match DAY 5 Updates: Kohli-Pujara in; India Lead New Zeala - India.com A-League grand final LIVE updates: Red-hot City lead 2-1 over 10-man Sydney FC - The Sydney Morning Herald India.com The Sydney Morning Herald 2021-06-22 2021-06-27 18:08:55Z 08:30:20Z
6 Prime Day headphone deals you shouldn't miss on AirPods^ Bose^ Beats^ Sony^ Samsung and more - CNET Why most people who now die with Covid in England have been vaccinated - The Guardian CNET The Guardian 2021-06-22 2021-06-27 18:03:00Z 08:22:00Z
7 Jack Grealish^ Bukayo Saka and Harry Maguire start for England against Czech Republic - Sky Sports Some families frustrated by pace of search and rescue efforts in Florida building collapse - CNN Sky Sports CNN 2021-06-22 2021-06-27 18:01:14Z 08:11:00Z
8 Mother's gestational diabetes is an independent risk factor for fetal hypoxia during labor - News-Medical.Net PH’s COVID-19 cases nears 1.4 million-mark with 6^096 new infections - INQUIRER.net News-Medical.Net Inquirer.net 2021-06-22 2021-06-27 18:01:00Z 08:04:00Z
9 Amazon sees Prime Day sales boost amid supply chain snags - CNA How to use Alexa Whisper Mode on an Amazon Echo - TechRadar CNA TechRadar 2021-06-22 2021-06-27 18:00:37Z 08:00:00Z
10 Twitter opens applications for Ticketed Spaces and Super Follows test - The Verge Low vitamin D can raise death risk from Covid by 20% - ETHealthworld.com The Verge The Times of India 2021-06-22 2021-06-27 18:00:00Z 07:58:20Z
11 Mastercard Foundation Appoints Robin Washington to Board of Directors - Guardian M5.0 quake strikes near Surigao del Sur - SunStar Philippines Guardian Nigeria Sunstar.com.ph 2021-06-22 2021-06-27 18:00:00Z 07:56:05Z
12 Trudeau says border restrictions will be further relaxed 'in the coming weeks' if all goes well - CBC.ca Statesmen think of the next generation^ not the next election - Rafidah blasts MCO inconsistency - Malaysiakini CBC News Malaysiakini 2021-06-22 2021-06-27 17:58:29Z 07:54:50Z
13 Euro 2020 LIVE: Grealish and Maguire start for England^ Mount and Chilwell out of Czech Republic clash^... - talkSPORT.com Long Covid: 'I've blood clots^ a braced leg and damaged heart... but I'm home' - The Samford Crimson TalkSport Samfordcrimson.com 2021-06-22 2021-06-27 17:47:23Z 07:54:34Z
14 Quarter of a million children in England missed school last week due to Covid - The Guardian Guns of the west: Hot Dogs dominate Eagles in Perth - AFL The Guardian Afl.com.au 2021-06-22 2021-06-27 17:46:00Z 07:53:00Z
15 'I am appalled': Billie Eilish apologizes for mouthing racial slur in resurfaced video - CBC.ca China releases videos of rover on Mars - Yahoo News CBC News Yahoo Entertainment 2021-06-22 2021-06-27 17:45:46Z 07:53:00Z
16 U.S. to narrowly miss Biden’s July 4 vaccination goal^ White House says - The Washington Post Five dead^ 156 still missing in Florida building collapse as searchers race against time - News24 The Washington Post News24 2021-06-22 2021-06-27 17:45:00Z 07:44:27Z
17 Vin Diesel explains feud with Dwayne Johnson: 'A lot of tough love' - Fox News Singapore detects 14 new COVID-19 cases; 12 in community - Yahoo Singapore News Fox News Yahoo Entertainment 2021-06-22 2021-06-27 17:41:14Z 07:44:23Z
18 Today’s coronavirus news: Two-thirds of Canadians say governments shouldn’t lift all restrictions; Construction complete on new vaccine-manufacturing plant in Montreal; Ontario reporting 296 cases - Toronto Star Indonesia commends JTF Tawi-Tawi for rescue of 4 kidnap victims - GMA News Online Toronto Star GMA News 2021-06-22 2021-06-27 17:37:30Z 07:41:53Z
19 ‘Tembisa 10’: Piet Rampedi pens apology to Independent Media staff for baby saga - News24 Don't copy Bollywood: Imran Khan's advice to Pakistani filmmakers - Hindustan Times News24 Hindustan Times 2021-06-22 2021-06-27 17:33:26Z 07:41:00Z
20 Stinging secret: research reveals how venom from Australian caterpillars could be used in medicines - The Guardian Rugby league: New Zealand Warriors to lose Euan Aitken and Josh Curran for two weeks after Covid-19 scare - New Zealand Herald The Guardian New Zealand Herald 2021-06-22 2021-06-27 17:31:00Z 07:39:23Z
21 Doc Rivers not giving up on Ben Simmons^ says 76ers have a plan in place to improve his shooting struggles - CBS Sports Watch the incredible moment Massey High School player sinks wild three-point buzzer-beater - Stuff.co.nz CBS Sports Stuff.co.nz 2021-06-22 2021-06-27 17:28:00Z 07:39:00Z

View File

@ -1 +1 @@
[{"date": "2021-06-23", "time": "01:00:00", "round": "0", "home_team": "Phoenix Suns", "home_score": null, "away_team": "Los Angeles Clippers", "away_score": null}, {"date": "2021-06-24", "time": "00:30:00", "round": "0", "home_team": "Milwaukee Bucks", "home_score": null, "away_team": "Atlanta Hawks", "away_score": null}, {"date": "2021-06-25", "time": "01:00:00", "round": "0", "home_team": "Los Angeles Clippers", "home_score": null, "away_team": "Phoenix Suns", "away_score": null}, {"date": "2021-06-26", "time": "00:30:00", "round": "0", "home_team": "Milwaukee Bucks", "home_score": null, "away_team": "Atlanta Hawks", "away_score": null}, {"date": "2021-06-27", "time": "01:00:00", "round": "0", "home_team": "Los Angeles Clippers", "home_score": null, "away_team": "Phoenix Suns", "away_score": null}, {"date": "2021-06-28", "time": "00:30:00", "round": "0", "home_team": "Atlanta Hawks", "home_score": null, "away_team": "Milwaukee Bucks", "away_score": null}, {"date": "2021-06-30", "time": "00:30:00", "round": "0", "home_team": "Atlanta Hawks", "home_score": null, "away_team": "Milwaukee Bucks", "away_score": null}] [{"date": "2021-06-27", "time": "01:00:00", "round": "0", "home_team": "Los Angeles Clippers", "home_score": "80", "away_team": "Phoenix Suns", "away_score": "84"}, {"date": "2021-06-28", "time": "00:30:00", "round": "0", "home_team": "Atlanta Hawks", "home_score": null, "away_team": "Milwaukee Bucks", "away_score": null}, {"date": "2021-06-29", "time": "01:00:00", "round": "0", "home_team": "Phoenix Suns", "home_score": null, "away_team": "Los Angeles Clippers", "away_score": null}, {"date": "2021-06-30", "time": "00:30:00", "round": "0", "home_team": "Atlanta Hawks", "home_score": null, "away_team": "Milwaukee Bucks", "away_score": null}]

View File

@ -1 +1 @@
[] [{"date": "2021-06-27", "time": "01:00", "progess": "", "status": "FT", "home_team": "Los Angeles Clippers", "home_score": "80", "away_team": "Phoenix Suns", "away_score": "84"}]

View File

@ -1 +1 @@
[{"date": "2021-06-21", "time": "00:00:00", "round": "0", "home_team": "Philadelphia 76ers", "home_score": "96", "away_team": "Atlanta Hawks", "away_score": "103"}, {"date": "2021-06-20", "time": "19:30:00", "round": "0", "home_team": "Phoenix Suns", "home_score": "120", "away_team": "Los Angeles Clippers", "away_score": "114"}, {"date": "2021-06-20", "time": "00:30:00", "round": "0", "home_team": "Brooklyn Nets", "home_score": "111", "away_team": "Milwaukee Bucks", "away_score": "115"}, {"date": "2021-06-19", "time": "02:00:00", "round": "0", "home_team": "Los Angeles Clippers", "home_score": "131", "away_team": "Utah Jazz", "away_score": "119"}, {"date": "2021-06-18", "time": "23:30:00", "round": "0", "home_team": "Atlanta Hawks", "home_score": "99", "away_team": "Philadelphia 76ers", "away_score": "104"}, {"date": "2021-06-18", "time": "00:30:00", "round": "0", "home_team": "Milwaukee Bucks", "home_score": "104", "away_team": "Brooklyn Nets", "away_score": "89"}, {"date": "2021-06-17", "time": "02:00:00", "round": "0", "home_team": "Utah Jazz", "home_score": "111", "away_team": "Los Angeles Clippers", "away_score": "119"}, {"date": "2021-06-16", "time": "00:30:00", "round": "0", "home_team": "Brooklyn Nets", "home_score": "114", "away_team": "Milwaukee Bucks", "away_score": "108"}, {"date": "2021-06-16", "time": "23:30:00", "round": "0", "home_team": "Philadelphia 76ers", "home_score": "106", "away_team": "Atlanta Hawks", "away_score": "109"}, {"date": "2021-06-15", "time": "02:00:00", "round": "0", "home_team": "Los Angeles Clippers", "home_score": "118", "away_team": "Utah Jazz", "away_score": "104"}, {"date": "2021-06-14", "time": "23:30:00", "round": "0", "home_team": "Atlanta Hawks", "home_score": "103", "away_team": "Philadelphia 76ers", "away_score": "100"}, {"date": "2021-06-14", "time": "00:00:00", "round": "0", "home_team": "Denver Nuggets", "home_score": "118", "away_team": "Phoenix Suns", "away_score": "125"}, {"date": "2021-06-13", "time": "00:30:00", "round": "0", "home_team": "Los Angeles Clippers", "home_score": "132", "away_team": "Utah Jazz", "away_score": "106"}, {"date": "2021-06-13", "time": "19:00:00", "round": "0", "home_team": "Milwaukee Bucks", "home_score": "107", "away_team": "Brooklyn Nets", "away_score": "96"}, {"date": "2021-06-12", "time": "02:00:00", "round": "0", "home_team": "Denver Nuggets", "home_score": "102", "away_team": "Phoenix Suns", "away_score": "116"}] [{"date": "2021-06-26", "time": "00:30:00", "round": "0", "home_team": "Milwaukee Bucks", "home_score": "125", "away_team": "Atlanta Hawks", "away_score": "91"}, {"date": "2021-06-25", "time": "01:00:00", "round": "0", "home_team": "Los Angeles Clippers", "home_score": "106", "away_team": "Phoenix Suns", "away_score": "92"}, {"date": "2021-06-24", "time": "00:30:00", "round": "0", "home_team": "Milwaukee Bucks", "home_score": "113", "away_team": "Atlanta Hawks", "away_score": "116"}, {"date": "2021-06-23", "time": "01:00:00", "round": "0", "home_team": "Phoenix Suns", "home_score": "104", "away_team": "Los Angeles Clippers", "away_score": "103"}, {"date": "2021-06-21", "time": "00:00:00", "round": "0", "home_team": "Philadelphia 76ers", "home_score": "96", "away_team": "Atlanta Hawks", "away_score": "103"}, {"date": "2021-06-20", "time": "19:30:00", "round": "0", "home_team": "Phoenix Suns", "home_score": "120", "away_team": "Los Angeles Clippers", "away_score": "114"}, {"date": "2021-06-20", "time": "00:30:00", "round": "0", "home_team": "Brooklyn Nets", "home_score": "111", "away_team": "Milwaukee Bucks", "away_score": "115"}, {"date": "2021-06-19", "time": "02:00:00", "round": "0", "home_team": "Los Angeles Clippers", "home_score": "131", "away_team": "Utah Jazz", "away_score": "119"}, {"date": "2021-06-18", "time": "23:30:00", "round": "0", "home_team": "Atlanta Hawks", "home_score": "99", "away_team": "Philadelphia 76ers", "away_score": "104"}, {"date": "2021-06-18", "time": "00:30:00", "round": "0", "home_team": "Milwaukee Bucks", "home_score": "104", "away_team": "Brooklyn Nets", "away_score": "89"}, {"date": "2021-06-17", "time": "02:00:00", "round": "0", "home_team": "Utah Jazz", "home_score": "111", "away_team": "Los Angeles Clippers", "away_score": "119"}, {"date": "2021-06-16", "time": "00:30:00", "round": "0", "home_team": "Brooklyn Nets", "home_score": "114", "away_team": "Milwaukee Bucks", "away_score": "108"}, {"date": "2021-06-16", "time": "23:30:00", "round": "0", "home_team": "Philadelphia 76ers", "home_score": "106", "away_team": "Atlanta Hawks", "away_score": "109"}, {"date": "2021-06-15", "time": "02:00:00", "round": "0", "home_team": "Los Angeles Clippers", "home_score": "118", "away_team": "Utah Jazz", "away_score": "104"}, {"date": "2021-06-14", "time": "23:30:00", "round": "0", "home_team": "Atlanta Hawks", "home_score": "103", "away_team": "Philadelphia 76ers", "away_score": "100"}]

View File

@ -1 +1 @@
[{"date": "2021-06-22", "time": "00:00:00", "round": "0", "home_team": "Tampa Bay Lightning", "home_score": "8", "away_team": "New York Islanders", "away_score": "0"}, {"date": "2021-06-23", "time": "01:00:00", "round": "0", "home_team": "Vegas Golden Knights", "home_score": null, "away_team": "Montreal Canadiens", "away_score": null}, {"date": "2021-06-24", "time": "00:00:00", "round": "0", "home_team": "New York Islanders", "home_score": null, "away_team": "Tampa Bay Lightning", "away_score": null}, {"date": "2021-06-25", "time": "00:00:00", "round": "0", "home_team": "Montreal Canadiens", "home_score": null, "away_team": "Vegas Golden Knights", "away_score": null}] []

View File

@ -1 +1 @@
[{"date": "2021-06-22", "time": "00:00", "progess": "", "status": "FT", "home_team": "Tampa Bay Lightning", "home_score": "8", "away_team": "New York Islanders", "away_score": "0"}] []

View File

@ -1 +1 @@
[{"date": "2021-06-21", "time": "00:00:00", "round": "0", "home_team": "Montreal Canadiens", "home_score": "1", "away_team": "Vegas Golden Knights", "away_score": "2"}, {"date": "2021-06-20", "time": "00:00:00", "round": "0", "home_team": "New York Islanders", "home_score": "3", "away_team": "Tampa Bay Lightning", "away_score": "2"}, {"date": "2021-06-19", "time": "00:00:00", "round": "0", "home_team": "Montreal Canadiens", "home_score": "3", "away_team": "Vegas Golden Knights", "away_score": "2"}, {"date": "2021-06-18", "time": "00:00:00", "round": "0", "home_team": "New York Islanders", "home_score": "1", "away_team": "Tampa Bay Lightning", "away_score": "2"}, {"date": "2021-06-17", "time": "01:00:00", "round": "0", "home_team": "Vegas Golden Knights", "home_score": "2", "away_team": "Montreal Canadiens", "away_score": "3"}, {"date": "2021-06-16", "time": "00:00:00", "round": "0", "home_team": "Tampa Bay Lightning", "home_score": "4", "away_team": "New York Islanders", "away_score": "2"}, {"date": "2021-06-15", "time": "01:00:00", "round": "0", "home_team": "Vegas Golden Knights", "home_score": "4", "away_team": "Montreal Canadiens", "away_score": "1"}, {"date": "2021-06-13", "time": "19:00:00", "round": "0", "home_team": "Tampa Bay Lightning", "home_score": "1", "away_team": "New York Islanders", "away_score": "2"}, {"date": "2021-06-11", "time": "01:00:00", "round": "0", "home_team": "Vegas Golden Knights", "home_score": "6", "away_team": "Colorado Avalanche", "away_score": "3"}, {"date": "2021-06-09", "time": "23:30:00", "round": "0", "home_team": "New York Islanders", "home_score": "6", "away_team": "Boston Bruins", "away_score": "2"}, {"date": "2021-06-09", "time": "01:00:00", "round": "0", "home_team": "Colorado Avalanche", "home_score": "2", "away_team": "Vegas Golden Knights", "away_score": "3"}, {"date": "2021-06-08", "time": "22:30:00", "round": "0", "home_team": "Carolina Hurricanes", "home_score": "0", "away_team": "Tampa Bay Lightning", "away_score": "2"}, {"date": "2021-06-08", "time": "00:00:00", "round": "0", "home_team": "Montreal Canadiens", "home_score": "3", "away_team": "Winnipeg Jets", "away_score": "2"}, {"date": "2021-06-07", "time": "22:30:00", "round": "0", "home_team": "Boston Bruins", "home_score": "4", "away_team": "New York Islanders", "away_score": "5"}, {"date": "2021-06-07", "time": "00:30:00", "round": "0", "home_team": "Vegas Golden Knights", "home_score": "5", "away_team": "Colorado Avalanche", "away_score": "1"}] [{"date": "2021-06-26", "time": "00:00:00", "round": "0", "home_team": "Tampa Bay Lightning", "home_score": "1", "away_team": "New York Islanders", "away_score": "0"}, {"date": "2021-06-25", "time": "00:00:00", "round": "0", "home_team": "Montreal Canadiens", "home_score": "3", "away_team": "Vegas Golden Knights", "away_score": "2"}, {"date": "2021-06-24", "time": "00:00:00", "round": "0", "home_team": "New York Islanders", "home_score": "3", "away_team": "Tampa Bay Lightning", "away_score": "2"}, {"date": "2021-06-23", "time": "01:00:00", "round": "0", "home_team": "Vegas Golden Knights", "home_score": "1", "away_team": "Montreal Canadiens", "away_score": "4"}, {"date": "2021-06-22", "time": "00:00:00", "round": "0", "home_team": "Tampa Bay Lightning", "home_score": "8", "away_team": "New York Islanders", "away_score": "0"}, {"date": "2021-06-21", "time": "00:00:00", "round": "0", "home_team": "Montreal Canadiens", "home_score": "1", "away_team": "Vegas Golden Knights", "away_score": "2"}, {"date": "2021-06-20", "time": "00:00:00", "round": "0", "home_team": "New York Islanders", "home_score": "3", "away_team": "Tampa Bay Lightning", "away_score": "2"}, {"date": "2021-06-19", "time": "00:00:00", "round": "0", "home_team": "Montreal Canadiens", "home_score": "3", "away_team": "Vegas Golden Knights", "away_score": "2"}, {"date": "2021-06-18", "time": "00:00:00", "round": "0", "home_team": "New York Islanders", "home_score": "1", "away_team": "Tampa Bay Lightning", "away_score": "2"}, {"date": "2021-06-17", "time": "01:00:00", "round": "0", "home_team": "Vegas Golden Knights", "home_score": "2", "away_team": "Montreal Canadiens", "away_score": "3"}, {"date": "2021-06-16", "time": "00:00:00", "round": "0", "home_team": "Tampa Bay Lightning", "home_score": "4", "away_team": "New York Islanders", "away_score": "2"}, {"date": "2021-06-15", "time": "01:00:00", "round": "0", "home_team": "Vegas Golden Knights", "home_score": "4", "away_team": "Montreal Canadiens", "away_score": "1"}, {"date": "2021-06-13", "time": "19:00:00", "round": "0", "home_team": "Tampa Bay Lightning", "home_score": "1", "away_team": "New York Islanders", "away_score": "2"}, {"date": "2021-06-11", "time": "01:00:00", "round": "0", "home_team": "Vegas Golden Knights", "home_score": "6", "away_team": "Colorado Avalanche", "away_score": "3"}, {"date": "2021-06-09", "time": "23:30:00", "round": "0", "home_team": "New York Islanders", "home_score": "6", "away_team": "Boston Bruins", "away_score": "2"}]

1
csv/table_league.txt Normal file
View File

@ -0,0 +1 @@
premier_league

View File

@ -1,4 +1,4 @@
name,current,opening name,current,opening
MSFT,265.24,262.72 MSFT,265.02,266.23
NFLX,511.198,498.54 NFLX,527.07,528.84
GOOG,2536.73,2529 GOOG,2539.9,2539.14

1 name current opening
2 MSFT 265.24 265.02 262.72 266.23
3 NFLX 511.198 527.07 498.54 528.84
4 GOOG 2536.73 2539.9 2529 2539.14

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

View File

@ -7,7 +7,7 @@ pip3 install pexpect
sudo apt-get install libopenjp2-7 sudo apt-get install libopenjp2-7
sudo apt-get install libtiff5 sudo apt-get install libtiff5
chmod ugo+rwx display_images/* chmod -R ugo+rwx display_images
cd rpi-rgb-led-matrix cd rpi-rgb-led-matrix
sudo apt-get update && sudo apt-get install python3-dev python3-pillow -y sudo apt-get update && sudo apt-get install python3-dev python3-pillow -y
make build-python PYTHON=$(which python3) make build-python PYTHON=$(which python3)

View File

@ -219,14 +219,15 @@ class StockTicker():
def scrollFunctionsAnimated(self, options, animation = 'continuous'): def scrollFunctionsAnimated(self, options, animation = 'continuous'):
# scrolls trhough all functions with animation. Updates functions and remakes images when each function not being dispplayed # scrolls trhough all functions with animation. Updates functions and remakes images when each function not being dispplayed
self.updateMultiple(options)
self.updateMultiple([options[0]])
print('done update') print('done update')
kill = False kill = False
i = 0 # keep track of which image we are displaying i = 0 # keep track of which image we are displaying
while True: while True:
update_process = Process(target = self.updateMultiple, args = (options,)) update_process = Process(target = self.updateMultiple, args = ([options[(i+1) % len(options)]],))
update_process.start() update_process.start()
print('display_images/' + options[i % len(options)] +'.ppm') print('display_images/' + options[i % len(options)] +'.ppm')
@ -244,26 +245,31 @@ class StockTicker():
#first scroll image in from bottom #first scroll image in from bottom
if animation == 'up': if animation == 'up':
offset_y = 32 offset_y = 33
while offset_y > 0: while offset_y > 0:
self.setImage(image, offset_x = offset_x, offset_y = offset_y)
offset_y -= 1 offset_y -= 1
self.setImage(image, offset_x = offset_x, offset_y = offset_y)
time.sleep(self.delay) time.sleep(self.delay)
kill = self.checkKilled() kill = self.checkKilled()
if kill: break if kill: break
time.sleep(1)
elif animation == 'down': elif animation == 'down':
offset_y = -32 offset_y = -33
while offset_y < 0: while offset_y < 0:
self.setImage(image, offset_x = offset_x, offset_y = offset_y)
offset_y += 1 offset_y += 1
self.setImage(image, offset_x = offset_x, offset_y = offset_y)
time.sleep(self.delay) time.sleep(self.delay)
kill = self.checkKilled() kill = self.checkKilled()
if kill: break if kill: break
time.sleep(1)
@ -302,7 +308,7 @@ class StockTicker():
i+=1 i+=1
def textImage(self, text, font, r = 255, g = 255, b = 255, matrix_height = False, buff = 0): def textImage(self, text, font, r = 255, g = 255, b = 255, matrix_height = False, w_buff = 3, h_buff = 3):
''' '''
creates and returns a ppm image containing the text in the supplied font and colour creates and returns a ppm image containing the text in the supplied font and colour
''' '''
@ -311,7 +317,7 @@ class StockTicker():
if matrix_height: if matrix_height:
height = 32 height = 32
img = Image.new('RGB', (width + buff + 3, height+3)) img = Image.new('RGB', (width + w_buff, height + h_buff))
d = ImageDraw.Draw(img) d = ImageDraw.Draw(img)
d.text((0, 0), text, fill=(r, g, b), font=font) d.text((0, 0), text, fill=(r, g, b), font=font)
@ -336,64 +342,6 @@ class StockTicker():
img = self.textImage(text, font, int(r), int(g), int(b), True, buff = 50) img = self.textImage(text, font, int(r), int(g), int(b), True, buff = 50)
return img return img
def getNewsImage(self):
headline_font = ImageFont.load("./fonts/10x20.pil")
source_font = ImageFont.load("./fonts/10x20.pil")
image_list = []
headlines = []
source_date_times = []
f = open('csv/news.csv', 'r')
CSV = csv.reader(f)
next(CSV)
for row in CSV:
headline, source, date, time = row
headlines.append(headline)
source_date_times.append(source + ': ' + date + ' ' + time)
f.close()
for i, headline in enumerate(headlines):
headline = headline.replace("^", ",")
headline = headline.replace("", "'")
headline = headline.replace("", "'")
headline = headline.replace('', '"')
headline = headline.replace('', '"')
headline_img = self.textImage(headline, headline_font, matrix_height = True)
source_img = self.textImage(source_date_times[i], source_font, r=255, g=255, b=0, matrix_height = True)
try:
logos_path = os.path.join(os.path.join(os.path.dirname(os.path.abspath(__file__)), 'logos'), 'news_logos')
logo = Image.open(os.path.join(logos_path, 'techcrunch' + '.png'))
img = Image.new('RGB', (headline_img.size[0], 32))
img.paste(headline_img, (2, -3))
img.paste(source_img, (2,16))
img= self.stitchImage([logo,img])
except Exception as e:
print(e)
img = Image.new('RGB', (headline_img.size[0], 32))
img.paste(headline_img, (0,0))
img.paste(source_img, (0,16))
image_list.append(img)
news_image = self.stitchImage(image_list)
return news_image
def displayGIF(self, gif): def displayGIF(self, gif):
# To iterate through the entire gif # To iterate through the entire gif
i = 0 i = 0
@ -696,11 +644,78 @@ class StockTicker():
return finalDisplayImage return finalDisplayImage
def getLeagueImage(self, league, time): def getNewsImage(self):
font = ImageFont.load("./fonts/texgyre-27.pil")
title_img = self.textImage('NEWS', font, matrix_height = True)
headline_font = ImageFont.load("./fonts/10x20.pil")
source_font = ImageFont.load("./fonts/10x20.pil")
image_list = [title_img]
headlines = []
source_date_times = []
f = open('csv/news.csv', 'r')
CSV = csv.reader(f)
next(CSV)
for row in CSV:
headline, source, date, time = row
headlines.append(headline)
source_date_times.append(source + ': ' + date + ' ' + time)
f.close()
for i, headline in enumerate(headlines):
headline = headline.replace("^", ",")
headline = headline.replace("", "'")
headline = headline.replace("", "'")
headline = headline.replace('', '"')
headline = headline.replace('', '"')
headline_img = self.textImage(headline, headline_font, matrix_height = True)
source_img = self.textImage(source_date_times[i], source_font, r=255, g=255, b=0, matrix_height = True)
try:
logos_path = os.path.join(os.path.join(os.path.dirname(os.path.abspath(__file__)), 'logos'), 'news_logos')
logo = Image.open(os.path.join(logos_path, 'techcrunch' + '.png'))
img = Image.new('RGB', (headline_img.size[0], 32))
img.paste(headline_img, (2, -3))
img.paste(source_img, (2,16))
img= self.stitchImage([logo,img])
except Exception as e:
print(e)
img = Image.new('RGB', (headline_img.size[0], 32))
img.paste(headline_img, (0,0))
img.paste(source_img, (0,16))
image_list.append(img)
news_image = self.stitchImage(image_list)
return news_image
def getLeagueImage(self, league=False, time = 'past'):
if not league:
f = open( "csv/league.txt", 'r' )
league = f.read().replace('\n', '')
f.close()
img = Image.new('RGB', (10000, 32)) img = Image.new('RGB', (10000, 32))
league_info = json.load(open('csv/sports/{}/{}_games.json'.format(league, time), 'r')) league_info = json.load(open('csv/sports/{}/{}_games.json'.format(league, time), 'r'))
print(league_info[0].keys()) print(league_info[0].keys())
small_font = ImageFont.load("./fonts/5x7.pil") small_font = ImageFont.load("./fonts/5x7.pil")
med_font = ImageFont.load("./fonts/7x14B.pil") med_font = ImageFont.load("./fonts/7x14B.pil")
large_font = ImageFont.load("./fonts/9x18B.pil") large_font = ImageFont.load("./fonts/9x18B.pil")
@ -743,16 +758,7 @@ class StockTicker():
away_logo = self.textImage(away_team.replace(' ', '\n'), small_font, r = 255, g = 255, b = 255) away_logo = self.textImage(away_team.replace(' ', '\n'), small_font, r = 255, g = 255, b = 255)
print(e) print(e)
#away_timage = self.textImage(sports_info[away_team]['code'], small_font, r = 255, g = 255, b = 255)
date_timage = self.textImage(date, small_font, r = 255, g = 255, b = 255) date_timage = self.textImage(date, small_font, r = 255, g = 255, b = 255)
#round_timage = self.textImage('round:' + rond, small_font, r = 255, g = 255, b = 255)
img.paste(home_logo, (x_offset,0)) img.paste(home_logo, (x_offset,0))
@ -761,9 +767,6 @@ class StockTicker():
if time == 'future': if time == 'future':
img.paste(date_timage, (x_offset+5, 0)) img.paste(date_timage, (x_offset+5, 0))
#vs_timage = self.textImage(sports_info[home_team]['code'] + 'vs' + sports_info[away_team]['code'], med_font, r = 255, g = 255, b = 255)
#img.paste(vs_timage, (x_offset, 12))
h_colour = mcolors.to_rgb(sports_info[home_team]['colour'].replace(' ', '')) h_colour = mcolors.to_rgb(sports_info[home_team]['colour'].replace(' ', ''))
a_colour = mcolors.to_rgb(sports_info[away_team]['colour'].replace(' ', '')) a_colour = mcolors.to_rgb(sports_info[away_team]['colour'].replace(' ', ''))
@ -779,9 +782,7 @@ class StockTicker():
x_offset += max( date_timage.size[0], hc_timage.size[0] + vs_timage.size[0] + ac_timage.size[0]) x_offset += max( date_timage.size[0], hc_timage.size[0] + vs_timage.size[0] + ac_timage.size[0])
else: else:
score_image = self.textImage(home_score + '-' + away_score, large_font, h_buff = 5, r = 255, g = 255, b = 255)
score_image = self.textImage(home_score + '-' + away_score, large_font, r = 255, g = 255, b = 255)
#vs_timage = self.textImage(sports_info[home_team]['code'] + 'vs' + sports_info[away_team]['code'], small_font, r = 255, g = 255, b = 255) #vs_timage = self.textImage(sports_info[home_team]['code'] + 'vs' + sports_info[away_team]['code'], small_font, r = 255, g = 255, b = 255)
@ -832,10 +833,18 @@ class StockTicker():
x_offset += buff_size x_offset += buff_size
img = img.crop((0,0,x_offset ,32)) img = img.crop((0,0,x_offset ,32))
return img font = ImageFont.load("./fonts/texgyre-27.pil")
title_img = self.textImage(time.upper() + ' GAMES', font, matrix_height = True)
def getTeamsImage(self, league): return self.stitchImage([title_img, img])
def getLeagueTableImage(self, league = False):
if not league:
f = open( "csv/table_league.txt", 'r' )
league = f.read().replace('\n', '')
f.close()
img = Image.new('RGB', (10000, 32)) img = Image.new('RGB', (10000, 32))
team_info = json.load(open('csv/sports/{}/team_stats.json'.format(league), 'r')) team_info = json.load(open('csv/sports/{}/team_stats.json'.format(league), 'r'))
@ -886,7 +895,10 @@ class StockTicker():
img = img.crop((0,0,x_offset ,32)) img = img.crop((0,0,x_offset ,32))
return img font = ImageFont.load("./fonts/texgyre-27.pil")
title_img = self.textImage('LEAGUE TABLE', font, matrix_height = True)
return self.stitchImage([title_img, img])
def getTodayWeatherImage(self): def getTodayWeatherImage(self):
@ -993,7 +1005,10 @@ class StockTicker():
vtext_img = self.textImage(str(current_weather['visibility']/1000) + 'km', small_font) vtext_img = self.textImage(str(current_weather['visibility']/1000) + 'km', small_font)
img.paste(vtext_img, (168, 22)) img.paste(vtext_img, (168, 22))
return img font = ImageFont.load("./fonts/texgyre-27.pil")
title_img = self.textImage('WEATHER', font, matrix_height = True)
return self.stitchImage([title_img, img])
def getDailyWeatherImageAlt(self): def getDailyWeatherImageAlt(self):
@ -1313,9 +1328,11 @@ class StockTicker():
img1 = img.crop((0,0,x_offset ,32)) img1 = img.crop((0,0,x_offset ,32))
# add the image text
font = ImageFont.load("./fonts/texgyre-27.pil")
title_img = self.textImage('WEATHER', font, matrix_height = True)
return self.stitchImage([title_img, img1])
return img1
#Retrieve symbols and stock info from the csv file #Retrieve symbols and stock info from the csv file
@ -1503,8 +1520,8 @@ class StockTicker():
stock_ticker.scrollImageTransition(['display_images/league.ppm', 'display_images/league.ppm'], stocks = False) stock_ticker.scrollImageTransition(['display_images/league.ppm', 'display_images/league.ppm'], stocks = False)
elif msg == 't': #teams elif msg == 't': #legue tble
img = self.getTeamsImage('premier_league') img = self.getLeagueTableImage('premier_league')
img.save('display_images/teams.ppm') img.save('display_images/teams.ppm')
stock_ticker.scrollImageTransition(['display_images/teams.ppm', 'display_images/teams.ppm'], stocks = False) stock_ticker.scrollImageTransition(['display_images/teams.ppm', 'display_images/teams.ppm'], stocks = False)
@ -1512,9 +1529,10 @@ class StockTicker():
elif msg == 'A': #everything elif msg == 'A': #everything
self.functions = {'stocks': self.getStockImage, 'crypto': self.getCryptoImage, 'forex': self.getForexImage, self.functions = {'stocks': self.getStockImage, 'crypto': self.getCryptoImage, 'forex': self.getForexImage,
'weather':self.getDailyWeatherImage} #put this somewhere else 'daily_weather':self.getDailyWeatherImage, 'today_weather': self.getDailyWeatherImage, 'league_table': self.getLeagueTableImage,
'league_games': self.getLeagueImage, 'news':self.getNewsImage} #put this somewhere else
userSettings = ['stocks', 'crypto', 'forex'] # these wil be read from csv, just for demo userSettings = ['stocks', 'crypto', 'forex', 'today_weather', 'daily_weather', 'league_table', 'league_games', 'news'] # these wil be read from csv, just for demo
#userSettings = ['stocks', 'crypto'] # these wil be read from csv, just for demo #userSettings = ['stocks', 'crypto'] # these wil be read from csv, just for demo
#userSettings = [ 'forex', 'weather'] # these wil be read from csv, just for demo #userSettings = [ 'forex', 'weather'] # these wil be read from csv, just for demo
@ -1530,7 +1548,7 @@ if __name__ == '__main__':
stock_ticker = StockTicker() stock_ticker = StockTicker()
#stock_ticker.process_msg('P') #stock_ticker.process_msg('P')
#stock_ticker.process_msg('A') stock_ticker.process_msg('P')