generated from PdxCodeGuild/IntensivePythonFullStack
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathjsondb.py
49 lines (37 loc) · 1.03 KB
/
jsondb.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
'''
A simple JSON-based database that can be used with Flask.
Usage:
import from jsondb import JsonDB
db = JsonDB('database.json')
db.load()
x = db.get('x', 0)
x += 1
db.set('x', x)
db.save()
'''
import json
class JsonDB:
def __init__(self, path='db.json'):
self.path = path
self.data = None
def load(self):
with open(self.path, 'r') as file:
self.data = json.loads(file.read())
def save(self):
with open(self.path, 'w') as file:
file.write(json.dumps(self.data, indent=4, sort_keys=True))
def __getitem__(self, key):
return self.data[key]
def __setitem__(self, key, value):
self.data[key] = value
def __delitem__(self, key):
del self.data[key]
def get(self, key, default=None):
return self.data.get(key, default)
def set(self, key, value):
self.data[key] = value
def clear(self, key=None):
if key is not None:
del self.data[key]
else:
self.data = {}