1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556 |
-
-
- from influxdb import InfluxDBClient
- from datetime import datetime
- import xlsxwriter
-
-
- host = '10.23.42.14'
- port = 8086
- user = 'root'
- password = 'root'
- dbname = 'giessomat'
-
-
- client = InfluxDBClient(host, port, user, password, dbname)
- print("Querying DB " + dbname + " on " + host)
- result = client.query('SELECT "id", "duration" FROM "plant";')
-
-
- data = list(result.get_points())
- print("Got " + str(len(data)) + " datapoints")
-
-
- ids = list(set([ d['id'] for d in data ]))
- ids.sort()
-
- print("IDs found: " + str(ids))
-
- values = []
- times = []
- durations = []
- for id in ids:
- values.append([d for d in data if d['id'] == id])
- times.append([datetime.strptime(d['time'], '%Y-%m-%dT%H:%M:%S.%fZ') for d in data if d['id'] == id])
- durations.append([d['duration'] for d in data if d['id'] == id])
-
- workbook = xlsxwriter.Workbook('InfluxExport.xlsx')
- worksheet = workbook.add_worksheet()
-
- bold = workbook.add_format({'bold': 1})
- date_format = workbook.add_format({'num_format': 'dd.mm.yyyy hh:mm'})
-
- for i in range(len(ids)):
- worksheet.write_string(0, (i * 3) + 0, "ID", bold)
- worksheet.write_number(0, (i * 3) + 1, int(ids[i]))
-
- worksheet.write_string(1, (i * 3) + 0, "Time", bold)
- worksheet.set_column((i * 3) + 0, (i * 3) + 0, 20)
- for j in range(len(times[i])):
- worksheet.write_datetime(j + 2, (i * 3) + 0, times[i][j], date_format)
-
- worksheet.write_string(1, (i * 3) + 1, "Duration", bold)
- for j in range(len(durations[i])):
- worksheet.write_number(j + 2, (i * 3) + 1, durations[i][j])
-
- workbook.close()
|