A veces es necesario saber cuánto tiempo ha transcurrido de una fecha a otra. Por ejemplo, puede que necesitemos saber hace cuántos días se registró un usuario, etcétera.

Lo único que necesitamos es tener las dos fechas: la fecha actual y la fecha con la que queremos trabajar (en nuestro ejemplo sería la fecha del registro del usuario).

Para obtener la fecha actual, usamos la función date de PHP. Le podemos pasar una cadena de formato como se ve a continuación:

<?php
$fechaActual = date("Y-m-d H:i:s");
?>

Esto nos daría una salida así:

2017-05-16 20:40:15

Ya tenemos la fecha actual. Ahora, supongamos que la fecha del registro del usuario es de hace un mes, y que la recuperamos de una base de datos con el siguiente aspecto:

2017-04-16 17:10:00

Ya tenemos ambas fechas. Lo único que hace falta es restarlas. No tenemos que quebrarnos la cabeza recortando la cadena o separando meses, años, etcétera. PHP hace todo por nosotros con su función strtotime que toma como argumento una cadena de fecha y regresa un entero representando los segundos transcurridos desde la fecha Unix. Después, con los segundos de cada fecha ya podemos hacer matemáticas. Así que, el código quedaría así:

<?php
$fechaActual = date("Y-m-d H:i:s");
$fechaRegistro = "2017-04-16 17:10:00";
$segundosFechaActual = strtotime($fechaActual);
$segundosFechaRegistro = strtotime($fechaRegistro);
$segundosTranscurridos = $segundosFechaActual - $segundosFechaRegistro;
echo $segundosTranscurridos;
?>

La salida del programa sería algo como 2604615. Ahora, con este número podemos seguir haciendo matemáticas. Recordemos lo siguiente:

Un minuto = 60 segundos

Una hora = 60 minutos * 60 segundos = 3600 segundos

Un día = 24 horas * 60 minutos * 60 segundos = 86, 400 segundos

Una semana = 7 días * 24 horas * 60 minutos * 60 segundos = 604,800 segundos

Relacionado:  Extraer año, mes o día de alguna fecha en PHP

Entonces, para saber cuántos días han pasado, podemos dividir los segundos transcurridos entre 86,400. Así:

<?php
$fechaActual = "2017-05-16 20:40:15";
$fechaRegistro = "2017-04-16 17:10:00";
$segundosFechaActual = strtotime($fechaActual);
$segundosFechaRegistro = strtotime($fechaRegistro);
$segundosTranscurridos = $segundosFechaActual - $segundosFechaRegistro;
$diasTranscurridos = $segundosTranscurridos / 86400;
echo $diasTranscurridos;
?>

La salida del programa sería algo como 30.146006944444 pero podemos redondearlo al entero anterior con floor, o al siguiente entero mayor con ceil. Igual podemos saber las semanas, los meses u horas.

Si el post fue de tu agrado muestra tu apoyo compartiéndolo, suscribiéndote al blog, siguiéndome o realizando una donación.

Suscribir por correo

Ingresa tu correo y recibirás mis últimas entradas sobre programación, open source, bases de datos y todo lo relacionado con informática

Únete a otros 390 suscriptores


parzibyte

Programador freelancer listo para trabajar contigo. Aplicaciones web, móviles y de escritorio. PHP, Java, Go, Python, JavaScript, Kotlin y más :) https://parzibyte.me/blog/software-creado-por-parzibyte/

5 Comments

gerardo vargas · agosto 15, 2018 a las 5:34 pm

Gracias me fue de mucha ayuda

    parzibyte · agosto 15, 2018 a las 5:40 pm

    Es un gusto ayudar 🙂

    Enrique · septiembre 7, 2018 a las 10:31 am

    Excelente!!!,,muchas gracias!!!..una consulta; como podría generar fechas a partir de una fecha de inicio y una cantidad x de meses?.. algo así como: fec_ini=’2018-08-30′ y cantidad de meses=10, que quede algo así; 1= ‘2018-09-30’, 2=’2018-10-30’…etc., ojala me haya explicado, gracias!!!

    parzibyte · septiembre 7, 2018 a las 1:22 pm

    No sé si es a lo que te refieres pero aquí el código: https://gist.github.com/parzibyte/2a02db5da77c9385698f9c9fe8710b67
    Eso genera algo como:
    Después de un mes, la fecha es: 2018-09-30
    Después de un mes, la fecha es: 2018-10-30
    Después de un mes, la fecha es: 2018-11-30
    Después de un mes, la fecha es: 2018-12-30
    Después de un mes, la fecha es: 2019-01-30
    Después de un mes, la fecha es: 2019-03-02
    Después de un mes, la fecha es: 2019-04-02
    Después de un mes, la fecha es: 2019-05-02
    Después de un mes, la fecha es: 2019-06-02
    Después de un mes, la fecha es: 2019-07-02

Obtener fecha de mañana en PHP - Parzibyte's blog · octubre 3, 2018 a las 5:35 pm

[…] vimos cómo obtener los días transcurridos en dos fechas con PHP en un post anterior. Ahora veamos cómo obtener la fecha de mañana, incluso con precisión de […]

Deja un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

A %d blogueros les gusta esto: