-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathapp.py
68 lines (49 loc) · 2 KB
/
app.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
from flask import Flask, jsonify, render_template
import sqlalchemy
from sqlalchemy.ext.automap import automap_base
from sqlalchemy.orm import Session
from sqlalchemy import create_engine, func
import pandas as pd
#################################################
# Database Setup
#################################################
engine = create_engine("sqlite:///data/pandemic_final.db")
#################################################
# Flask Setup
#################################################
app = Flask(__name__)
#################################################
# Flask Routes
#################################################
@app.route("/")
def welcome():
#######QUERY FROM DATABASE fOR THIS ROUTE #######
return render_template('index.html')
@app.route("/charts")
def charts():
return render_template('charts.html')
@app.route("/globe")
def globe():
return render_template('globe.html')
@app.route("/about")
def about():
return render_template('about.html')
@app.route("/api/v1.0/pandemic")
def pandemic():
# Create our session (link) from Python to the DB
#session = Session(engine)
""" Query all Pandemics for 'Pandemic', 'Country', 'Year', 'Cases', 'Deaths', 'Lon', 'Lat', 'population'"""
#results_old = session.query(pandemic_table.Pandemic, pandemic_table.Country, pandemic_table.Year, pandemic_table.Cases, pandemic_table.Deaths, pandemic_table.Lon, pandemic_table.Lat, pandemic_table.population).all()
query ='SELECT "Pandemic", "Country", "Year", "Cases", "Deaths", "Lon", "Lat", "population" from "pandemic_final";'
results = pd.read_sql(query, con=engine)
all_pandemics = results.to_dict(orient="records")
# Grab list of pandemic names
pandemic_names = list(results.Pandemic.unique())
# Mimic the pandemic_final.json structure for the graphs to work
pandemics_final = {
'names': pandemic_names,
'pandemics': all_pandemics
}
return jsonify(pandemics_final)
if __name__ == "__main__":
app.run(debug=True)