18位数的时间戳?

时间:2009-12-02 12:50:50

标签: php xml timestamp

我正在研究与电视录制相关的系统。

我正在从另一个系统解析以下xml(我没有文档):

<Program FileName="2009.11.07-Saturday 07 November 2009.dvr-ms" SubChannel="ABC1" StartTime="633931722046825183" StopTime="633932388000119414" ActualStopTime="633932388016825183" ShareShow="True" />
<Program FileName="2009.11.08-Sunday 08 November 2009.dvr-ms" SubChannel="ABC1" StartTime="633932586046773253" StopTime="633933252000157907" ActualStopTime="633933252006773253" ShareShow="True" />
<Program FileName="2009.11.09-Monday 09 November 2009.dvr-ms" SubChannel="ABC1" StartTime="633933450046168953" StopTime="633934116000207688" ActualStopTime="633934116026168953" ShareShow="True" />
<Program FileName="2009.11.10-Tuesday 10 November 2009.dvr-ms" SubChannel="ABC1" StartTime="633934314046899495" StopTime="633934980000869533" ActualStopTime="633934980096899495" ShareShow="True" />
<Program FileName="2009.11.11-Wednesday 11 November 2009.dvr-ms" SubChannel="ABC1" StartTime="633935178054202612" StopTime="633935844000077447" ActualStopTime="633935844064202612" ShareShow="True" />
<Program FileName="2009.11.12-Thursday 12 November 2009.dvr-ms" SubChannel="ABC1" StartTime="633936042047633656" StopTime="633936708000009191" ActualStopTime="633936708047633656" ShareShow="True" />

我的问题是,有没有人认识到StartTime和StopTime属性的时间戳格式?我认为通常时间戳到第二个有10个数字,所以其他8个来自哪里?我的猜测类似于时区和毫秒精度。

我正在使用php,所以将PHP转换为日期时间的PHP特定方式会很好,但是一切都很好。

3 个答案:

答案 0 :(得分:9)

看起来像C#的DateTime标记:

  

DateTime值类型表示   具有值范围的日期和时间   从1月1日午夜12点开始,   0001 Anno Domini(Common Era)通过   公元9999年12月31日晚上11:59:59   (C.E。)

这一行:

Console.WriteLine (new DateTime (633936042047633656));

打印:

  

11/12/2009 6:30:04 AM

如果您需要将这些数字转换为Unix时间,请减去621355968000000000L,即 ticks 中表示的Unix纪元。

答案 1 :(得分:2)

在php中安装gmp lib你可以这样做:

$epoch     = '621355968000000000';
$newtime   = gmp_sub($dateTime, $epoch);
$newtime   = gmp_div($newtime, '10000000');
$timestamp = gmp_strval($newtime);

现在你有个约会对象:

echo date('Y-m-d H:i:s', $timestamp);

答案 2 :(得分:1)

$dateLargeInt= "131424999530821857";
$secsAfterADEpoch = $dateLargeInt / (10000000); 
$ADToUnixConvertor=((1970-1601) * 365.242190) * 86400;
// unix epoch - AD epoch * number of tropical days * seconds in a day 
$unixTsLastLogon=intval($secsAfterADEpoch-$ADToUnixConvertor); 

// unix Timestamp version of AD timestamp
$lastlogon=date("d-m-Y", $unixTsLastLogon); // formatted date

echo $lastlogon;