Update app.py
Browse files
app.py
CHANGED
@@ -314,7 +314,7 @@ def plot_ph_week():
|
|
314 |
week_number = 1
|
315 |
elif week_number > 30:
|
316 |
week_number = 30
|
317 |
-
|
318 |
conn = sqlite3.connect('system_data.db')
|
319 |
cursor = conn.cursor()
|
320 |
|
@@ -322,16 +322,8 @@ def plot_ph_week():
|
|
322 |
table_exists = cursor.fetchone()
|
323 |
|
324 |
if not table_exists:
|
325 |
-
return '''
|
326 |
-
|
327 |
-
<body>
|
328 |
-
<h1>Ошибка!</h1>
|
329 |
-
<p>Таблица system_data не существует.</p>
|
330 |
-
<button onclick="window.location.href='/plot_ph_week'">Назад</button>
|
331 |
-
</body>
|
332 |
-
</html>
|
333 |
-
'''
|
334 |
-
|
335 |
cursor.execute('''
|
336 |
SELECT date_time, ph, ec, dey, onA, onB, onC
|
337 |
FROM system_data
|
@@ -339,81 +331,25 @@ def plot_ph_week():
|
|
339 |
ORDER BY date_time
|
340 |
''', (week_number,))
|
341 |
rows = cursor.fetchall()
|
342 |
-
|
343 |
conn.close()
|
344 |
-
|
345 |
if not rows:
|
346 |
-
return f''
|
347 |
-
|
348 |
-
|
349 |
-
|
350 |
-
|
351 |
-
|
352 |
-
|
353 |
-
|
354 |
-
|
355 |
-
''
|
356 |
-
|
357 |
-
|
358 |
-
|
359 |
-
|
360 |
-
|
361 |
-
onB_values = [float(row[5]) for row in rows]
|
362 |
-
onC_values = [float(row[6]) for row in rows]
|
363 |
-
|
364 |
-
plt.figure(figsize=(15, 18)) # Увеличил высоту для трех графиков
|
365 |
-
|
366 |
-
# График pH
|
367 |
-
plt.subplot(3, 1, 1)
|
368 |
-
plt.plot(dates, ph_values, linestyle='-', color='b')
|
369 |
-
plt.title(f'График pH за {week_number}-ю неделю', fontsize=14)
|
370 |
-
plt.xlabel('Дата и день недели', fontsize=12)
|
371 |
-
plt.ylabel('Значение pH', fontsize=12)
|
372 |
-
plt.xticks(rotation=90, fontsize=6)
|
373 |
-
plt.grid(True)
|
374 |
-
|
375 |
-
# График EC
|
376 |
-
plt.subplot(3, 1, 2)
|
377 |
-
plt.plot(dates, ec_values, linestyle='-', color='g')
|
378 |
-
plt.title(f'График EC за {week_number}-ю неделю', fontsize=14)
|
379 |
-
plt.xlabel('Дата и день недели', fontsize=12)
|
380 |
-
plt.ylabel('Значение EC', fontsize=12)
|
381 |
-
plt.xticks(rotation=90, fontsize=6)
|
382 |
-
plt.grid(True)
|
383 |
-
|
384 |
-
# График насосов
|
385 |
-
plt.subplot(3, 1, 3)
|
386 |
-
plt.plot(dates, onA_values, linestyle='-', color='green', label='Насос A')
|
387 |
-
plt.plot(dates, onB_values, linestyle='-', color='brown', label='Насос B')
|
388 |
-
plt.plot(dates, onC_values, linestyle='-', color='orange', label='Насос C')
|
389 |
-
plt.title(f'График работы насосов за {week_number}-ю неделю', fontsize=14)
|
390 |
-
plt.xlabel('Дата и день недели', fontsize=12)
|
391 |
-
plt.ylabel('Состояние насосов', fontsize=12)
|
392 |
-
plt.xticks(rotation=90, fontsize=6)
|
393 |
-
plt.legend()
|
394 |
-
plt.grid(True)
|
395 |
-
|
396 |
-
# Увеличиваем расстояние между графиками
|
397 |
-
plt.subplots_adjust(hspace=1.2, bottom=0.1, top=0.95)
|
398 |
-
|
399 |
-
buffer = io.BytesIO()
|
400 |
-
plt.savefig(buffer, format='png')
|
401 |
-
buffer.seek(0)
|
402 |
-
|
403 |
-
plot_data = base64.b64encode(buffer.getvalue()).decode('utf-8')
|
404 |
-
|
405 |
-
return f'''
|
406 |
-
<html>
|
407 |
-
<body>
|
408 |
-
<h1>Графики за {week_number}-ю неделю</h1>
|
409 |
-
<button onclick="window.location.href='/plot_ph_week?week={week_number - 1}'" {"disabled" if week_number == 1 else ""}>Предыдущая неделя</button>
|
410 |
-
<button onclick="window.location.href='/plot_ph_week?week={week_number + 1}'" {"disabled" if week_number == 30 else ""}>Следующая неделя</button>
|
411 |
-
<br><br>
|
412 |
-
<img src="data:image/png;base64,{plot_data}" alt="Графики pH, EC и насосов">
|
413 |
-
</body>
|
414 |
-
</html>
|
415 |
-
'''
|
416 |
-
|
417 |
except Exception as e:
|
418 |
return jsonify({'status': 'error', 'message': str(e)}), 500
|
419 |
|
@@ -433,7 +369,6 @@ def plot_ph_week():
|
|
433 |
|
434 |
|
435 |
|
436 |
-
|
437 |
@app.route("/")
|
438 |
def index():
|
439 |
return flask.render_template('index.html')
|
|
|
314 |
week_number = 1
|
315 |
elif week_number > 30:
|
316 |
week_number = 30
|
317 |
+
|
318 |
conn = sqlite3.connect('system_data.db')
|
319 |
cursor = conn.cursor()
|
320 |
|
|
|
322 |
table_exists = cursor.fetchone()
|
323 |
|
324 |
if not table_exists:
|
325 |
+
return jsonify({'status': 'error', 'message': 'Таблица system_data не существует'}), 404
|
326 |
+
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
327 |
cursor.execute('''
|
328 |
SELECT date_time, ph, ec, dey, onA, onB, onC
|
329 |
FROM system_data
|
|
|
331 |
ORDER BY date_time
|
332 |
''', (week_number,))
|
333 |
rows = cursor.fetchall()
|
334 |
+
|
335 |
conn.close()
|
336 |
+
|
337 |
if not rows:
|
338 |
+
return jsonify({'status': 'error', 'message': f'Нет данных за {week_number}-ю неделю'}), 404
|
339 |
+
|
340 |
+
# Формируем данные для JSON
|
341 |
+
data = {
|
342 |
+
'week': week_number,
|
343 |
+
'dates': [row[0] for row in rows], # Даты
|
344 |
+
'ph': [float(row[1]) for row in rows], # pH
|
345 |
+
'ec': [float(row[2]) for row in rows], # EC
|
346 |
+
'onA': [float(row[4]) for row in rows], # Насос A
|
347 |
+
'onB': [float(row[5]) for row in rows], # Насос B
|
348 |
+
'onC': [float(row[6]) for row in rows], # Насос C
|
349 |
+
}
|
350 |
+
|
351 |
+
return render_template('plot_ph_week.html', data=data)
|
352 |
+
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
353 |
except Exception as e:
|
354 |
return jsonify({'status': 'error', 'message': str(e)}), 500
|
355 |
|
|
|
369 |
|
370 |
|
371 |
|
|
|
372 |
@app.route("/")
|
373 |
def index():
|
374 |
return flask.render_template('index.html')
|