324 lines
11 KiB
Python
324 lines
11 KiB
Python
import random
|
|
from flask import Flask, jsonify,make_response
|
|
from flask import request
|
|
import pymysql
|
|
import bs4 as bs
|
|
import requests as req
|
|
|
|
app = Flask(__name__)
|
|
|
|
def Update():
|
|
connection = pymysql.connect(db="hubobel",
|
|
user="hubobel",
|
|
passwd="polier2003",
|
|
host='10.0.1.59',charset='utf8')
|
|
cursor = connection.cursor()
|
|
sql="SELECT * FROM facts"
|
|
resp=cursor.execute(sql)
|
|
x=cursor.fetchall()
|
|
fact=dict(x)
|
|
cursor.close()
|
|
connection.close()
|
|
a=len(fact)
|
|
return fact,a
|
|
def Lotto():
|
|
|
|
connection = pymysql.connect(db="hubobel",
|
|
user="hubobel",
|
|
passwd="polier2003",
|
|
host='10.0.1.59', charset='utf8')
|
|
cursor = connection.cursor()
|
|
sql = "SELECT * FROM mittwoch ORDER BY id DESC"
|
|
resp = cursor.execute(sql)
|
|
x = int(resp)
|
|
sql_q = "SELECT * FROM mittwoch WHERE id like '" + str(x) + "'"
|
|
cursor.execute(sql_q)
|
|
resp = cursor.fetchall()
|
|
resp = (resp[0][1:])
|
|
ZahlenMittwoch = {'Datum': '', 'Z1': '', 'Z2': '', 'Z3': '', 'Z4': '', 'Z5': '', 'Z6': '', 'Superzahl': '',
|
|
'Spiel77': '', 'Super6': ''}
|
|
a = 1
|
|
while a != 7:
|
|
ZahlenMittwoch['Z' + str(a)] = resp[a]
|
|
a = a + 1
|
|
ZahlenMittwoch['Datum'] = resp[0]
|
|
ZahlenMittwoch['Superzahl'] = resp[7]
|
|
ZahlenMittwoch['Spiel77'] = resp[9]
|
|
ZahlenMittwoch['Super6'] = resp[8]
|
|
|
|
cursor = connection.cursor()
|
|
sql = "SELECT * FROM samstag ORDER BY id DESC"
|
|
resp = cursor.execute(sql)
|
|
x = int(resp)
|
|
sql_q = "SELECT * FROM samstag WHERE id like '" + str(x) + "'"
|
|
cursor.execute(sql_q)
|
|
resp = cursor.fetchall()
|
|
resp = resp[0][1:]
|
|
ZahlenSamstag = {'Datum': '', 'Z1': '', 'Z2': '', 'Z3': '', 'Z4': '', 'Z5': '', 'Z6': '', 'Superzahl': '',
|
|
'Spiel77': '', 'Super6': ''}
|
|
a = 1
|
|
while a != 7:
|
|
ZahlenSamstag['Z' + str(a)] = resp[a]
|
|
a = a + 1
|
|
ZahlenSamstag['Datum'] = resp[0]
|
|
ZahlenSamstag['Superzahl'] = resp[7]
|
|
ZahlenSamstag['Spiel77'] = resp[9]
|
|
ZahlenSamstag['Super6'] = resp[8]
|
|
|
|
cursor = connection.cursor()
|
|
sql = "SELECT * FROM euro ORDER BY id DESC"
|
|
resp = cursor.execute(sql)
|
|
x = int(resp)
|
|
sql_q = "SELECT * FROM euro WHERE id like '" + str(x) + "'"
|
|
cursor.execute(sql_q)
|
|
resp = cursor.fetchall()
|
|
resp = resp[0][1:]
|
|
ZahlenEuro = {'Datum': '', 'Z1': '', 'Z2': '', 'Z3': '', 'Z4': '', 'Z5': '', 'Eurozahl1': '', 'Eurozahl2': ''}
|
|
a = 1
|
|
while a != 6:
|
|
ZahlenEuro['Z' + str(a)] = resp[a]
|
|
a = a + 1
|
|
ZahlenEuro['Datum'] = resp[0]
|
|
ZahlenEuro['Eurozahl1'] = resp[6]
|
|
ZahlenEuro['Eurozahl2'] = resp[7]
|
|
connection.commit()
|
|
cursor.close()
|
|
connection.close()
|
|
return ZahlenMittwoch,ZahlenEuro,ZahlenSamstag
|
|
def Lottoaktuell():
|
|
req.packages.urllib3.disable_warnings()
|
|
sauce = req.get('https://www.eurojackpot.org/gewinnzahlen/', verify=False)
|
|
soup = bs.BeautifulSoup(sauce.text, 'lxml')
|
|
|
|
zahlen = []
|
|
ergebniss = []
|
|
ZahlenEuro = {'Datum': '', 'Z1': '', 'Z2': '', 'Z3': '', 'Z4': '', 'Z5': '', 'Eurozahl1': '', 'Eurozahl2': ''}
|
|
a = 1
|
|
datum = soup.find_all('time')
|
|
tag = []
|
|
for i in datum:
|
|
tag.append(i.text)
|
|
for li in soup.find_all('li'):
|
|
zahlen.append(li.text)
|
|
for i in zahlen[0:7]:
|
|
ergebniss.append(int(i))
|
|
ergebniss.append(tag[1])
|
|
while a != 6:
|
|
ZahlenEuro['Z' + str(a)] = ergebniss[a - 1]
|
|
a = a + 1
|
|
|
|
|
|
|
|
ende = (ergebniss[7].find('- Freitag'))
|
|
Datum=ergebniss[7]
|
|
ZahlenEuro['Datum'] = Datum[:ende-1]
|
|
ZahlenEuro['Eurozahl1'] = ergebniss[5]
|
|
ZahlenEuro['Eurozahl2'] = ergebniss[6]
|
|
|
|
req.packages.urllib3.disable_warnings()
|
|
sauce = req.get('https://www.lotto24.de/webshop/product/lottonormal/result', verify=False)
|
|
soup = bs.BeautifulSoup(sauce.text, 'lxml')
|
|
|
|
# print(soup.prettify())
|
|
Lottozahlen = {'Datum': '', 'Z1': '', 'Z2': '', 'Z3': '', 'Z4': '', 'Z5': '', 'Z6': '', 'Superzahl': '',
|
|
'Spiel77': '', 'Super6': ''}
|
|
daten = soup.find_all('div', class_="winning-numbers__number")
|
|
zahlen = []
|
|
for i in daten:
|
|
zahlen.append(int(i.text))
|
|
a = 1
|
|
while a != 7:
|
|
Lottozahlen['Z' + str(a)] = zahlen[a - 1]
|
|
a = a + 1
|
|
Spiel77 = ''
|
|
Super6 = ''
|
|
zahlen77 = []
|
|
daten = soup.find_all('div', class_="winning-numbers__number--additional")
|
|
for i in daten:
|
|
zahlen77.append(int(i.text))
|
|
spiel77 = zahlen77[0:7]
|
|
super6 = zahlen77[-6:]
|
|
for i in spiel77:
|
|
Spiel77 = Spiel77 + str(i)
|
|
for i in super6:
|
|
Super6 = Super6 + str(i)
|
|
|
|
daten = soup.find_all('h2', class_="strong hidden-xs")
|
|
for i in daten:
|
|
date = i.text
|
|
date = date.replace(' ', '')
|
|
date = date.replace('\n', '')
|
|
|
|
start = (date.find('dem')) + 4
|
|
ende = (date.find('(Alle'))
|
|
|
|
Lottozahlen['Superzahl'] = zahlen[6]
|
|
Lottozahlen['Spiel77'] = Spiel77
|
|
Lottozahlen['Super6'] = Super6
|
|
Lottozahlen['Datum'] = date[start:ende]
|
|
|
|
return Lottozahlen,ZahlenEuro
|
|
|
|
@app.route('/lotto', methods=['GET'])
|
|
def get_lotto():
|
|
Mit,EUR,Sam=Lotto()
|
|
return jsonify('Hinweis: Alle Angaben ohne Gewaehr auf Richtigkeit:',Mit,EUR,Sam)
|
|
|
|
@app.route('/lotto/Samstag', methods=['GET'])
|
|
def get_lottoSam():
|
|
Mit,EUR,Sam=Lotto()
|
|
return jsonify('Hinweis: Alle Angaben ohne Gewaehr auf Richtigkeit:',Sam)
|
|
|
|
@app.route('/lotto/Mittwoch', methods=['GET'])
|
|
def get_lottoMit():
|
|
Mit,EUR,Sam=Lotto()
|
|
return jsonify('Hinweis: Alle Angaben ohne Gewaehr auf Richtigkeit:',Mit)
|
|
|
|
@app.route('/lotto/Euro', methods=['GET'])
|
|
def get_lottoEur():
|
|
Mit,EUR,Sam=Lotto()
|
|
return jsonify('Hinweis: Alle Angaben ohne Gewaehr auf Richtigkeit:',EUR)
|
|
|
|
@app.route('/lotto/aktuell', methods=['GET'])
|
|
def get_lottoAktuell():
|
|
Lottozahlen,ZahlenEuro=Lottoaktuell()
|
|
|
|
return jsonify(Lottozahlen,ZahlenEuro)
|
|
|
|
@app.errorhandler(404)
|
|
def not_found(error):
|
|
return make_response(jsonify({'error': 'Nicht unterstuetzt'}), 404)
|
|
@app.route('/')
|
|
def index():
|
|
fact,a = Update()
|
|
|
|
return """
|
|
<!DOCTYPE html>
|
|
<head>
|
|
<title>Hubobel.de RESTful-API</title>
|
|
<link rel="stylesheet" href="http://stash.compjour.org/assets/css/foundation.css">
|
|
</head>
|
|
<body style="width: 880px; margin: auto;">
|
|
<h1>Willkommen bei der RESTful-API von hubobel.de</h1>
|
|
<p>folgende Aufrufe sind derzeit realisisert:</p>
|
|
<p>GET: api.hubobel.de/facts.....: Uebersicht ueber alle verfuegbaren Facts mit ihrer ID</p>
|
|
<p>GET: api.hubobel.de/facts/'ID'.....: JSON des abgefragten Facts</p>
|
|
<p>GET: api.hubobel.de/facts/zufall.....: ein zufaellig ausgewaehlter Fact wird im JSON zurueck gegeben</p>
|
|
<p>GET: api.hubobel.de/lotto....: Liefert die letzten Zahlen von Mittwochs-, Euro- und Samstagslotto
|
|
(aus der Datenbank)</p>
|
|
<p>GET: api.hubobel.de/lotto/Mittwoch.....: Liefert die letzten Mottwochszahlen (aus der Datenbank)</p>
|
|
<p>GET: api.hubobel.de/lotto/Euro.....: Liefert die letzten Eurojackpotzahlen (aus der Datenbank)</p>
|
|
<p>GET: api.hubobel.de/lotto/Samstag.....: Liefert die letzten Samstagszahlen (aus der Datenbank)</p>
|
|
<p>GET: api.hubobel.de/lotto/aktuell.....: Liefert die letzten Lottozahlen des Euro- und Mittwoch
|
|
bzw.Samstagslotto (online jeweils neu ermittelt)</p>
|
|
<p>POST: api.hubobel.de/lotto/6aus49/check.....: Uebergabe der 6+1 Zahlen als Liste - liefert Anzahl
|
|
der Treffer zurueck</p>
|
|
<p>POST: api.hubobel.de/lotto/6aus49/check.....: Uebergabe der 5+2 Zahlen als Liste - liefert Anzahl
|
|
der Treffer zurueck</p>
|
|
<p>...to be continued</p>
|
|
|
|
</body>
|
|
"""
|
|
@app.route('/facts', methods=['GET'])
|
|
def get_tasks():
|
|
fact, a = Update()
|
|
return jsonify({'facts': fact})
|
|
@app.route('/facts/<int:task_id>', methods=['GET'])
|
|
def get_task(task_id):
|
|
connection = pymysql.connect(db="hubobel",
|
|
user="hubobel",
|
|
passwd="polier2003",
|
|
host='10.0.1.59', charset='utf8')
|
|
cursor = connection.cursor()
|
|
sql = "SELECT * FROM facts ORDER BY nr DESC"
|
|
resp = cursor.execute(sql)
|
|
x = int(resp)
|
|
if x<task_id:
|
|
return jsonify({'error':"Auch Chuck Norris FACTS sind begrenzt"})
|
|
sql_q = "SELECT * FROM facts WHERE nr like '" + str(task_id) + "'"
|
|
cursor.execute(sql_q)
|
|
resp = cursor.fetchall()
|
|
resp = (resp[0][1])
|
|
cursor.close()
|
|
connection.close()
|
|
return jsonify({'fact': resp})
|
|
@app.route('/zufall', methods=['GET'])
|
|
def zufall():
|
|
connection = pymysql.connect(db="hubobel",
|
|
user="hubobel",
|
|
passwd="polier2003",
|
|
host='10.0.1.59', charset='utf8')
|
|
cursor = connection.cursor()
|
|
sql = "SELECT * FROM facts ORDER BY nr DESC"
|
|
resp = cursor.execute(sql)
|
|
x = int(resp)
|
|
ran = random.randint(1, x)
|
|
print(x, ran)
|
|
sql_q = "SELECT * FROM facts WHERE nr like '" + str(ran) + "'"
|
|
resp = cursor.execute(sql_q)
|
|
resp = cursor.fetchall()
|
|
resp = (resp[0][1])
|
|
cursor.close()
|
|
connection.close()
|
|
return jsonify({ran: resp})
|
|
|
|
@app.route('/lotto/6aus49/check', methods=['POST'])
|
|
def checkMittwoch():
|
|
if len(request.json) != 7:
|
|
return make_response(jsonify({'error': 'Sie müssen 6+1 Zahl als Liste übergeben'}), 404)
|
|
Treffer=0
|
|
Ziffern=[]
|
|
eingabe=request.json
|
|
Lottozahlen_aktuell,ZahlenEuro_aktuell=Lottoaktuell()
|
|
|
|
Lottozahlen=[]
|
|
a=1
|
|
while a!=7:
|
|
Lottozahlen.append(Lottozahlen_aktuell['Z'+str(a)])
|
|
a+=1
|
|
for i in eingabe[:6]:
|
|
if i in Lottozahlen:
|
|
Treffer+=1
|
|
Ziffern.append(i)
|
|
Lottozahlen.remove(i)
|
|
if eingabe[6]==Lottozahlen_aktuell['Superzahl']:
|
|
Superzahl=True
|
|
else:
|
|
Superzahl=False
|
|
|
|
return jsonify({'Treffer':Treffer,'Superzahl':Superzahl,'richtige Ziffern':Ziffern})
|
|
|
|
@app.route('/lotto/Euro/check', methods=['POST'])
|
|
def checkEuro():
|
|
if len(request.json) != 7:
|
|
return make_response(jsonify({'error': 'Sie müssen 5+2 Zahlen als Liste übergeben'}), 404)
|
|
Treffer=0
|
|
Ziffern=[]
|
|
eingabe=request.json
|
|
Lottozahlen_aktuell,ZahlenEuro_aktuell=Lottoaktuell()
|
|
|
|
Lottozahlen=[]
|
|
a=1
|
|
while a!=6:
|
|
Lottozahlen.append(ZahlenEuro_aktuell['Z'+str(a)])
|
|
a+=1
|
|
for i in eingabe[:6]:
|
|
if i in Lottozahlen:
|
|
Treffer+=1
|
|
Ziffern.append(i)
|
|
Lottozahlen.remove(i)
|
|
if eingabe[5]==ZahlenEuro_aktuell['Eurozahl1']:
|
|
Eurozahl1=True
|
|
else:
|
|
Eurozahl1=False
|
|
if eingabe[6]==ZahlenEuro_aktuell['Eurozahl2']:
|
|
Eurozahl2=True
|
|
else:
|
|
Eurozahl2=False
|
|
|
|
return jsonify({'Treffer':Treffer,'Eurozahl1':Eurozahl1,'Eurozahl2':Eurozahl2,'richtige Ziffern':Ziffern})
|
|
|
|
if __name__ == '__main__':
|
|
app.run(host='0.0.0.0')
|
|
|
|
|