I need something simple like date
, but in seconds since 1970 instead of the current date, hours, minutes, and seconds.
date
doesn't seem to offer that option. Is there an easy way?
This should work:
date +%s
Just to add. Get the seconds since epoch(Jan 1 1970) for any given date(e.g Oct 21 1973).
date -d "Oct 21 1973" +%s
Convert the number of seconds back to date
date --date @120024000
The command date
is pretty versatile. Another cool thing you can do with date(shamelessly copied from date --help
). Show the local time for 9AM next Friday on the west coast of the US
date --date='TZ="America/Los_Angeles" 09:00 next Fri'
Better yet, take some time to read the man page http://man7.org/linux/man-pages/man1/date.1.html
date
or because I'm using zsh
(macOS Catalina) but this doesn't work for me. Running $ date -d "Oct 21 1973" +%s
outputs usage: date [-jnRu] [-d dst] [-r seconds] [-t west] [-v[+|-]val[ymwdHMS]] ... [-f fmt date | [[[mm]dd]HH]MM[[cc]yy][.ss]] [+format]
man date
shows that the option(s) used to parse another date string are -j
and -f expectedformat
on macOS. (-d
is used to set daylight savings.)
date
command above is from gnu coreutils pacakge. On mac, gnu coreutils package can be installed with brew or macports. After installing, the binary is named as gdate
to distinguish it from macOS's preinstalled /bin/date
date -r 120024000
Pure bash solution
Since bash
5.0 (released on 7 Jan 2019) you can use the built-in variable EPOCHSECONDS
.
$ echo $EPOCHSECONDS
1547624774
There is also EPOCHREALTIME
which includes fractions of seconds.
$ echo $EPOCHREALTIME
1547624774.371210
EPOCHREALTIME
can be converted to micro-seconds (μs) by removing the decimal point. This might be of interest when using bash
's built-in arithmetic (( expression ))
which can only handle integers.
$ echo ${EPOCHREALTIME/./}
1547624774371210
In all examples from above the printed time values are equal for better readability. In reality the time values would differ since each command takes a small amount of time to be executed.
date +%s%3N
) you can use echo $(( ${EPOCHREALTIME/./} / 1000 ))
So far, all the answers use the external program date
.
Since Bash 4.2, printf
has a new modifier %(dateformat)T
that, when used with argument -1
outputs the current date with format given by dateformat
, handled by strftime(3)
(man 3 strftime
for informations about the formats).
So, for a pure Bash solution:
printf '%(%s)T\n' -1
or if you need to store the result in a variable var
:
printf -v var '%(%s)T' -1
No external programs and no subshells!
Since Bash 4.3, it's even possible to not specify the -1
:
printf -v var '%(%s)T'
(but it might be wiser to always give the argument -1
nonetheless).
If you use -2
as argument instead of -1
, Bash will use the time the shell was started instead of the current date. This can be used to compute elapsed times
$ printf -v beg '%(%s)T\n' -2
$ printf -v now '%(%s)T\n' -1
$ echo beg=$beg now=$now elapsed=$((now-beg))
beg=1583949610 now=1583953032 elapsed=3422
-2
in case you have a longer running job (think of a script to control you backups) and send a mail in the end "Backup started at $somewhen completed at $now" - which can be accomplished with -2
avoiding to store a dedicated variable at the beginning.
With most Awk implementations:
awk 'BEGIN {srand(); print srand()}'
srand()
are typically seeded with the current date/time. The second call to srand()
returns the value previously used as the seed.
This is an extension to what @pellucide has done, but for Macs:
To determine the number of seconds since epoch (Jan 1 1970) for any given date (e.g. Oct 21 1973)
$ date -j -f "%b %d %Y %T" "Oct 21 1973 00:00:00" "+%s"
120034800
Please note, that for completeness, I have added the time part to the format. The reason being is that date
will take whatever date part you gave it and add the current time to the value provided. For example, if you execute the above command at 4:19PM, without the '00:00:00' part, it will add the time automatically. Such that "Oct 21 1973" will be parsed as "Oct 21 1973 16:19:00". That may not be what you want.
To convert your timestamp back to a date:
$ date -j -r 120034800
Sun Oct 21 00:00:00 PDT 1973
Apple's man page for the date implementation: https://developer.apple.com/library/mac/documentation/Darwin/Reference/ManPages/man1/date.1.html
date
command, whereas any solutions suggesting date -d
are for GNU date
. BSD date in macOS comes from FreeBSD, and shares a number of options with NetBSD and OpenBSD. And this is entirely separate from bash.
%N
option mentioned for fractional seconds in gnu date is missing from MacOS date. On 10.14, none of the formats are in the man page; they're in the strftime(3)
man page, which you won't have if you don't have Xcode installed, and might not see with man command even if you do.
use this bash script (my ~/bin/epoch
):
#!/bin/bash
# get seconds since epoch
test "x$1" == x && date +%s && exit 0
# or convert epoch seconds to date format (see "man date" for options)
EPOCH="$1"
shift
date -d @"$EPOCH" "$@"
Success story sharing
%s seconds since 1970-01-01 00:00:00 UTC
to%s seconds since the epoch, 1970-01-01 00:00:00 UTC
because I missed it in there.date
is not built intobash
, so your version ofbash
has nothing to do with whichdate
implementation your system ships with.date +%s.%N
date +%s%3N