0 / 0 / 0
Регистрация: 13.10.2014
Сообщений: 23

Как найти середину даты между двумя датами

20.11.2015, 10:25. Показов 4915. Ответов 6
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Прошу помочь решить такую задачку в PHP.
ест 2 дата
1. 2015-11-20
2. 2016-02-20

Нужно вычислить какой дата между ними.
Например от 2015-11-20 до 2015-02-20 будет гдето 90 дней,
нужна найти половину 45-ый день на какое число подходить,


Искал но не нашел ответа,
Спасибо заранее
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
20.11.2015, 10:25
Ответы с готовыми решениями:

Выбрать даты в StringGrid находящиеся между двумя другими датами
Добрый день. Подскажите пожалуйста как решить следующую задачу. У меня имеется две даты: дата начала периода и дата конца периода...

Даты в виде записей. Определить количество дней между двумя датами
Создать программу, позволяющую определить количество дней между двумя датами.Для хранения даты использовать зпись.

Найти количество дней между двумя датами
Помогите решить задачку в MATLAB, пожалуйста. Два ребенка родились в 2015. Нужно найти количество дней между датами их рождения. При этом...

6
10 / 10 / 7
Регистрация: 18.10.2015
Сообщений: 160
20.11.2015, 14:54
PHP
1
2
3
4
5
6
$subTime = strtotime('2016-02-20') - strtotime('2015-11-20');
$y = ($subTime/(60*60*24*365));
$d = ($subTime/(60*60*24))%365;
 
echo $y." years\n";
echo $d." days\n";
0
0 / 0 / 0
Регистрация: 13.10.2014
Сообщений: 23
21.11.2015, 03:48  [ТС]
Есть 2 даты
1. 2015-11-20
2. 2016-11-20

Разница между этими датамы 90 дней.
Нужно найти из половину 90 дней, то есть 45-ый день на какое число подходить
дата между 2015-11-20 и 2016-11-20 подходить на 2016-01-04
0
Web Programmer
 Аватар для JimUSA
325 / 286 / 121
Регистрация: 28.09.2011
Сообщений: 1,570
22.11.2015, 02:43
PHP/HTML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
<?php
 
$date1 = mktime(0, 0, 0, 11, 1, 2015);
$date2 = mktime(0, 0, 0, 11, 20, 2015);
 
if($date2 > $date1) {
    $date = $date1 + (($date2 % $date1) / 2);
    $date = date('d.m.Y', $date);
}else
    $date = 'N/A';
 
echo '<style type="text/css">
table {background-color: rgba(185,185,185,1);}
td {padding: 8px;border: 1px solid rgba(200,200,200,1);background-color: rgba(235,235,235,1);}
</style>
<table cellpadding="0" cellspacing="1">
<tr>
    <td>Date 1</td>
    <td>Date 2</td>
    <td>Date / 2 part</td>
</td>
<tr>
    <td>' . date('d.m.Y', $date1) . '</td>
    <td>' . date('d.m.Y', $date2) . '</td>
    <td>' . $date . '</td>
</tr>
</table>';
0
 Аватар для GoDr
90 / 79 / 33
Регистрация: 17.08.2015
Сообщений: 512
Записей в блоге: 1
22.11.2015, 10:30
Лучший ответ Сообщение было отмечено КунгФуПанда как решение

Решение

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
// Дата 1
$d1 = '2015-11-20';
 
// Дата 2
$d2 = '2016-11-20';
 
// количество дней (разница)
$day = getDateDiff($d1, $d2);
 
// Половина
$part = (int)($day / 2);
 
// Дата половины
$d3 = getDateAdd($d1, 'P'.$part.'D', 'Y-m-d');
 
echo $d3;
 
/**
 * Возвращает разницу дат
 *
 * @param datetime      $date1  : уменьшаемое
 * @param datetime|null $date2  : вычитаемое (если не задана то текущая)
 * @param string        $format : возвращаемый формат (каждому символу должен предшествовать знак процента [%])
 *                              Y : Годы, число, минимум две цифры с ведущими нулями
 *                              y : Годы, число
 *                              M : Месяцы, число, минимум две цифры с ведущими нулями
 *                              m : Месяцы, число
 *                              D : Дни, число, минимум две цифры с ведущими нулями
 *                              d : Дни, число
 *                              a : Общее количество дней в качестве результата выполнения DateTime::diff(), либо unknown
 *                              H : Часы, число, минимум две цифры с ведущими нулями
 *                              h : Часы, число
 *                              I : Минуты, число, минимум две цифры с ведущими нулями
 *                              i : Минуты, число
 *                              S : Секунды, число, минимум две цифры с ведущими нулями
 *                              s : Секунды, число
 *                              R : Знак "-" при отрицательном числе, "+" при положительном
 *                              r : Знак "-" при отрицательном числе, пусто при положительном
 *
 * @return int : разность (в днях)
 *
 * @example :
 *         echo LibDateTime::getDateDiff('01.01.2015');
 *         echo LibDateTime::getDateDiff('11.11.2020', '01.01.2015');
 *         echo LibDateTime::getDateDiff('11.11.2020', '01.01.2015', '%r%a');
 *
 * @version 1.1
 * @since   21.08.2015 Gold Dragon
 */
function getDateDiff($date1, $date2 = null, $format = '%r%a')
{
    if (is_null($date2)) {
        $date2 = date('Y-m-d');
    }
    $d1 = new DateTime($date1);
    $d2 = new DateTime($date2);
 
    $result = (int)$d1->diff($d2)->format($format);
 
    return $result;
}
 
/**
 * Прибавляет интервал к дате
 *
 * @param string $date     - дата
 * @param string $interval - интервал в формате ISO 8601, например, P5D (5 дней) или P3Y (3 года)
 *                         Y : Количество лет
 *                         M : Количество месяцев
 *                         D : Количество дней
 *                         W : недели. Преобразуется в дни, поэтому не может быть использован совместно с D.
 *                         H : часы
 *                         M : минуты
 *                         S : секунды
 * @param string $format   - возвращаемый формат (по умолчанию  d.m.Y)
 *
 * @return string - дата в формате $format
 *
 * @example:
 *         echo LibDateTime::getDateAdd('01.01.2015', 'P5D');
 *         echo LibDateTime::getDateAdd('01.01.2015', 'P5D', 'Y-m-d');
 */
function getDateAdd($date, $interval, $format)
{
    $d1 = new DateTime($date);
    $result = $d1->add(new DateInterval($interval))->format($format);
 
    return $result;
}
1
 Аватар для Drygba
512 / 454 / 119
Регистрация: 17.02.2012
Сообщений: 1,032
Записей в блоге: 1
22.11.2015, 15:58
ну вы и наворотили
PHP
1
2
3
4
$dateOne = new DateTime('2015-11-20');
$dateTwo = new DateTime('2016-03-20');
 
var_dump(round($dateOne->diff($dateTwo)->days / 2));
0
0 / 0 / 0
Регистрация: 13.10.2014
Сообщений: 23
05.12.2015, 08:52  [ТС]
Спасибо, то что искал.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
05.12.2015, 08:52
Помогаю со студенческими работами здесь

Найти количество полных лет, прошедших между двумя датами
Даны две даты (число, месяц, год). Найти количество полных лет, прошедших между этими двумя датами.

Структура данных - очередь. Найти разность между двумя датами
Я чего - то вообще в тупике. Ничего на ум не приходит. Расскажите алгоритм, пожалуйста. /* В задании необходимо разработать...

найти ошибку в коде по нахождению количества дней между двумя датами
пишет какую-то белеберду void Date::megdy(){ unsigned int mday, mday2; cout&lt;&lt;&quot;Сколько дней между двумя датами?&quot;&lt;&lt;endl; ...

Как получить количество дней между двумя датами?
Выкачивается из MS SQL две даты - как можно вычислить кол-во дней между ними при помощи JScript?

Количество дней между двумя датами. Как определить?
Подскажите есть дата отезда(тип данных дата\время) и дата приезда(тип данных дата\время) как найти количество дней(тип данных числовой)


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Опции темы

Новые блоги и статьи
Анализ и линтинг кода JavaScript: ESLint, Prettier и JSHint
run.dev 26.04.2025
JavaScript прошёл долгий путь от простого языка для анимации веб-страниц до основы современной веб-разработки. С ростом сложности приложений, увеличением кодовых баз и масштабированием команд. . .
Паттерны в Python: Singleton, Factory и Observer
py-thonny 26.04.2025
Паттерны проектирования — это проверенные временем решения типовых проблем разработки программного обеспечения. Их история берёт начало с книги "Приёмы объектно-ориентированного проектирования. . . .
Исключения в C#: Stack Overflow, Access Violation и Out of memory
stackOverflow 26.04.2025
Исключения в C# — это не только механизм оповещения о проблемах, а целое искусство управления потоком выполнения программы в экстремальных ситуациях. Обычное исключение, например,. . .
Логирование в C# ASP.NET Core с помощью Serilog, ElasticSearch, Kibana
stackOverflow 25.04.2025
Помните те времена, когда для анализа проблемы приходилось подключаться к серверу, искать нужный лог-файл среди десятков других и вручную фильтровать тысячи строк в поисках ошибки? К счастью, эти дни. . .
Структура "железный OnKeyUp" вместо антидребезга. Полностью асинхронный счётчик.
Hrethgir 25.04.2025
Программа для симуляции схемы - Logisim Evolution В общем какое-то время отвлёкся, так было надо, теперь когда запилю это на verilog и FPGA , досоставлю заявку в ФИПС на полезную модель - не готов. . .
Автоматизация Amazon Web Services (AWS) с Boto3 в Python
py-thonny 25.04.2025
Облачные вычисления стали неотъемлемой частью современной ИТ-инфраструктуры, а Amazon Web Services (AWS) занимает лидирующие позиции среди провайдеров облачных услуг. Управление многочисленными. . .
Apache Kafka vs RabbitMQ в микросервисной архитектуре
ArchitectMsa 25.04.2025
Современная разработка ПО всё чаще склоняется к микросервисной архитектуре — подходу, при котором приложение разбивается на множество небольших, автономных сервисов. В этой распределённой среде. . .
Параллельное программирование с OpenMP в C++
NullReferenced 24.04.2025
Параллельное программирование — подход к созданию программ, когда одна задача разбивается на несколько подзадач, которые могут выполняться одновременно. Оно стало необходимым навыком для. . .
Цепочки методов в C# с Fluent API
UnmanagedCoder 24.04.2025
Современное программирование — это не только решение функциональных задач, но и создание кода, который удобно поддерживать, расширять и читать. Цепочки методов и Fluent-синтаксис в C# стали мощным. . .
Мульти-тенантные БД с PostgreSQL Row Security
Codd 23.04.2025
Современные облачные сервисы и бизнес-приложения всё чаще обслуживают множество клиентов в рамках единой программной инфраструктуры. Эта архитектурная модель, известная как мульти-тенантность, стала. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru