This repository was archived by the owner on Sep 28, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmain.py
More file actions
112 lines (98 loc) · 4.39 KB
/
main.py
File metadata and controls
112 lines (98 loc) · 4.39 KB
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
from flask import Flask, render_template, request, redirect, url_for
from flask_sqlalchemy import SQLAlchemy
import pandas as pd
from data import Foods
import datetime
import json
EmissionData = pd.read_excel('EmissionValues.xlsx')
app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///purchases.sqlite3'
db = SQLAlchemy(app)
class Purchases(db.Model):
id = db.Column('entry_id', db.Integer, primary_key = True)
category = db.Column(db.String(100))
amount = db.Column(db.Float)
globalWarmingPotential = db.Column(db.Float)
energyConsumption = db.Column(db.Float)
waterUsage = db.Column(db.Float)
dateAdded = db.Column(db.DateTime, nullable = False, default = datetime.datetime.utcnow)
def __init__(self, category = None, amount = None, globalWarmingPotential = None, energyConsumption = None, waterUsage = None):
self.category = category
self.amount = amount
self.globalWarmingPotential = globalWarmingPotential
self.energyConsumption = energyConsumption
self.waterUsage = waterUsage
def __repr__(self):
return "Purchase('{self.category}', '{self.amount}', '{self.globalWarmingPotential}', '{self.energyConsumption}', '{self.waterUsage}')"
class ReferenceValues(db.Model):
id = db.Column('entry_id', db.Integer, primary_key = True)
category = db.Column(db.String(100))
globalWarmingPotential = db.Column(db.Float)
energyConsumption = db.Column(db.Float)
waterUsage = db.Column(db.Float)
def __init__(self, category = None, globalWarmingPotential = None, energyConsumption = None, waterUsage = None):
self.category = category
self.globalWarmingPotential = globalWarmingPotential
self.energyConsumption = energyConsumption
self.waterUsage = waterUsage
def __repr__(self):
return "ReferenceValues('{self.category}', '{self.globalWarmingPotential}', '{self.energyConsumption}', '{self.waterUsage}')"
class ReferenceValuesUnits(db.Model):
id = db.Column('entry_id', db.Integer, primary_key = True)
globalWarmingPotential = db.Column(db.Float)
energyConsumption = db.Column(db.Float)
waterUsage = db.Column(db.Float)
def __init__(self, globalWarmingPotential = None, energyConsumption = None, waterUsage = None):
self.waterUsage = waterUsage
self.globalWarmingPotential = globalWarmingPotential
self.energyConsumption = energyConsumption
def __repr__(self):
return "ReferenceValues('{self.globalWarmingPotential}', '{self.energyConsumption}', '{self.waterUsage}')"
@app.route('/')
def index():
Selections = EmissionData['Category'].dropna()
return render_template('index.html', selections = Selections)
@app.route('/about')
def about():
return render_template('about.html')
@app.route('/view_list')
def view_list():
# print "Querying"
purch = Purchases.query.all()
units = ['kg of CO2', 'MJ', 'm^3']
return render_template('view_list.html', purchases = purch, ref_units = units)
@app.route('/overview')
def overview():
# print "Querying"
purch = ReferenceValues.query.all()
units = ['kg of CO2', 'MJ', 'm^3']
return render_template('overview.html', purchases = purch, ref_units = units)
@app.route('/piechart')
def piechart():
purch = Purchases.query.all()
return render_template('piechart.html', purchases = purch)
@app.route('/barchart')
def barchart():
purch = Purchases.query.all()
return render_template('barchart.html', purchases = purch)
@app.route('/results', methods = ['POST'])
def result():
# Looping through the received object and adding all the elements to the array newData
newData = []
# Getting the response and converting it to an object
postData = json.loads(request.form['purchases'])
# Looping through the dict and adding the values to the newData list
for key in postData:
ref_val = ReferenceValues.query.filter_by(category=key).first()
# Making sure to not multiply by 'NaN'
if ref_val.energyConsumption == None:
ref_val.energyConsumption = 0
ref_val.waterUsage = 0
newData.append(Purchases(category = key, amount = postData[key], globalWarmingPotential = round(postData[key]*ref_val.globalWarmingPotential,2),
energyConsumption = round(postData[key]*ref_val.energyConsumption,2), waterUsage = round(postData[key]*ref_val.waterUsage,2)))
db.session.bulk_save_objects(newData)
db.session.commit()
# print "Added."
return json.dumps({'success':True}), 200, {'ContentType':'application/json'}
if __name__ == '__main__':
app.run(debug = True)