-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathapp.py
More file actions
98 lines (74 loc) · 2.21 KB
/
app.py
File metadata and controls
98 lines (74 loc) · 2.21 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
from flask import Flask, render_template, request
import sqlite3
from datetime import datetime
from utils.calculator import calculate_total
app = Flask(__name__)
# Define database file
DATABASE = "database.db"
# -----------------------------
# Database Initialization
# -----------------------------
def init_db():
conn = sqlite3.connect(DATABASE)
cursor = conn.cursor()
cursor.execute("""
CREATE TABLE IF NOT EXISTS history (
id INTEGER PRIMARY KEY AUTOINCREMENT,
travel REAL,
electricity REAL,
diet REAL,
total REAL,
yearly REAL,
score INTEGER,
category TEXT,
date TEXT
)
""")
conn.commit()
conn.close()
# Run DB initialization at startup
init_db()
# -----------------------------
# Routes
# -----------------------------
@app.route("/")
def home():
return render_template("index.html")
@app.route("/result", methods=["POST"])
def result():
data = request.form
# Calculate from calculator.py
result_data = calculate_total(data)
# Save to database
conn = sqlite3.connect(DATABASE)
cursor = conn.cursor()
cursor.execute("""
INSERT INTO history
(travel, electricity, diet, total, yearly, score, category, date)
VALUES (?, ?, ?, ?, ?, ?, ?, ?)
""", (
result_data["travel"],
result_data["electricity"],
result_data["diet"],
result_data["total"],
result_data["yearly"],
result_data["score"],
result_data["category"],
datetime.now().strftime("%Y-%m-%d %H:%M")
))
conn.commit()
conn.close()
return render_template("result.html", result=result_data)
@app.route("/history")
def history():
conn = sqlite3.connect(DATABASE)
cursor = conn.cursor()
cursor.execute("SELECT * FROM history ORDER BY id DESC")
records = cursor.fetchall()
conn.close()
return render_template("history.html", data=records)
# -----------------------------
# Run App
# -----------------------------
if __name__ == "__main__":
app.run(host="0.0.0.0", port=5000)