Unix时间戳(Unix timestamp)在线转换 |
|
当前北京时间是 |
实时标准时间: |
|
现在的Unix时间戳(Unix timestamp)是 |
Unix时间戳(Unix timestamp): |
秒(s) |
|
毫秒(ms) |
|
Unix时间戳(Unix timestamp)转北京时间 |
|
Unix时间戳(Unix timestamp): |
|
转换后北京时间: |
|
|
标准时间转换Unix时间戳(Unix timestamp) |
|
标准时间: |
|
转换后Unix时间戳(Unix timestamp): |
|
|
什么是Unix时间戳(Unix timestamp)? |
Unix时间戳(Unix timestamp),或称Unix时间(Unix time)、POSIX时间(POSIX time),是一种时间表示方式,定义为从格林威治时间1970年01月01日00时00分00秒起至现在的总秒数。Unix时间戳不仅被使用在Unix 系统、类Unix系统中,也在许多其他操作系统中被广泛采用。
目前相当一部分操作系统使用32位二进制数字表示时间。此类系统的Unix时间戳最多可以使用到格林威治时间2038年01月19日03时14分07秒(二进制:01111111 11111111 11111111 11111111)。其后一秒,二进制数字会变为10000000 00000000 00000000 00000000,发生溢出错误,造成系统将时间误解为1901年12月13日20时45分52秒。这很可能会引起软件故障,甚至是系统瘫痪。使用64位二进制数字表示时间的系统(最多可以使用到格林威治时间292,277,026,596年12月04日15时30分08秒)则基本不会遇到这类溢出问题。 |
如何在不同编程语言中获取现在的Unix时间戳(Unix timestamp)? |
|
Java |
time |
JavaScript |
Math.round(new Date().getTime()/1000)
getTime()返回数值的单位是毫秒
|
Microsoft .NET / C# |
epoch = (DateTime.Now.ToUniversalTime().Ticks - 621355968000000000) /
10000000
|
MySQL |
SELECT unix_timestamp(now()) |
Perl |
time |
PHP |
time() |
PostgreSQL |
SELECT extract(epoch FROM now()) |
Python |
先 import time 然后 time.time() |
Ruby |
获取Unix时间戳:Time.now 或 Time.new
显示Unix时间戳:Time.now.to_i
|
Go |
先 import time 然后 int32(time.Now().Unix())
|
SQL Server |
SELECT DATEDIFF(s, '1970-01-01 00:00:00', GETUTCDATE()) |
Unix / Linux |
date +%s |
VBScript / ASP |
DateDiff("s", "01/01/1970 00:00:00", Now()) |
其他操作系统
(如果Perl被安装在系统中)
|
命令行状态:perl -e "print time" |
|
如何在不同编程语言中实现Unix时间戳(Unix timestamp) → 普通时间? |
Java |
String date = new java.text.SimpleDateFormat("dd/MM/yyyy
HH:mm:ss").format(new java.util.Date(Unix timestamp * 1000))
|
JavaScript |
先 var unixTimestamp = new Date(Unix timestamp *
1000) 然后 commonTime = unixTimestamp.toLocaleString()
|
Linux |
date -d @Unix timestamp |
MySQL |
from_unixtime(Unix timestamp) |
Perl |
先 my $time = Unix timestamp 然后 my
($sec, $min, $hour, $day, $month, $year) = (localtime($time))[0,1,2,3,4,5,6]
|
PHP |
date('r', Unix timestamp) |
PostgreSQL |
SELECT TIMESTAMP WITH TIME ZONE 'epoch' + Unix timestamp) *
INTERVAL '1 second';
|
Python |
先 import time 然后 time.gmtime(Unix
timestamp)
|
Ruby |
Time.at(Unix timestamp) |
SQL Server |
DATEADD(s, Unix timestamp, '1970-01-01 00:00:00') |
VBScript / ASP |
DateAdd("s", Unix timestamp, "01/01/1970 00:00:00") |
其他操作系统
(如果Perl被安装在系统中)
|
命令行状态:perl -e "print scalar(localtime(Unix
timestamp))"
|
|
如何在不同编程语言中实现普通时间 → Unix时间戳(Unix timestamp)? |
Java |
long epoch = new java.text.SimpleDateFormat("dd/MM/yyyy
HH:mm:ss").parse("01/01/1970 01:00:00");
|
JavaScript |
var commonTime = new Date(Date.UTC(year, month - 1, day,
hour, minute, second))
|
MySQL |
SELECT unix_timestamp(time)
时间格式: YYYY-MM-DD HH:MM:SS 或 YYMMDD 或 YYYYMMDD
|
Perl |
先 use Time::Local 然后 my $time =
timelocal($sec, $min, $hour, $day, $month, $year);
|
PHP |
mktime(hour, minute, second, month,
day, year)
|
PostgreSQL |
SELECT extract(epoch FROM date('YYYY-MM-DD HH:MM:SS')); |
Python |
先 import time 然后
int(time.mktime(time.strptime('YYYY-MM-DD HH:MM:SS', '%Y-%m-%d %H:%M:%S')))
|
Ruby |
Time.local(year, month, day, hour, minute,
second)
|
SQL Server |
SELECT DATEDIFF(s, '1970-01-01 00:00:00', time) |
Unix / Linux |
date +%s -d"Jan 1, 1970 00:00:01" |
VBScript / ASP |
DateDiff("s", "01/01/1970 00:00:00", time) |
|
Unix 时间戳是从1970年1月1日(UTC/GMT的午夜)开始所经过的秒数,不考虑闰秒。
Unix 时间戳(英文为 Unix epoch, Unix time, POSIX time 或 Unix timestamp)
UNIX时间戳的 0 按照 ISO 8601 规范为 :1970-01-01T00:00:00Z.
一个小时表示为UNIX时间戳格式为:3600秒;一天表示为UNIX时间戳为86400秒,闰秒不计算。
在大多数的 Unix 系统中 Unix 时间戳存储为 32 位,这样会引发 2038 年问题或 Y2038。 |