[GastForen Programme Web/Internet PDF Grundlagen / Web / eForms Zeitdifferenz in PDF-Formular mit JavaScript berechnen

  • Suche
  • Hilfe
  • Lesezeichen
  • Benutzerliste
Web/Internet - Webdesign, eForms
Themen
Beiträge
Moderatoren
Letzter Beitrag

Zeitdifferenz in PDF-Formular mit JavaScript berechnen

Steffen Kernstock
Beiträge gesamt: 105

25. Feb 2013, 18:06
Beitrag # 1 von 8
Bewertung:
(37839 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
Liebes Forum,

jetzt habe ich so lange gesucht und rumprobiert, dass ich aufgebe und auf Euch hoffe ...

Ich habe in einem PDF-Formular zwei Felder mit Namen "UhrzeitA1" und "UhrzeitE1", in die ich Uhrzeiten eingeben möchte im Format "hh:mm", und ein Feld, das mir die Zeitdauer im selben Format ausgeben soll - ich wäre aber auch mit einer Ausgabe im Dezimalformat schon glücklich.

Folgendes Script habe ich mir zusammengestrickt, aber es tut nicht, d.h. das Feld bleibt leer ...

Code
// Startzeit aus Feld "UhrzeitA1" (Format "Zeit HH:MM"): 
UhrzeitA1=this.getField("UhrzeitA1");

// Endezeit aus Feld "UhrzeitE1" (Format "Zeit HH:MM"):
UhrzeitE1=this.getField("UhrzeitE1");

// Startzeit in Minuten seit 00:00h umrechnen:
var StartZeit = Substr(UhrzeitA1,0,2) * 60 + Substr(UhrzeitA1,3,2);

// Endezeit in Minuten seit 00:00h umrechnen:
var EndeZeit = Substr(UhrzeitE1,0,2) * 60 + Substr(UhrzeitE1,3,2);

// Zeitdifferenz in Minuten (auch tagesübergreifend):
var DiffZeit = ((EndeZeit + 24*60) - StartZeit) % (24*60);

// ganze Stunden der Dauer:
var DauerH = Floor(DiffZeit/60);

// Minutenanteil der Dauer:
var DauerM = DiffZeit - (DauerH * 60);

// Ergebnis im Format "hh:mm" zusammensetzen:
var Dauer = Concat(Format("99", DauerH),":",Format("99", DauerM));

{
event.value = Dauer;
}


Täte mir jemand den entscheidenden Tipp geben, was ich falsch mache?

Mac 10.6.8
Acrobat 10.1.4

Vielen Dank im Voraus
Steffen
X

Zeitdifferenz in PDF-Formular mit JavaScript berechnen

taunus11
Beiträge gesamt: 609

26. Feb 2013, 15:46
Beitrag # 2 von 8
Beitrag ID: #509028
Bewertung:
(37743 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
Wo wird das Skript angewendet? Erscheint eine Fehlermeldung?

Bernd Alheit


als Antwort auf: [#508990]

Zeitdifferenz in PDF-Formular mit JavaScript berechnen

Steffen Kernstock
Beiträge gesamt: 105

26. Feb 2013, 16:51
Beitrag # 3 von 8
Beitrag ID: #509033
Bewertung:
(37725 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
Antwort auf [ taunus11 ] Wo wird das Skript angewendet?

Im Textfeld - Eigenschaften: "Berechnung" unter "Benutzerdef. Berechnungsskript"

Antwort auf [ taunus11 ] Erscheint eine Fehlermeldung?

Nö;-)


als Antwort auf: [#509028]

Zeitdifferenz in PDF-Formular mit JavaScript berechnen

taunus11
Beiträge gesamt: 609

26. Feb 2013, 17:33
Beitrag # 4 von 8
Beitrag ID: #509045
Bewertung:
(37709 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
Wenn ich das Skript in Acrobat eingebe, erhalte ich mehrere Fehlermeldungen bzgl. undefinierten Funktionen.

Ich würde folgendes verwenden:
Code
// Startzeit aus Feld "UhrzeitA1" (Format "Zeit HH:MM"):  
UhrzeitA1=this.getField("UhrzeitA1").value;

// Endezeit aus Feld "UhrzeitE1" (Format "Zeit HH:MM"):
UhrzeitE1=this.getField("UhrzeitE1").value;

// Startzeit in Minuten seit 00:00h umrechnen:
var StartZeit = UhrzeitA1.substr(0,2) * 60 + UhrzeitA1.substr(3,2) * 1;

// Endezeit in Minuten seit 00:00h umrechnen:
var EndeZeit = UhrzeitE1.substr(0,2) * 60 + UhrzeitE1.substr(3,2) * 1;

// Zeitdifferenz in Minuten (auch tagesübergreifend):
var DiffZeit = ((EndeZeit + 24*60) - StartZeit) % (24*60);

// ganze Stunden der Dauer:
var DauerH = Math.floor(DiffZeit/60);

// Minutenanteil der Dauer:
var DauerM = DiffZeit - (DauerH * 60);

DauerH = "00" + DauerH;
DauerH = DauerH.substr(-2);

DauerM = "00" + DauerM;
DauerM = DauerM.substr(-2);

// Ergebnis im Format "hh:mm" zusammensetzen:
event.value = DauerH + ":" + DauerM;

Bernd Alheit


als Antwort auf: [#509033]

Zeitdifferenz in PDF-Formular mit JavaScript berechnen

Steffen Kernstock
Beiträge gesamt: 105

27. Feb 2013, 00:14
Beitrag # 5 von 8
Beitrag ID: #509058
Bewertung:
(37674 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
Ah, jetzt komme ich der Sache näher.

Besonders der Trick mit der "Aufpolsterung" des einziffrigen Ergebnisses mit Nullen ist genial.

Nachdem ich dann bei der Eingabe z.B. von "9:00" als Anfangsuhrzeit wieder einen Not-A-Number-Fehler bekam, hab ich dasselbe auf die Uhrzeit-Variablen angewandt und ... es funzt.

Vielen Dank, Bernd!


als Antwort auf: [#509045]

Zeitdifferenz in PDF-Formular mit JavaScript berechnen

schmalen
Beiträge gesamt: 11

28. Feb 2015, 10:01
Beitrag # 6 von 8
Beitrag ID: #537559
Bewertung:
(35430 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
Hallo,

habe noch eine Frage zu deiner Formel, ich weiss lang ist's her, aber immer noch aktuell!

Ich habe deine Formel im Feld eingegeben, und klar es funktioniert einwandfrei, ich weiss zwar wie man in dezimal umrechnen kann anstat 00:15 (0,25) oder eben 00:25 , aber wo genau muss ich das in deiner Formel eingeben?


Start Zeit z.B: 08:00 Endzeit 09:30

Ergebnis in der Zelle wäre 01:30 die Zahl soll aber dezimal ausgegeben werden also 01:25


als Antwort auf: [#509045]

Zeitdifferenz in PDF-Formular mit JavaScript berechnen

micha764
Beiträge gesamt: 4

4. Mai 2023, 09:30
Beitrag # 7 von 8
Beitrag ID: #586036
Bewertung:
(13346 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
Hallo zusammen,

Das Script funktioniert solange man unter 23:59 Stunden im Ergebnis bleibt.
Angenommen ich starte am 04.05.23 um 14:23 Uhr und Ende am 05.05.23 um 16:01 Uhr. Das Ergebnis ist 01:38. Richtig wäre 25:38

Wie kann ich dieses Problem lösen.

Vielen Dank

Micha


als Antwort auf: [#509045]

Zeitdifferenz in PDF-Formular mit JavaScript berechnen

taunus11
Beiträge gesamt: 609

9. Mai 2023, 15:25
Beitrag # 8 von 8
Beitrag ID: #586055
Bewertung:
(13217 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
Wenn es über mehrere Tage geht, muss auch auch das Datum und nicht nur die Uhrzeit berücksichtigt werden.


als Antwort auf: [#586036]
X