Преобразование PHP date() в последовательный формат Excel

#php

#php

Вопрос:

Я искал уже несколько часов. Везде я вижу примеры того, как преобразовать номер серийной даты Excel в UNIX_Date.

Что я хочу сделать, так это PHP date («Y-m-d H: i: s»), чтобы преобразовать его в номер серийной даты Excel.

Пример:

 $php_date = date("Y-m-d H:i:s"); // "2019-04-18 11:57:25" at the time
 

и если я введу это «2019-04-18 11:57:25» в ячейку Excel и отформатирую ее, чтобы отобразить число, тогда Excel покажет мне «43573.4982060185»
Как получить это «43573.4982060185» в PHP?

РЕДАКТИРОВАТЬ: согласно приведенному ниже ответу Моргана, теперь у меня есть функция, которая делает это: РЕДАКТИРОВАТЬ 2: Добавлен часовой пояс, установленный для получения моего местного времени, если кому-то еще это нужно, установите для вашего местного часового пояса. Список поддерживаемых часовых поясов для PHP можно найти здесь https://www.php.net/manual/en/timezones.php

 function PHP_to_Excel() {
date_default_timezone_set("Europe/London");
$datetime = date("Y-m-d H:i:s");    
$strdate = strtotime($datetime);    
$excel_date = floatval(25569   ($strdate / 86400));

return $excel_date;
}
 

Приведенная выше функция вернет правильный серийный номер для текущей локальной даты и времени.

Комментарии:

1. Здесь вы увидите, как Excel вычисляет последовательную дату

Ответ №1:

Здесь:

 <?php

date_default_timezone_set('America/New_York');
$date_time = date("Y-m-d H:i:s");
$str_date = strtotime($date_time . '  1 day');
$excel_date = floatval(25569   $str_date / 86400);
var_dump($excel_date);
 

Вы должны изменить часовой пояс на свой текущий, вы можете увидеть все часовые пояса здесь

Возврат:

 float(43573.46537037)
 

Комментарии:

1. Вы очень близки, я также пробовал аналогичный подход, но без floatval(). Но в вашем случае теперь, если я введу это значение в Excel, Excel покажет приблизительную разницу в один час. Есть ли способ исправить это поведение? Или объяснение, почему это происходит?

2. Хмм, я не уверен в этом, позвольте мне проверить

3. Это ровно один час? если это так, как насчет добавления одного часа вручную?

4. Ну, я подумал об этом, но я не уверен, что тот же код даст мне правильное время в летнее / зимнее время. Это может быть связано с этим. Но я думаю, я не могу проверить сейчас