getdate
Current datetime or POSIX timestamp from computer's clock. Datetimes from given timestamps
Syntax
curDatetime = getdate() timeStamp = getdate("s") dateTimes = getdate(timeStamps)
Arguments
- curDatetime
- vector of integers with
Index 1 2 3 4 5 6 7 8 9 10 Content year month week yearday weekday monthday hour minute second millisecond Range ≥ 1970 [1,12] [1,53] [1,366] [1,7] 1=sunday [1,31] [0,23] [0,59] [0,59] [0,999] - timeStamp
- integer number of seconds elapsed since 1970-01-01 00:00:00 UTC, excluding leap seconds, as defined by the POSIX standard (see description).
- timeStamps
- Array of positive decimal numbers representing POSIX timestamps. Negative timestamps are not accepted.
- dateTimes
- length(timeStamps)-by-10 Matrix: The row #i elements are datetime data
corresponding to timeStamps(i), as documented for
curDatetime
, except thatdateTimes(:,10)
are fractions of second in [0,1) instead of milliseconds. dateTimes are expressed in the current computer's time zone.
Description
getdate() returns the current datetime of the computer's clock, expressed in the Gregorian calendar, and for the computer's time zone + possible daylight saving offset.
Nowadays, most of computers are automatically synchronized with the legal time for the considered time zone, through time servers. Legal datetimes are synchronized on the Coordinated Universal Time (UTC), by a known time zone (and daylight saving) offset.
getdate("s") reads the computer's clock
and returns the corresponding POSIX timestamp. This corresponds to the number
of seconds elapsed since 1970-01-01 00:00:00 UTC, except that leap seconds
are not counted. Hence, if n = getdate("s")
is run at an
exact round hour, modulo(n, 3600)
will return 0 instead
of cumulated leap seconds
added since 1972 (27s, up to 2020).
getdate(timeStamps) returns the status of the
local computer's clock for the given POSIX time stamps, that may include fractional
seconds. If any, the computer's current Daylight Saving offset is never considered.
getdate(0)
will return 1970-01-01 00:00:00
only if the clock is set for the time zone = 0. Otherwise, for instance for
Scilab users living in Bélem, Brazil, UTC-3, getdate(0)
returns
1969-12-31 21:00:00, actually corresponding to 1970-01-01 00:00:00 POSIX.
Examples
D = getdate() mprintf("%d-%02d-%02d %02d:%02d:%06.3f\n", D(1), D(2), D(6:8), D(9)+D(10)/1000); x = getdate("s"); mprintf("%.2f\n", x) D = getdate(0) mprintf("%d-%02d-%02d %02d:%02d:%06.3f\n", D(1), D(2), D(6:8), D(9)+D(10)/1000);
--> D = getdate() D = 2020. 7. 30. 208. 1. 26. 23. 8. 28. 474. --> mprintf("%d-%02d-%02d %02d:%02d:%06.3f\n", D(1), D(2), D(6:8), D(9)+D(10)/1000); 2020-07-26 23:08:28.474 --> x = getdate("s"); --> mprintf("%.2f\n", x) 1595797708.00 --> D = getdate(0) D = 1970. 1. 1. 1. 5. 1. 1. 0. 0. 0. --> mprintf("%d-%02d-%02d %02d:%02d:%06.3f\n", D(1), D(2), D(6:8), D(9)+D(10)/1000); 1970-01-01 01:00:00.000
getdate("s") ignores leap seconds:
s = 1; // Expecting the next round minute @ your clock. Please be patient.. while s <> 0 D = getdate(); x = getdate("s"); s = D(9); sleep(300) // ms. To not use 100% of your processor end // If leap seconds are taken into account, they would appear here (27, in 2020): modulo(x, 60)
--> modulo(x, 60) ans = 0.
getdate([1e9, 2e9, 3e9] + 0.21) // Note the fractional seconds
--> getdate([1e9, 2e9, 3e9] + 0.21) ans = 2001. 9. 36. 252. 1. 9. 3. 46. 40. 0.21 2033. 5. 20. 138. 4. 18. 5. 33. 20. 0.21 2065. 1. 4. 24. 7. 24. 6. 20. 0. 0.21
See also
Report an issue | ||
<< etime | Data e Hora | now >> |