2009-12-02 4 views
3

Я работаю над системой, связанной с записью телевизора.18-разрядная временная метка?

Я разбор следующего 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" /> 

Мой вопрос, кто-нибудь признает формат временной метки атрибутов время_запуска и конечный момент? Я думал, что временные метки для второго имеют 10 цифр, так где же остальные 8? Мое предположение - это то, что напоминает часовой пояс и миллисекундную точность.

Я использую php, поэтому особый способ преобразования его в datetime был бы приятным, но все хорошо.

+0

Timestamps подсчет миллисекунды из эпохи в настоящее время имеют 10 цифр , После того, как были отметки 3/4/5/6/etc в метку «сейчас». – laura

ответ

8

Похоже, С # DateTime клещей:

Тип значения DateTime представляет даты и времени со значениями в диапазоне от 12:00:00 полночь, 1 января 0001 Anno Domini (Common Era) через 11:59:59 PM, 31 декабря, 9999 AD (CE)

Эта линия:

Console.WriteLine (new DateTime (633936042047633656)); 

печатает:

11/12/2009 6:30:04 AM

Если вам нужно конвертировать из этих чисел в Unix времени, 621355968000000000L вычесть, который является Unix эпохи выражается в клещей.

+0

Хмм, без 64-битного int в PHP, который может быть проблемой: P Ну, я найду способ. –

+0

Не должно быть слишком сложно сделать эту математику в 32 битах, с небольшим количеством предварительной обработки строк. Сначала «разделите» на миллион, удалив последние 6 символов строки, затем удалите ведущий «6». Затем вычитаем 2 из первой цифры строки. Теперь преобразуем то, что осталось в 32-битное целое, и вычтем 1355968000. – MSalters

2

С ГМПОМ Lib установлен в PHP вы можете сделать это следующим образом:

$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); 
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; 
Смежные вопросы