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

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

То, что я хочу сделать, это дата PHP ("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?

Обновлено: Согласно ответу Моргана ниже, у меня теперь есть функция, которая делает это: Обновлено еще раз: Добавлен часовой пояс, чтобы получить мое местное время, если кому-то еще это нужно, установите для вашего местного часового пояса. Список поддерживаемых часовых поясов для 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;
}

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

Здесь вы увидите, как Excel вычисляет серийную дату
B001ᛦ 18.04.2019 13:02
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
2
1
579
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 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)

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

al1en 18.04.2019 13:19

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

MorganFreeFarm 18.04.2019 13:24

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

MorganFreeFarm 18.04.2019 13:29

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

al1en 18.04.2019 13:31

Другие вопросы по теме