Lo zero e una data di nascita
Un timestamp pari a 0 indica l'inizio esatto della Unix Epoch: 1970-01-01T00:00:00Z (UTC).
Un timestamp pari a 0 indica l'inizio esatto della Unix Epoch: 1970-01-01T00:00:00Z (UTC).
10 cifre = secondi; 13 cifre = millisecondi. Aggiungi o rimuovi tre zeri per passare da una unita all'altra.
I timestamp sono indipendenti dal fuso orario. Londra, New York o Tokyo mostrano orari locali diversi, ma e lo stesso istante.
Il 2038-01-19 03:14:07 UTC, i contatori a 32 bit in secondi vanno in overflow. I moderni sistemi a 64 bit evitano questo problema.
In ISO-8601, la Z finale (es.: 2025-03-01T10:30:00Z) indica UTC, cioe lo stesso orario ovunque.
Un timestamp UNIX (spesso chiamato epoch time) e un numero singolo che indica quanto tempo
e trascorso dalla Unix Epoch: 1970-01-01T00:00:00Z (UTC). E molto usato in log,
database e API perche e compatto, ordinabile e indipendente dal fuso orario.
1700000000)1700000000000)1700000000000000)-31536000 → 1969-01-01T00:00:00Z).2147483647 → 2038-01-19T03:14:07Z. I sistemi moderni usano 64 bit e non hanno questo limite.| Significato | Secondi | Millisecondi | UTC (ISO-8601) |
|---|---|---|---|
| Inizio Epoch | 0 |
0 |
1970-01-01T00:00:00Z |
| Un miliardo di secondi | 1000000000 |
1000000000000 |
2001-09-09T01:46:40Z |
| Confine 2038 (32 bit) | 2147483647 |
2147483647000 |
2038-01-19T03:14:07Z |
| Esempio era attuale | 1600000000 |
1600000000000 |
2020-09-13T12:26:40Z |
2025-03-01T10:30:00Z o con offset (es.: +01:00).2025-03-01 10:30:00 → local time2025-03-01T10:30:00Z → UTC (la Z finale indica Zulu/UTC)2025-03-01T10:30:00+05:30 → UTC+5:301,000,000 per ottenere i millisecondi.Date, browser e gran parte del codice front-end.Date in JS.Snippet copia-incolla per operazioni comuni: epoch corrente, data leggibile → epoch, epoch → data.
// current epoch
const s = Math.floor(Date.now() / 1000); // seconds
const ms = Date.now(); // milliseconds
// date → epoch
const dt = new Date("2025-03-01T10:30:00Z");
const epochSeconds = Math.floor(dt.getTime() / 1000);
// epoch → date
const d1 = new Date(1700000000 * 1000); // seconds → ms
const d2 = new Date(1700000000000); // ms
import time, datetime, calendar
# current epoch
sec = time.time() # float seconds
ms = round(time.time()*1000)
# date → epoch (UTC)
dt = datetime.datetime(2025, 3, 1, 10, 30, tzinfo=datetime.timezone.utc)
epoch_seconds = int(dt.timestamp())
# epoch → date (UTC)
dt2 = datetime.datetime.fromtimestamp(1700000000, tz=datetime.timezone.utc)
import java.time.*;
long sec = Instant.now().getEpochSecond(); // current epoch (s)
long ms = Instant.now().toEpochMilli(); // current epoch (ms)
// date → epoch
Instant ins = Instant.parse("2025-03-01T10:30:00Z");
long epochSeconds = ins.getEpochSecond();
// epoch → date
Instant ins2 = Instant.ofEpochSecond(1700000000);
ZonedDateTime zdt = ins2.atZone(ZoneId.of("UTC"));
using System;
long sec = DateTimeOffset.UtcNow.ToUnixTimeSeconds();
long ms = DateTimeOffset.UtcNow.ToUnixTimeMilliseconds();
// date → epoch
var dto = new DateTimeOffset(2025, 3, 1, 10, 30, 0, TimeSpan.Zero);
long epochSeconds = dto.ToUnixTimeSeconds();
// epoch → date
var dto2 = DateTimeOffset.FromUnixTimeSeconds(1700000000); // UTC
package main
import ("fmt"; "time")
func main() {
sec := time.Now().Unix() // seconds
ms := time.Now().UnixMilli() // milliseconds
// date → epoch (UTC)
t, _ := time.Parse(time.RFC3339, "2025-03-01T10:30:00Z")
fmt.Println(t.Unix())
// epoch → date
t2 := time.Unix(1700000000, 0).UTC()
fmt.Println(t2.Format(time.RFC3339))
}
// current epoch
$sec = time(); // seconds
$ms = round(microtime(true)*1000);
// date → epoch (UTC recommended)
$dt = new DateTime("2025-03-01T10:30:00Z");
$epoch = $dt->getTimestamp();
// epoch → date
$dt2 = (new DateTime())->setTimestamp(1700000000)->setTimezone(new DateTimeZone("UTC"));
echo $dt2->format(DATE_RFC3339);
# current epoch
s = Time.now.to_i # seconds
ms = (Time.now.to_f*1000).to_i
# date → epoch (UTC)
t = Time.utc(2025,3,1,10,30,0)
s2 = t.to_i
# epoch → date
t2 = Time.at(1700000000).utc
use std::time::{SystemTime, UNIX_EPOCH, Duration};
// current epoch
let now = SystemTime::now().duration_since(UNIX_EPOCH).unwrap();
let sec = now.as_secs();
let ms = now.as_millis();
// epoch → date (example with chrono)
use chrono::{DateTime, Utc, TimeZone};
let d: DateTime<Utc> = Utc.timestamp_opt(1_700_000_000, 0).unwrap();
import java.time.Instant
import java.time.ZoneId
val sec = Instant.now().epochSecond
val ms = Instant.now().toEpochMilli()
// date → epoch
val ins = Instant.parse("2025-03-01T10:30:00Z")
val epochSeconds = ins.epochSecond
// epoch → date
val zdt = Instant.ofEpochSecond(1700000000).atZone(ZoneId.of("UTC"))
import Foundation
let sec = Int(Date().timeIntervalSince1970) // seconds
let ms = Int(Date().timeIntervalSince1970 * 1000)
// date → epoch (ISO8601)
let iso = ISO8601DateFormatter().date(from: "2025-03-01T10:30:00Z")!
let epoch = Int(iso.timeIntervalSince1970)
// epoch → date
let d = Date(timeIntervalSince1970: 1700000000)
#include <chrono>
using namespace std::chrono;
// current epoch
auto now = system_clock::now();
auto sec = duration_cast<seconds>(now.time_since_epoch()).count();
auto ms = duration_cast<milliseconds>(now.time_since_epoch()).count();
// epoch → time_point
auto tp = system_clock::time_point{seconds{1700000000}};
# current epoch
date +%s # seconds
python3 - <<'PY'\nimport time; print(round(time.time()*1000))\nPY # ms fallback
# date → epoch (UTC)
date -u -d "2025-03-01 10:30:00" +%s
# epoch → date (local or -u for UTC)
date -d @1700000000
# current epoch
$sec = [int][double]::Parse((Get-Date (Get-Date).ToUniversalTime() -UFormat %s))
$ms = [int]([DateTimeOffset]::UtcNow.ToUnixTimeMilliseconds())
# epoch → date
[DateTimeOffset]::FromUnixTimeSeconds(1700000000).UtcDateTime
-- current epoch (seconds)
SELECT EXTRACT(EPOCH FROM NOW());
-- date → epoch (UTC)
SELECT EXTRACT(EPOCH FROM TIMESTAMP '2025-03-01 10:30:00+00');
-- epoch → timestamp
SELECT TO_TIMESTAMP(1700000000) AT TIME ZONE 'UTC';
-- current epoch
SELECT UNIX_TIMESTAMP();
-- date → epoch (assumes UTC string if suffixed with 'Z')
SELECT UNIX_TIMESTAMP('2025-03-01 10:30:00');
-- epoch → datetime
SELECT FROM_UNIXTIME(1700000000);
Suggerimento: preferisci stringhe ISO-8601 (es.: 2025-03-01T10:30:00Z) per UTC senza ambiguita. Se un'API si aspetta secondi ma hai millisecondi, dividi per 1000 (e moltiplica per l'operazione inversa).
No. Il timestamp codifica un istante assoluto; cambia solo la visualizzazione in base al fuso orario o all'ora legale.
I sistemi back-end e le API usano spesso i secondi; browser e JavaScript usano tipicamente i millisecondi. Questo strumento gestisce entrambi.
Si. Usa l'output UTC per stringhe in stile ISO-8601 come YYYY-MM-DDTHH:mm:ssZ.
Si. Tutto viene calcolato nel browser, senza richieste di rete per le conversioni.