Zeitangaben, rechnen mit: Unterschied zwischen den Versionen

Aus FHEMWiki
Zeile 19: Zeile 19:
==== Beispiel: Zeitstempel eines Readings in Sekunden umwandeln ====
==== Beispiel: Zeitstempel eines Readings in Sekunden umwandeln ====
   time_str2num(ReadingsTimestamp(<devicename>, <reading>,<defaultvalue>))
   time_str2num(ReadingsTimestamp(<devicename>, <reading>,<defaultvalue>))
=== Berechnung ===


=== Umwandeln der Zahl in eine Zeichenkette ===
=== Umwandeln der Zahl in eine Zeichenkette ===
Zur Umwandlung seien die folgenden Perl-Funktionen genannt:
Zur Umwandlung seien die folgenden Perl-Funktionen genannt:
* <code>"HH:MM, DD.MM.YY" =~ /(\d\d).(\d\d)..(\d\d).(\d\d).(\d\d)/</code> extrahiert HH,MM,DD,MM und YY aus der Zeichenkette HH:MM, DD.MM.YY, die ein Datum in der angegebenen Form enthält. \d steht für eine Ziffer, der Punkt für ein beliebiges Zeichen, die () schreiben den Treffer in spezielle Variablen in der Reihenfolge ihrer Anordnung HH in $1, MM in $2, DD in $3 usw.
* <code>(Sekunden, Minuten, Stunden, Tag des Monats, Monat, Jahr, Nummer des Wochentages, Tag des Jahres, Sommerzeitkennzeichen) = localtime(Zeit in Sekunden)</code> gibt die einzelnen Zeitelemente zurück, siehe [http://perldoc.perl.org/functions/localtime.html]  
* <code>(Sekunden, Minuten, Stunden, Tag des Monats, Monat, Jahr, Nummer des Wochentages, Tag des Jahres, Sommerzeitkennzeichen) = localtime(Zeit in Sekunden)</code> gibt die einzelnen Zeitelemente zurück, siehe [http://perldoc.perl.org/functions/localtime.html]  
* <code>POSIX::strftime(<Format>,<Array mit Zeitelementen>)</code>, wandelt ein Array aus Zeitelementen, wie es <code>localtime</code> liefert in eine formatierte Zeichenkette um. <Format> wird mit Hilfe bestimmter Formatierungszeichen (%a für den Wochentagnamen, %d für den Tag des Monats usw. siehe [http://search.cpan.org/~dexter/POSIX-strftime-GNU-0.02/lib/POSIX/strftime/GNU.pm]) festgelegt.
* <code>POSIX::strftime(<Format>,<Array mit Zeitelementen>)</code>, wandelt ein Array aus Zeitelementen, wie es <code>localtime</code> liefert in eine formatierte Zeichenkette um. <Format> wird mit Hilfe bestimmter Formatierungszeichen (%a für den Wochentagnamen, %d für den Tag des Monats usw. siehe [http://search.cpan.org/~dexter/POSIX-strftime-GNU-0.02/lib/POSIX/strftime/GNU.pm]) festgelegt.
=== Berechnung Beispiele ===


=== Weitere Funktionen zur Zeitumwandlung ===
=== Weitere Funktionen zur Zeitumwandlung ===

Version vom 23. Januar 2018, 15:05 Uhr


Clock - Under Construction.svg An dieser Seite wird momentan noch gearbeitet.


Mit leicht lesbaren Zeitangaben, wie 07:30, 23.05.2017, 09:20 usw. kann in FHEM nicht ohne Weiteres gerechnet werden, da es sich um Zeichenketten handelt und nicht um Zahlen.

Verfahren zum Rechnen mit Zeitangaben, die als Zeichenkette vorliegen

Die Berechnung erfolgt in Perl. Das Verfahren besteht aus drei Schritten:

  • Umwandeln der Zeichenketten in eine Zahl, z.B. Sekunden.
  • Berechen einer Zeit als Zahl.
  • Umwandeln der Zahl in eine Zeichenkette (Formatierung)

Umwandeln eine Zeichenkette in eine Zahl

Hier hängt das Verfahren von der Struktur der Zeichenkette ab.

Perl und FHEM stellen Funktionen zur Umwandlung bereit.

  • time liefert die aktuelle Zeit in Sekunden, siehe [1]
  • time_str2num("YYYY-MM-DD HH:MM:SS") wandelt einen FHEM-Zeitstempel in Sekunden um, siehe [2]
  • timelocal(<Sekunden>, <Minuten>, <Stunden>, <Tag des Monats>, <Monat>, <Jahr>) wandelt einen Satz von Zeitelementen (Sekunden, Minuten, Stunden usw.) in Sekunden um, siehe [3]
  • Sekunden + Minuten * 60 + Stunden * 60 * 60 + Tage * 24 * 60 * 60 berechnen eines Summanden oder Subtrahenden aus Sekunden, Minuten, Stunden und Tagen.

Beispiel: Zeitstempel eines Readings in Sekunden umwandeln

 time_str2num(ReadingsTimestamp(<devicename>, <reading>,<defaultvalue>))

Umwandeln der Zahl in eine Zeichenkette

Zur Umwandlung seien die folgenden Perl-Funktionen genannt:

  • "HH:MM, DD.MM.YY" =~ /(\d\d).(\d\d)..(\d\d).(\d\d).(\d\d)/ extrahiert HH,MM,DD,MM und YY aus der Zeichenkette HH:MM, DD.MM.YY, die ein Datum in der angegebenen Form enthält. \d steht für eine Ziffer, der Punkt für ein beliebiges Zeichen, die () schreiben den Treffer in spezielle Variablen in der Reihenfolge ihrer Anordnung HH in $1, MM in $2, DD in $3 usw.
  • (Sekunden, Minuten, Stunden, Tag des Monats, Monat, Jahr, Nummer des Wochentages, Tag des Jahres, Sommerzeitkennzeichen) = localtime(Zeit in Sekunden) gibt die einzelnen Zeitelemente zurück, siehe [4]
  • POSIX::strftime(<Format>,<Array mit Zeitelementen>), wandelt ein Array aus Zeitelementen, wie es localtime liefert in eine formatierte Zeichenkette um. <Format> wird mit Hilfe bestimmter Formatierungszeichen (%a für den Wochentagnamen, %d für den Tag des Monats usw. siehe [5]) festgelegt.

Berechnung Beispiele

Weitere Funktionen zur Zeitumwandlung