forked from CSS-Electronics/canedge-influxdb-writer
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.py
38 lines (30 loc) · 1.36 KB
/
main.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
from utils import (
setup_fs,
load_dbc_files,
list_log_files,
ProcessData,
MultiFrameDecoder,
restructure_data,
add_signal_prefix
)
from utils_db import SetupInflux
import inputs as inp
# initialize connection to InfluxDB + get latest data entries per device
influx = SetupInflux(inp.influx_url, inp.token, inp.org_id, inp.influx_bucket, inp.res)
start_times = influx.get_start_times(inp.devices, inp.default_start, inp.dynamic)
# setup filesystem (local/S3), load DBC files and list log files for processing
fs = setup_fs(inp.s3, inp.key, inp.secret, inp.endpoint, inp.region, passwords=inp.pw)
db_list = load_dbc_files(inp.dbc_paths)
log_files = list_log_files(fs, inp.devices, start_times, True, inp.pw)
# process log files and write extracted signals to InfluxDB
proc = ProcessData(fs, db_list, inp.signals, inp.days_offset)
for log_file in log_files:
df_raw, device_id = proc.get_raw_data(log_file, inp.pw)
if inp.tp_type != "":
tp = MultiFrameDecoder(inp.tp_type)
df_raw = tp.combine_tp_frames(df_raw)
df_phys = proc.extract_phys(df_raw)
proc.print_log_summary(device_id, log_file, df_phys)
df_phys = add_signal_prefix(df_phys, can_id_prefix=inp.can_id_prefix, pgn_prefix=inp.pgn_prefix, bus_prefix=inp.bus_prefix)
df_phys = restructure_data(df_phys,inp.res)
influx.write_signals(device_id, df_phys)