-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathb_schools_and_classes.py
More file actions
54 lines (47 loc) · 1.98 KB
/
b_schools_and_classes.py
File metadata and controls
54 lines (47 loc) · 1.98 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
import sqlite3
from important_variables import DATABASE_PATH
def save_school(school_name:str) -> None:
'''Insert a school in database.'''
db = sqlite3.connect(DATABASE_PATH)
db.execute('INSERT INTO schools_classes (school,classes) VALUES (?,?)', (school_name, '[]'))
db.commit()
db.close()
def save_class(school_name:str, class_name:str) -> None:
'''Insert a class in database.'''
db = sqlite3.connect(DATABASE_PATH)
cursor = db.execute('SELECT classes FROM schools_classes WHERE school=?', (school_name,))
classes = eval(cursor.fetchone()[0])
classes.append(class_name)
db.execute('UPDATE schools_classes SET classes=? WHERE school=?', (f'{classes}', school_name))
db.commit()
db.close()
def read_schools() -> list:
'''Reads all schools from database.'''
db = sqlite3.connect(DATABASE_PATH)
cursor = db.execute('SELECT school FROM schools_classes')
data = cursor.fetchall()
schools = [school[0] for school in data]
db.close()
return schools
def read_classes(school_name:str) -> list:
'''Reads all classes of a school from database.'''
db = sqlite3.connect(DATABASE_PATH)
cursor = db.execute('SELECT classes FROM schools_classes WHERE school=?', (school_name,))
classes = eval(cursor.fetchone()[0])
db.close()
return classes
def delete_school(school_name:str) -> None:
'''Deletes a school and all of it classes from database.'''
db = sqlite3.connect(DATABASE_PATH)
db.execute('DELETE FROM schools_classes WHERE school=?', (school_name,))
db.commit()
db.close()
def delete_class(school_name:str, class_name:str) -> None:
'''Deletes a class from database.'''
db = sqlite3.connect(DATABASE_PATH)
cursor = db.execute('SELECT classes FROM schools_classes WHERE school=?', (school_name,))
classes = eval(cursor.fetchone()[0])
classes.remove(class_name)
db.execute('UPDATE schools_classes SET classes=? WHERE school=?', (f'{classes}', school_name))
db.commit()
db.close()