Foros del Web » Programando para Internet » PHP »

Intervalo entre varias fechas

Estas en el tema de Intervalo entre varias fechas en el foro de PHP en Foros del Web. Buen día. Mi problema es hacer un cálculo para saber el total de días entre varias fechas. Ejemplo. Intervalo 1: 01 - 09 - 2010 ...
  #1 (permalink)  
Antiguo 14/09/2010, 16:10
 
Fecha de Ingreso: septiembre-2010
Mensajes: 5
Antigüedad: 13 años, 7 meses
Puntos: 0
Intervalo entre varias fechas

Buen día.

Mi problema es hacer un cálculo para saber el total de días entre varias fechas.
Ejemplo.

Intervalo 1: 01 - 09 - 2010 a 30 - 09 - 2010 = 30 días
Intervalo 2: 15 - 09 - 2010 a 15 - 10 - 2010 = 30 días

Y que quite los días repetidos y el resultado sea 45 días.

y así para X fechas.


De antemano gracias.
  #2 (permalink)  
Antiguo 24/09/2010, 14:06
Avatar de repara2  
Fecha de Ingreso: septiembre-2010
Ubicación: München
Mensajes: 2.445
Antigüedad: 13 años, 7 meses
Puntos: 331
Respuesta: Intervalo entre varias fechas

Te paso dos funciones que te pueden servir:

Código PHP:
<?php

// Las xDates están en formato dd-mm-yyyy cbruschi.blogspot.com
    
function rdates($xDate1$xDate0) {
        return 
date2days(ymd($xDate1)) - date2days(ymd($xDate0));
    }

    
// xDate a días.
    
function date2days($xDate) {
        
// yyyy-mm-dd
        
list($anyo$mes$dia) = explode("-"$xDate);
    
        
// Días acumulados por meses.
        // Basta hasta novimbre.
        
$ar_dias = array(
            
31
            
31 28
            
31 28 31
            
31 28 31 30
            
31 28 31 30 31
            
31 28 31 30 31 30
            
31 28 31 30 31 30 31
            
31 28 31 30 31 30 31 31
            
31 28 31 30 31 30 31 31 30
            
31 28 31 30 31 30 31 31 30 31
            
31 28 31 30 31 30 31 31 30 31 30); 
    
        
$xReturn floor(($anyo 1901) * 365.25);
        
$xReturn += (($mes != 1) ? $ar_dias[$mes 2] : 0);        // El array empieza en 0.
        
$xReturn += $dia;
        
$xReturn += (($mes 2) && checkdate(0229$anyo) ? 0);
    
        return 
$xReturn;
    }
    
    
// Cambia una xDate en formato dd-mm-yyyy al formato yyyy-mm-dd
    
function ymd($xDate){ 
        
$mixDate explode($xDate[2], $xDate);
        
$laxDate=$mixDate[2]."-".$mixDate[1]."-".$mixDate[0]; 
        return 
$laxDate
    } 
    
    
/**
Intervalo 1: 01 - 09 - 2010 a 30 - 09 - 2010 = 30 días
Intervalo 2: 15 - 09 - 2010 a 15 - 10 - 2010 = 30 días
*/
    //Te quedas con la mayor y la menor, utiliza la db u otra funcion para calcularlas.
    
    
$int0 "01-09-2010";
    
$int1 "15-10-2010";
    
    echo 
rdates($int1$int0);
    
    
?>
Lo pruebas y me cuentas, saludos
  #3 (permalink)  
Antiguo 24/09/2010, 17:16
Avatar de abimaelrc
Colaborador
 
Fecha de Ingreso: mayo-2009
Ubicación: En el planeta de Puerto Rico
Mensajes: 14.734
Antigüedad: 15 años
Puntos: 1517
Respuesta: Intervalo entre varias fechas

Me entretuvo este algoritmo, ¿algo así es lo que quieres?
Código PHP:
Ver original
  1. <?php
  2. function calcDays(){
  3.     if(func_num_args() > 0){
  4.         $dates = array();
  5.  
  6.         foreach(func_get_args() as $value){
  7.             if(is_string($value)){
  8.                 $dates[] = strtotime($value);
  9.             }
  10.             elseif(is_array($value) && count($value) == 1){
  11.                 $dates[] = strtotime($value[0]);
  12.             }
  13.             elseif(is_array($value) && count($value) >= 2){
  14.                 $minNum = strtotime($value[0]) < strtotime($value[1]) ? $value[0] : $value[1];
  15.                 $maxNum = strtotime($value[0]) > strtotime($value[1]) ? $value[0] : $value[1];
  16.                 $dates[] = strtotime($minNum);
  17.                 while(true){
  18.                     $addOne = empty($addOne) ? $minNum : date('Y-m-d', $addOne);
  19.                     $addOne = strtotime('+1 day ' . $addOne);
  20.                     if($addOne >= strtotime($maxNum)){
  21.                         $dates[] = strtotime($maxNum);
  22.                         break;
  23.                     }
  24.                     $dates[] = $addOne;
  25.                 }
  26.                 unset($addOne);
  27.             }
  28.         }
  29.     }
  30.     return empty($dates) ? 0 : count(array_unique($dates));
  31. }
  32.  
  33. echo calcDays(array('2010-09-01', '2010-09-30'), array('2010-09-15', '2010-10-15'), array('2010-07-15', '2010-08-15'), '2010-08-15') . '<br />';
  34. echo calcDays(array('2010-09-01', '2010-09-30'), array('2010-09-15', '2010-10-15'), array('2010-09-15', '2010-10-30')) . '<br />';
  35. echo calcDays(array('2010-09-01', '2010-09-30'), array('2010-10-29', '2010-10-30')) . '<br />';
  36. echo calcDays(array('2010-09-01', '2010-09-30'), array('2010-10-15', '2010-10-30'));
__________________
Verifica antes de preguntar.
Los verdaderos amigos se hieren con la verdad, para no perderlos con la mentira. - Eugenio Maria de Hostos

Última edición por abimaelrc; 24/09/2010 a las 20:59 Razón: Correcciones al código

Etiquetas: fechas, intervalo
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 08:07.