forked from misdoro/Electronic_load_px100
-
Notifications
You must be signed in to change notification settings - Fork 5
/
data_store.py
45 lines (35 loc) · 1.32 KB
/
data_store.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
from datetime import datetime
from os import path
from pandas import DataFrame
class DataStore:
def __init__(self):
self.reset()
def __bool__(self):
return len(self.lastrow) > 0
def reset(self):
self.lastrow = {}
self.data = DataFrame()
def append(self, row):
print(row)
self.lastrow = row
# monkey patch append to use pandas' internal function
self.data = self.data._append(row, ignore_index=True)
# better would be using concat according to stackoverflow. example:
# pd.DataFrame(df).append(new_row, ignore_index=True)
# becomes
# pd.concat([df, pd.DataFrame([new_row])], ignore_index=True)
def write(self, basedir, prefix):
filename = "{}_raw_{}.csv".format(prefix, datetime.now().strftime("%Y%m%d_%H%M%S"))
full_path = path.join(basedir, filename)
export_rows = self.data.drop_duplicates()
if export_rows.shape[0]:
print("Write RAW data to {}".format(path.relpath(full_path)))
self.data.drop_duplicates().to_csv(full_path)
else:
print("no data")
def plot(self, **args):
return self.data.plot(**args)
def lastval(self, key):
return self.lastrow[key]
def setlastval(self, key, val):
self.lastrow[key] = val