Ver Mensaje Individual
  #1 (permalink)  
Antiguo 26/10/2010, 20:24
nomafeito
 
Fecha de Ingreso: octubre-2010
Mensajes: 69
Antigüedad: 14 años, 3 meses
Puntos: 1
Procesar tiempo transcurrido

Bueno he escrito esta función a la que le pasamos un campo MYSQL en formato DATETIME al que a ese campo se le ha añadido un valor por el método NOW().

Voici:

Código PHP:
<?php

function tiempopasado($tiempo)
{

    
$tiempoactual strftime("%Y-%m-%d %H:%M");

    
$year substr($tiempo04);
    
$mes substr($tiempo52);
    
$dia substr($tiempo82);
    
$hora substr($tiempo112);
    
$minuto substr($tiempo142);

    
$yearactual strftime("%Y");
    
$mesactual strftime("%m");
    
$diaactual strftime("%d");
    
$horaactual strftime("%H");
    
$minutoactual strftime("%M");

    
$comptime = (($hora 60) + $minuto);
    
$comptimeact = (($horaactual 60) + $minutoactual); //compara si la fecha actual es anterior a la leida, si es así..
    
if ($comptimeact $comptime) { //.. no tiene sentido seguir.
        
return "error salida hora";
    }

    
$date substr($tiempo016); //fuera segundos de tabla DATETIME
    
$dateactual $yearactual "-" $mesactual "-" $diaactual " " $horaactual .
        
":" $minutoactual;


    if (
$date == $dateactual) {
        
$sale "menos de 1 minuto";
        return 
$sale;
    }

    
$date substr($tiempo013);
    
$dateactual $yearactual "-" $mesactual "-" $diaactual " " $horaactual;
    
$testtime $minutoactual $minuto;
    if ((
$date == $dateactual) && ($testtime 2)) {
        
$sale "1 minuto";
        return 
$sale;
    }

    if (
$date == $dateactual) {
        
$sale $testtime " minutos";
        return 
$sale;
    }

    
$date substr($tiempo010);
    
$dateactual $yearactual "-" $mesactual "-" $diaactual;
    
$testtime $horaactual $hora;
    if ((
$date == $dateactual) && ($testtime 2)) {
        
$sale "1 hora";
        return 
$sale;
    }
    if (
$date == $dateactual) {
        
$sale $testtime " horas";
        return 
$sale;
    }

    
$date substr($tiempo07);
    
$dateactual $yearactual "-" $mesactual;
    
$testtime $diaactual $dia;
    if ((
$date == $dateactual) && ($testtime 2)) {
        
$sale "ayer a las " $hora ":" $minuto;
        return 
$sale;
    }
    if (
$date == $dateactual) {
        
$sale $testtime " dias";
        return 
$sale;
    }

    
$totalmeses = (($year 2000) * 12) + $mes;
    
$totalmesesactual = (($yearactual 2000) * 12) + $mesactual;

    if (
$totalmesesactual <= $totalmeses) {
        return 
"error fechas salida";
    }

    
$totalmesesactual $totalmesesactual $totalmeses;

    if (
$totalmesesactual 12) {
        
$sale $totalmesesactual " meses" $totalmesesactual;
        return 
$sale;
    }
    if (
$totalmesesactual == 12) {
        
$sale "1 año" $totalmesesactual;
        return 
$sale;
    }
    if ((
$totalmesesactual 12) && ($totalmesesactual 23)) {
        
$sale "mas de 1 año" $totalmeses;
        return 
$sale;
    }
    if (
$totalmesesactual 23) {
        
$testtime = (round($totalmesesactual 12));
        
$sale $testtime " años" $totalmeses;
        return 
$sale;
    }
    return 
"salida error";
}


?>
Me he hecho un lio porque soy novato, llevo solo 2 semanas con el PHP, pero funciona!!! (al menos eso creo)

La cosa es que... no estoy contento, estoy seguro que se puede optimizar (como todo), porque no quiero usar tanto recurso de servidor, si teneis alguna idea...

..a vuestra disposición!