NAME

Quiq::Time - Klasse zur Repräsentation von Datum und Uhrzeit

BASE CLASS

Quiq::Object

DESCRIPTION

Ein Objekt der Klasse Quiq::Time repräsentiert eine Zeitangabe, bestehend aus den Komponenten Jahr (Y), Monat (M), Tag (D), Stunde (h), Minute (m) und Sekunde (s). Die Klasse stellt Methoden zur Manipulation der Zeitangabe zur Verfügung.

Die Zeitangabe ist keiner bestimmten Zeitzone zugeordnet, alle Tage haben 24 Stunden (keine Sommerzeit- und Winterzeit-Umschaltung) und alle Tage haben genau 86400 Sekunden (keine Schaltsekunden).

METHODS

Konstruktor

new() - Instantiiere Zeitobjekt

Synopsis

$ti = $class->new($year,$month,$day,$hour,$minute,$second);
$ti = $class->new($year,$month,$day,$hour,$minute);
$ti = $class->new($year,$month,$day,$hour);
$ti = $class->new($year,$month,$day);
$ti = $class->new($year,$month);
$ti = $class->new($year);
$ti = $class->new(local=>$epoch);
$ti = $class->new(utc=>$epoch);
$ti = $class->new(dmy=>'D M Y');
$ti = $class->new(dmyhms=>'D M Y H M S');
$ti = $class->new(ymd=>'Y M D');
$ti = $class->new(ymdhm=>'Y M D');
$ti = $class->new(ymdhms=>'Y M D H M S');
$ti = $class->new(parse=>'D.M.Y ...'|'M/D/Y ...'|'Y-M-D ...');
$ti = $class->new;

Description

Instantiiere Zeitobjekt, setze die Zeitkomponenten auf die angegebenen Werte und liefere das Objekt zurück.

Aufrufargumente siehe $ti->set().

copy() - Kopiere Zeitobjekt

Synopsis

$ti2 = $ti->copy;

Description

Kopiere Zeitobjekt und liefere die Kopie zurück.

asArray() - Liefere Zeit als Array

Synopsis

($year,$month,$day,$hour,$minute,$second) = $ti->asArray;

Zeit/Datum setzen

set() - Setze Zeit neu

Synopsis

$ti = $class->set($year,$month,$day,$hour,$minute,$second);
$ti = $class->set($year,$month,$day,$hour,$minute);
$ti = $class->set($year,$month,$day,$hour);
$ti = $class->set($year,$month,$day);
$ti = $class->set($year,$month);
$ti = $class->set($year);
$ti = $class->set(local=>$epoch);
$ti = $class->set(utc=>$epoch);
$ti = $class->set(dmy=>'D M Y');
$ti = $class->set(dmyhm=>'D M Y H M');
$ti = $class->set(dmyhms=>'D M Y H M S');
$ti = $class->set(ymd=>'Y M D');
$ti = $class->set(ymdhm=>'Y M D');
$ti = $class->set(ymdhms=>'Y M D H M S');
$ti = $class->set(parse=>'D.M.Y ...'|'M/D/Y ...'|'Y-M-D ...');
$ti = $class->set;

Description

Setze die Zeit gemäß der angegebenen Zeitkomponenten und liefere das Zeitobjekt zurück.

Alle nicht angegebenen Komponenten werden auf ihren kleinsten Wert initialisiert (1 bei bei Monat und Tag, 0 bei Stunde, Minute, Sekunde).

Ein Aufruf ohne Argument setzt das Objekt auf den Beginn der Epoche (1.1.1970 0 Uhr).

Bei den Formaten dmy, dmyhms, ... sind beliebige Trennzeichen zwischen den einzelnen Zahlen erlaubt.

setTime() - Setze Zeitanteil

Synopsis

$ti = $ti->setTime($hour,$minute,$second);

Description

Setze die Zeit auf die angegebenen Stunden, Minuten, Sekunden und liefere das Zeitobjekt zurück. Wird für eine Zeitkomponente Cltundef> angegeben, wird diese nicht gesetzt.

truncate() - Kürze Zeitkomponenten

Synopsis

$ti = $ti->truncate($unit);

Description

Kürze Zeit auf Jahr (Y), Monat (M), Tag (D), Stunde (h) oder Minute (m), d.h. setze alle kleineren Zeitkomponenten auf ihren kleinsten Wert und liefere das Zeitobjekt zurück.

Example

$ti = Quiq::Time->new(2005,12,28,22,56,37);
$ti->truncate('D');
==>
2005-12-28-00-00-00

Abfrage von Zeitkomponenten

year() - Liefere Jahr

Synopsis

$year = $ti->year;

month() - Liefere Monat (Nummer)

Synopsis

$month = $ti->month;

Description

Liefere die Nummer des Monats. Wertebereich: 1-12.

day() - Liefere Tag des Monats (Nummer)

Synopsis

$day = $ti->day;

dayAbbr() - Abgekürzter Wochentagsname

Synopsis

$str = $ti->dayAbbr;

Description

Liefere abgekürzten Wochentagsnamen (Mo, Di, Mi, Do, Fr, Sa, So).

dayName() - Wochentagsname

Synopsis

$n = $ti->dayName;

Description

Liefere Wochentagsname (Montag, Dienstag, Mittwoch, Donnerstag, Freitag, Samstag, Sonntag).

monthName() - Monatsname

Synopsis

$str = $ti->monthName;

Description

Liefere Monatsnamen (Januar, Februar, ..., Dezember).

dayOfWeek() - Wochentagsnummer

Synopsis

$n = $ti->dayOfWeek;

Description

Liefere Wochentagsnummer im Bereich 1-7, 1 = Montag.

daysOfMonth() - Anzahl der Tage des Monats

Synopsis

$n = $ti->daysOfMonth;

Description

Liefere die Anzahl der Tage des Monats, also 31 für Januar, 28 oder 29 für Februar usw.

dayOfYear() - Tag des Jahres (Nummer)

Synopsis

$n = $ti->dayOfYear;

Description

Liefere die Tagesnummer innerhalb des Jahres.

weekOfYear() - Kalenderwoche (Jahr, Wochennummer)

Synopsis

($year,$n) = $ti->weekOfYear;

Description

Liefere die Kalenderwoche, bestehend aus Jahr und Wochennummer gemäß DIN 1355.

epoch() - Epoch-Zeit

Synopsis

$epoch = $ti->epoch('local');
$epoch = $ti->epoch('utc');
$epoch = $ti->epoch;

Description

Liefere Epoch-Zeit. Ein Aufruf ohne Argument ist äquivalent zu $ti->epoch('utc').

isLeapyear() - Prüfe auf Schaltjahr

Synopsis

$bool = $ti->isLeapyear;

Description

Prüfe, ob Jahr ein Schaltjahr ist. Wenn ja, liefere "wahr", andernfalls "falsch".

Ausgabe von Zeit/Datum

strftime() - Formatiere per strftime formatierte Zeit

Synopsis

$str = $ti->strftime($fmt);

ddmmyyyy() - Liefere formatiertes Datum

Synopsis

$str = $ti->ddmmyyyy;
$str = $ti->ddmmyyyy($sep);

Description

Liefere Datum im Format DD.MM.YYYY, wobei Tag (DD) und Monat (MM) mit führender 0 angegeben werden. Ist $sep angegeben, wird anstelle des Punktes (.) die betreffende Zeichenkette als Trenner verwendet.

ddmmyyyyhhmmss() - Liefere formatiertes Datum+Zeit

Synopsis

$str = $ti->ddmmyyyyhhmmss;

Description

Liefere Datum/Zeit im Format "DD.MM.YYYY HH:MI:SS". Der Aufruf ist äquvalent zu

$str = $ti->ddmmyyyy.' '.$ti->hhmmss;

dmy() - Liefere formatiertes Datum

Synopsis

$str = $ti->dmy;
$str = $ti->dmy($sep);

Description

Liefere Datum im Format D.M.YYYY, wobei Tag (D) und Monat (M) ohne führende 0 angegeben werden. Ist $sep angegeben, wird anstelle des Punktes (.) die betreffende Zeichenkette als Trenner verwendet.

dmyhhmmss() - Liefere formatiertes Datum+Zeit

Synopsis

$str = $ti->dmyhhmmss;

Description

Liefere Datum/Zeit im Format "D.M.YYYY HH:MI:SS". Der Aufruf ist äquvalent zu

$str = $ti->dmy.' '.$ti->hhmmss;

dump() - Liefere Zeitobjekt als Zeichenkette

Synopsis

$str = $ti->dump;
$str = $ti->dump($sep);

Description

Liefere den internen Zustand des Zeitobjekts als Zeichenkette im Format

YYYY-MM-DD-hh-mm-ss

Ist $sep angegeben, verwende diesen String anstelle von '-' als Trenner.

hhmmss() - Liefere formatierte Zeit

Synopsis

$str = $ti->hhmmss;
$str = $ti->hhmmss($sep);

Description

Liefere Zeit im Format HH:MM:SS, wobei alle Angaben zweistellig sind, also ggf. eine führende 0 vorangestellt wird. Ist $sep angegeben, wird anstelle des Doppelpunkts (:) die betreffende Zeichenkette als Trenner verwendet.

hhmm() - Liefere formatierte Zeit

Synopsis

$str = $ti->hhmm;
$str = $ti->hhmm($sep);

Description

Liefere Zeit im Format HH:MM, wobei alle Angaben zweistellig sind, also ggf. eine führende 0 vorangestellt wird. Ist $sep angegeben, wird anstelle des Doppelpunkts (:) die betreffende Zeichenkette als Trenner verwendet.

yymmdd() - Liefere formatiertes Datum

Synopsis

$str = $ti->yymmdd;
$str = $ti->yymmdd($sep);

Description

Liefere Datum im Format YY-MM-DD, wobei das Jahr zweistellig angegeben ist und Tag (DD) und Monat (MM) mit führender 0 angegeben werden. Ist $sep angegeben, wird anstelle des Bindestrichs (-) die betreffende Zeichenkette als Trenner verwendet.

yyyymmdd() - Liefere formatiertes Datum

Synopsis

$str = $ti->yyyymmdd;
$str = $ti->yyyymmdd($sep);

Description

Liefere Datum im Format YYYY-MM-DD, wobei Tag (DD) und Monat (MM) mit führender 0 angegeben werden. Ist $sep angegeben, wird anstelle des Bindestrichs (-) die betreffende Zeichenkette als Trenner verwendet.

yyyymmddhhmmss() - Liefere formatiertes Datum+Zeit

Synopsis

$str = $ti->yyyymmddhhmmss;
$str = $ti->yyyymmddhhmmss($sep);

Alias

iso()

Description

Liefere Datum/Zeit im Format "YYYY-MM-DDXHH:MI:SS", wobei X das Trennzeichen zwischen Datum und Uhrzeit ist. Der Aufruf ist äquvalent zu

$str = $ti->yyyymmdd.$sep.$ti->hhmmss;

Ist $sep nicht angegeben, wird ein Leerzeichen als Trenner genommen.

yyyymmddhhmm() - Liefere formatiertes Datum + Stunde + Minute

Synopsis

$str = $ti->yyyymmddhhmm;
$str = $ti->yyyymmddhhmm($sep);

Description

Liefere Datum/Zeit im Format "YYYY-MM-DDXHH:MI", wobei X das Trennzeichen zwischen Datum und Uhrzeit ist. Der Aufruf ist äquvalent zu

$str = $ti->yyyymmdd.$sep.$ti->hhmm;

Ist $sep nicht angegeben, wird ein Leerzeichen als Trenner genommen.

yyyymmddxhhmmss() - Liefere formatiertes Datum+Zeit mit +-Trenner

Synopsis

$str = $ti->yyyymmddxhhmmss;

Description

Liefere Datum/Zeit im Format "YYYY-MM-DD+HH:MI:SS". Der Aufruf ist äquvalent zu

$str = $ti->yyyymmddhhmmss('+');

Zeitarithmetik

add() - Addiere Zeitkomponenten

Synopsis

$ti = $ti->add($n1,$unit1,$n2,$unit2,...);

Description

Addiere die angegebenen Zeitkomponenten ($nI, $unitI) für Jahr (Y), Monat (M) oder Tag (D) zur Zeit hinzu und liefere das modifizierte Zeitobjekt zurück. Die $nI sind ganze Zahlen, können also auch negativ sein.

Example

$ti = Quiq::Time->new(2005,12,28,22,56,37);
$ti->add(3,'Y',5,'M',-1,'D');
==>
2009-05-27-22-56-37

addYears() - Addiere n Jahre

Synopsis

$ti = $ti->addYears($n);

Description

Addiere $n Jahre zum Zeitobjekt hinzu ($n ist eine ganze Zahl, kann also auch negativ sein) und liefere das modifizierte Zeitobjekt zurück.

Example

  • Jahre hinzuaddieren

    $ti = Quiq::Time->new(2005,12,28,22,56,37);
    $ti->addYears(5);
    ==>
    2010-12-28-00-00-00
  • Jahre abziehen

    $ti = Quiq::Time->new(2005,12,28,22,56,37);
    $ti->addYears(-6);
    ==>
    1999-12-28-00-00-00

addMonths() - Addiere n Monate

Synopsis

$ti = $ti->addMonths($n);

Description

Addiere $n Monate zum Zeitobjekt hinzu ($n ist eine ganze Zahl, kann also auch negativ sein) und liefere das modifizierte Zeitobjekt zurück.

addDays() - Addiere n Tage

Synopsis

$ti = $ti->addDays($n);

Description

Addiere $n Tage zum Zeitobjekt hinzu ($n ist eine ganze Zahl, kann also auch negativ sein) und liefere das modifizierte Zeitobjekt zurück.

addHours() - Addiere n Stunden

Synopsis

$ti = $ti->addHours($n);

Description

Addiere $n Stunden zum Zeitobjekt hinzu ($n ist eine ganze Zahl, kann also auch negativ sein) und liefere das modifizierte Zeitobjekt zurück.

addMinutes() - Addiere n Minuten

Synopsis

$ti = $ti->addMinutes($n);

Description

Addiere $n Minuten zum Zeitobjekt hinzu ($n ist eine ganze Zahl, kann also auch negativ sein) und liefere das modifizierte Zeitobjekt zurück.

addSeconds() - Addiere n Sekunden

Synopsis

$ti = $ti->addSeconds($n);

Description

Addiere $n Sekunden zum Zeitobjekt hinzu ($n ist eine ganze Zahl, kann also auch negativ sein) und liefere das modifizierte Zeitobjekt zurück.

Vergleich von Zeiten

equal() - Prüfe auf Gleichheit

Synopsis

$bool = $ti1->equal($ti2);

Description

Liefere "wahr", wenn der Zeitpunkt $ti1 gleich dem Zeitpunkt $ti2 ist, andernfalls "falsch".

less() - Prüfe auf kleiner

Synopsis

$bool = $ti1->less($ti2);

Description

Liefere "wahr", wenn der Zeitpunkt $ti1 vor dem Zeitpunkt $ti2 liegt, andernfalls "falsch".

lessOrEqual() - Prüfe auf kleinergleich

Synopsis

$bool = $ti1->lessOrEqual($ti2);

Description

Liefere "wahr", wenn der Zeitpunkt $ti1 vor oder gleich dem Zeitpunkt $ti2 ist, andernfalls "falsch".

Zeitdifferenz

diff() - Differenz zweier Zeiten

Synopsis

$dur = $ti1->diff($ti2);

Description

Bilde die Differenz zweier Zeit-Objekte $ti2-$ti1 und liefere ein Zeitdauer-Objekt $dur zurück.

Dauer in Sekunden:

$sec = $dur->asSeconds;

Dauer als Zeichenkette (DdHhMmS.Xs):

$str = $dur->asString;

Konvertierung (Klassenmethoden)

monthAbbrToNum() - Liefere Monatsnummer zu Monats-Abkürzung

Synopsis

$n = $class->monthAbbrToNum($abbr);
$n = $class->monthAbbrToNum($abbr,$lang);

Description

Liefere Monatsnummer (1, ..., 12) zur Monatsabkürzung der Sprache $lang. Default für $lang ist 'en'.

VERSION

1.223

AUTHOR

Frank Seitz, http://fseitz.de/

COPYRIGHT

Copyright (C) 2024 Frank Seitz

LICENSE

This code is free software; you can redistribute it and/or modify it under the same terms as Perl itself.