![]() |
Sekunden seit 1. Januar 0:00 1970
So ich bekomme die Sekunden die seit obigen Datum verstrichen sind. Jetzt würde ich gerne diese in ein gescheites Datum umrechnen.
Für ersteres habe ich schon einen Ansatz:
Delphi-Quellcode:
Nur leider stimmt das:
procedure TForm1.ListBox1Click(Sender: TObject);
const TAB = #9; var sUser : String; ui11 : Pointer; ft : TFILETIME; st : TSYSTEMTIME; ui : ULARGE_INTEGER; buf1, buf2 : array[0..255] of Char; begin st.wYear := 1970; st.wMonth := 1; st.wDayOfWeek := 0; st.wDay := 1; st.wHour := 0; st.wMinute := 0; st.wSecond := 0; st.wMilliseconds := 0; SystemTimeToFileTime(st,ft); ui.QuadPart := PUserInfo11(ui11)^.usri11_last_logon+ULARGE_INTEGER(ft).QuadPart; FileTimeToSystemTime(TFileTime(ui),st); GetTimeFormat(LOCALE_USER_DEFAULT, TIME_FORCE24HOURFORMAT, @st, nil, buf1, sizeof(buf1)); GetDateFormat(LOCALE_USER_DEFAULT, DATE_SHORTDATE, @st, nil, buf2, sizeof(buf2)); Memo1.Lines.Add('Last-Logon'+TAB+': '+String(buf2)+' / '+String(buf1) ); end; NetAPIBufferFree(ui11); end; Zitat:
|
Hallo Luckie,
ich war da schon geboren und bin sogar schon zur Schule gegangen. Deshalb kann ich vielleicht helfen :mrgreen: .
Delphi-Quellcode:
with st do begin Datum := EncodeDate(year, month, Day); Zeit := EncodeTime(Hour, Minute, Second, Milliseconds); end; |
Ändert sich was, wenn du den DWORD-Wert als int64 castest, Luckie?
Wie bei INetTime:
Code:
ui.QuadPart := int64(PUserInfo11(ui11)^.usri11_last_logon) +
ULARGE_INTEGER(ft).QuadPart; |
@MrSpock: Kann ich leider nicht brauchen, da es später nonVCL werden soll.
@Mathias: Hilft leider aich nicht. Aber ich habe was gefunden.
Delphi-Quellcode:
RaisLastOSError liefert: "Aufruf einer Systemfunktion fehlgeschlagen." Und das stimmt auch mit meiner Beobachtung über ein. Als Datum bekomme ich nämlich immer das, was ich in die Struktur eintrage.
st.wYear := 1970;
st.wMonth := 1; st.wDayOfWeek := 0; st.wDay := 1; st.wHour := 0; st.wMinute := 0; st.wSecond := 0; st.wMilliseconds := 0; SystemTimeToFileTime(st,ft); RaiseLastOsError; |
Du willst also einen UNIX-Timestamp in eine lesbare Zeitangabe umrechnen? Das hatten wir hier schon mal:
![]() |
Danke für den Hinweis. Da gibt es nur ein Probleme, wie ich schon zu Spitzohr gesagt habe, es muß ohne SysUtils gehen.
Der Hinweis von Christian auf die Stelle im PSDK hab eich gefunden, nur leider kennt Delphi kein Int32x32To64. Zitat:
Code:
void TimetToFileTime( time_t t, LPFILETIME pft )
{ LONGLONG ll = Int32x32To64(t, 10000000) + 116444736000000000; pft->dwLowDateTime = (DWORD) ll; pft->dwHighDateTime = ll >>32; } |
Luckie, schon mal in die "WinNT.h" geguckt?
Code:
Oder, wenn mich mein bisschen Wissen nicht trügt:
#define Int32x32To64(a, b) ((LONGLONG)((LONG)(a)) * (LONGLONG)((LONG)(b)))
Delphi-Quellcode:
Und zu dem "nichts bringen": vielleicht fehlt in der Logon-Zeit auch das 10-Mio-Intervall? Sprich die Anzahl der 100ns-Intervalle?
function Int32x32To64(const a, b: dword): int64;
begin Result := int64(a) * int64(b); end; |
ja, ja, jaaaaa. :P Mathias du bist ein Schatz. :stupid:
Halt alles zurück. Da stimmt was nicht. Noch mal von vorne. Das habe ich jetzt:
Delphi-Quellcode:
Jetzt bin ich schon seit 1601-01-01 / 00:00:00 eingeloggt. :shock:
function Int32x32To64(const a, b: dword): int64;
begin Result := int64(a) * int64(b); end; procedure TForm1.ListBox1Click(Sender: TObject); const TAB = #9; var sUser : String; ui11 : Pointer; ft : TFILETIME; st : TSYSTEMTIME; ui : ULARGE_INTEGER; li : longint; buf1, buf2 : array[0..255] of Char; begin Memo1.Clear; sUser := Listbox1.Items.Strings[Listbox1.ItemIndex]; if sUser <> ''then begin NetUserGetInfo(nil, PWideChar(WideString(sUser)), 11, ui11); {st.wYear := 1970; st.wMonth := 1; st.wDayOfWeek := 0; st.wDay := 1; st.wHour := 0; st.wMinute := 0; st.wSecond := 0; st.wMilliseconds := 0; SystemTimeToFileTime(st,ft); ui.QuadPart := int64(PUserInfo11(ui11)^.usri11_last_logon)+ULARGE_INTEGER(ft).QuadPart; FileTimeToSystemTime(TFileTime(ui),st);} li := Int32x32To64(PUserInfo11(ui11)^.usri11_last_logon, 10000000) + 116444736000000000; ft.dwLowDateTime := DWORD(li); ft.dwHighDateTime := li shl 32; FileTimeToSystemTime(TFileTime(ui),st); GetTimeFormat(LOCALE_USER_DEFAULT, TIME_FORCE24HOURFORMAT, @st, nil, buf1, sizeof(buf1)); GetDateFormat(LOCALE_USER_DEFAULT, DATE_SHORTDATE, @st, nil, buf2, sizeof(buf2)); Memo1.Lines.Add('Last-Logon'+TAB+': '+String(buf2)+' / '+String(buf1) ); end; NetAPIBufferFree(ui11); end; |
![]() schau dir mal Punkt 10.1 an. Bei korrekten Eingabewerten sollte damit auch eine richtige Umrechnung ohne VCL möglich sein. |
Danke für den Link. Aber es muß auch so mit API-Funktionen gehen.
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 07:01 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz