projekt:python_ds18b20_logger
Unterschiede
Hier werden die Unterschiede zwischen zwei Versionen angezeigt.
| Beide Seiten der vorigen RevisionVorhergehende ÜberarbeitungNä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]] ist verpflichtende Voraussetzung und muss vollständig durchgeführt und erfolgreich getestet worden sein, da hier dieselbe Hardware weiterverwendet wird. | ||
| - | |||
| < | < | ||
| - | **Lokal (empfohlener Einstieg)** | + | Das Projekt [[python_projekt_ds18b20_digitaler_temperatursensor|DS18B20 |
| - | DS18B20 | + | |
| - | + | ||
| - | **Mit Webausgabe (optional)** | + | |
| - | DS18B20 → DokuWiki (Webserver) → FastAPI → Temperatur-Logger | + | |
| </ | </ | ||
| + | |||
| + | **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 55: | Zeile 60: | ||
| <code bash> | <code bash> | ||
| - | (course_env) pi@raspi88: | + | (course_env) pi@raspi88: |
| . | . | ||
| ├── data | ├── data | ||
| Zeile 64: | Zeile 69: | ||
| │ ├── hardware.py | │ ├── hardware.py | ||
| │ ├── __init__.py | │ ├── __init__.py | ||
| - | │ └── temperature_logger.py | + | │ └── temperature_logger.py |
| - | └── | + | └── |
| </ | </ | ||
| Zeile 161: | Zeile 166: | ||
| if MODE == " | if MODE == " | ||
| - | DATA_DIR = Path(" | + | DATA_DIR = Path(" |
| elif MODE == " | elif MODE == " | ||
| DATA_DIR = Path("/ | DATA_DIR = Path("/ | ||
| Zeile 203: | 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 274: | 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 283: | Zeile 296: | ||
| - | ++++ Quellcode '' | + | ++++ Quellcode '' |
| - | <code python | + | <code python |
| # | # | ||
| from core import temperature_logger as temp | from core import temperature_logger as temp | ||
| Zeile 306: | 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 354: | Zeile 367: | ||
| print_help() | print_help() | ||
| - | elif cmd in ("quit", "q"): | + | elif cmd in ("exit", "x"): |
| temp.stop() | temp.stop() | ||
| break | break | ||
| Zeile 366: | 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 371: | Zeile 459: | ||
| + | < | ||
| + | Der Apache-Webserver liefert automatisch die Datei '' | ||
| + | </ | ||
| + | |||
| + | |{{ : | ||
| + | |Bildausgabe über den Webbrowser| | ||
| Zeile 425: | Zeile 519: | ||
| </ | </ | ||
| - | < | + | < |
| </ | </ | ||
projekt/python_ds18b20_logger.1771756223.txt.gz · Zuletzt geändert: von torsten.roehl
