projekt:python_ds18b20_logger
Unterschiede
Hier werden die Unterschiede zwischen zwei Versionen angezeigt.
| Nächste Überarbeitung | Vorhergehende Überarbeitung | ||
| projekt:python_ds18b20_logger [2026/02/22 10:30] – [Voraussetzungen] torsten.roehl | projekt:python_ds18b20_logger [2026/02/23 12:23] (aktuell) – [Testen] torsten.roehl | ||
|---|---|---|---|
| Zeile 3: | Zeile 3: | ||
| // | // | ||
| - | In diesem Projekt wird ein Temperatur-Logger mit dem digitalen 1-Wire-Sensor DS18B20 am Raspberry Pi realisiert. Ergänzend zur reinen Temperaturauslese werden Messwerte kontinuierlich in einer Textdatei protokolliert und aus diesen Daten automatisch ein Temperaturverlauf als Grafik erzeugt. Der Logger lässt sich über ein Kommandozeilen-Interface steuern und speichert Messdaten sowie Diagramm lokal oder zur Anzeige im Webserver-Verzeichnis.// | + | In diesem Projekt wird ein Temperatur-Logger mit dem digitalen 1-Wire-Sensor DS18B20 am Raspberry Pi realisiert. Ergänzend zur reinen Temperaturauslese werden Messwerte kontinuierlich in einer Textdatei protokolliert und aus diesen Daten automatisch ein Temperaturverlauf als Grafik erzeugt. Der Logger lässt sich über ein Kommandozeilen-Interface steuern und speichert Messdaten sowie das Diagramm lokal oder zur Anzeige im Webserver-Verzeichnis.// |
| + | |{{ : | ||
| + | |Der Temperaturverlauf im Browser wird nur angezeigt, wenn zuvor das Programm '' | ||
| ====== Überblick ====== | ====== Überblick ====== | ||
| Zeile 13: | Zeile 15: | ||
| * Software | * Software | ||
| * Quellcode | * Quellcode | ||
| + | * Testen | ||
| + | * Terminal | ||
| * Webseite | * Webseite | ||
| Zeile 20: | Zeile 24: | ||
| ===== Voraussetzungen | ===== Voraussetzungen | ||
| - | Das Projekt [[python_projekt_ds18b20_digitaler_temperatursensor|DS18B20 digitaler Temperatursensor]] | + | < |
| + | Das Projekt [[python_projekt_ds18b20_digitaler_temperatursensor|DS18B20 digitaler Temperatursensor]] muss vollständig durchgeführt | ||
| + | </ | ||
| + | |||
| + | **Nutzung lokal: | ||
| + | Für die reine lokale Verwendung des Loggers sind keine weiteren Projekte erforderlich. | ||
| + | |||
| + | **Nutzung mit Webausgabe: | ||
| + | Hierfür muss zuvor das [[dokuwiki|DokuWiki-Projekt]] zur Einrichtung des Webservers abgeschlossen worden sein. Idealerweise wurde auch das [[python_fastapi|FastAPI-Projekt]] bereits durchgeführt. | ||
| ==== Environment ==== | ==== Environment ==== | ||
| Zeile 47: | Zeile 60: | ||
| <code bash> | <code bash> | ||
| - | (course_env) pi@raspi88: | + | (course_env) pi@raspi88: |
| . | . | ||
| ├── data | ├── data | ||
| Zeile 56: | Zeile 69: | ||
| │ ├── hardware.py | │ ├── hardware.py | ||
| │ ├── __init__.py | │ ├── __init__.py | ||
| - | │ └── temperature_logger.py | + | │ └── temperature_logger.py |
| - | └── | + | └── |
| </ | </ | ||
| Zeile 153: | Zeile 166: | ||
| if MODE == " | if MODE == " | ||
| - | DATA_DIR = Path(" | + | DATA_DIR = Path(" |
| elif MODE == " | elif MODE == " | ||
| DATA_DIR = Path("/ | DATA_DIR = Path("/ | ||
| Zeile 195: | Zeile 208: | ||
| plt.ylabel(" | plt.ylabel(" | ||
| - | if temps: | + | if temps: |
| - | plt.plot(times, | + | |
| - | plt.xticks(rotation=45) | + | |
| + | step = max(1, len(times) // 10) | ||
| + | plt.xticks(range(0, len(times), step), | ||
| + | | ||
| + | rotation=45) | ||
| else: | else: | ||
| plt.text( | plt.text( | ||
| Zeile 266: | Zeile 283: | ||
| === Hauptprogramm === | === Hauptprogramm === | ||
| - | Das eigenständige Programm '' | + | Das eigenständige Programm '' |
| Es ermöglicht das Starten und Stoppen der Messung, das Setzen des Messintervalls sowie das Zurücksetzen der gespeicherten Daten. | Es ermöglicht das Starten und Stoppen der Messung, das Setzen des Messintervalls sowie das Zurücksetzen der gespeicherten Daten. | ||
| + | |||
| + | <note tip>Die eigentliche Messung läuft in einem // | ||
| + | |||
| + | |||
| < | < | ||
| Zeile 275: | Zeile 296: | ||
| - | ++++ Quellcode '' | + | ++++ Quellcode '' |
| - | <code python | + | <code python |
| # | # | ||
| from core import temperature_logger as temp | from core import temperature_logger as temp | ||
| Zeile 298: | Zeile 319: | ||
| status | t Status anzeigen | status | t Status anzeigen | ||
| help | h Diese Hilfe anzeigen | help | h Diese Hilfe anzeigen | ||
| - | quit | q | + | exit | x |
| """ | """ | ||
| Zeile 346: | Zeile 367: | ||
| print_help() | print_help() | ||
| - | elif cmd in ("quit", "q"): | + | elif cmd in ("exit", "x"): |
| temp.stop() | temp.stop() | ||
| break | break | ||
| Zeile 358: | Zeile 379: | ||
| ++++ | ++++ | ||
| + | ===== Testen ===== | ||
| + | Das Programm kann sowohl **lokal im Terminal** als auch über den **Webbrowser getestet werden**. | ||
| + | Für die Webausgabe gelten die im Abschnitt „Voraussetzungen“ beschriebenen Bedingungen. | ||
| + | |||
| + | |||
| + | < | ||
| + | |||
| + | Wird die Messung mit '' | ||
| + | |||
| + | Die Erfassung erfolgt entsprechend dem eingestellten Messintervall, | ||
| + | </ | ||
| + | |||
| + | |||
| + | <note tip> | ||
| + | Vor dem Testen prüfen, welcher '' | ||
| + | |||
| + | * '' | ||
| + | * '' | ||
| + | |||
| + | Für die Webausgabe muss '' | ||
| + | </ | ||
| + | ==== Terminal ==== | ||
| + | Zur Überprüfung wird das Programm im Verzeichnis '' | ||
| + | <code bash> | ||
| + | chmod 755 temp_logger.py | ||
| + | ./ | ||
| + | </ | ||
| + | |||
| + | |||
| + | |||
| + | <code bash Beispiel Ausgabe> | ||
| + | Temperatur-Logger v1.0.0 | ||
| + | Mit ' | ||
| + | |||
| + | > h | ||
| + | |||
| + | VERFÜGBARE BEFEHLE | ||
| + | ------------------ | ||
| + | start | s | ||
| + | stop | p | ||
| + | reset | r | ||
| + | interval <sek> | i < | ||
| + | status | t Status anzeigen | ||
| + | help | h Diese Hilfe anzeigen | ||
| + | exit | x Programm beenden | ||
| + | |||
| + | > start | ||
| + | (Programm misst im Hintergrund …) | ||
| + | > stop | ||
| + | > | ||
| + | </ | ||
| + | Nach dem Start erscheint die Kommandozeilen-Oberfläche des Temperatur-Loggers. | ||
| + | Im obigen Beispiel wurde mit dem Befehl '' | ||
| + | |||
| + | Die Befehle können entweder vollständig ausgeschrieben (z. B. '' | ||
| + | |||
| + | |||
| + | |||
| + | Die erzeugten Dateien befinden sich im Verzeichnis '' | ||
| + | |||
| + | <code bash> | ||
| + | ls | ||
| + | temperature.png | ||
| + | temperature.txt | ||
| + | </ | ||
| + | |||
| + | Die Grafik kann anschließend mit folgendem Befehl betrachtet werden: | ||
| + | |||
| + | <code bash> | ||
| + | feh temperature.png | ||
| + | </ | ||
| + | |||
| + | |{{ : | ||
| + | |Bildausgabe mit dem Befehl '' | ||
| + | |||
| ==== Webseite ==== | ==== Webseite ==== | ||
| Zeile 363: | Zeile 459: | ||
| + | < | ||
| + | Der Apache-Webserver liefert automatisch die Datei '' | ||
| + | </ | ||
| + | |||
| + | |{{ : | ||
| + | |Bildausgabe über den Webbrowser| | ||
| Zeile 417: | Zeile 519: | ||
| </ | </ | ||
| - | < | + | < |
| </ | </ | ||
projekt/python_ds18b20_logger.1771756255.txt.gz · Zuletzt geändert: von torsten.roehl
