Foros del Web » Programando para Internet » PHP »

[SOLUCIONADO] Ordenar por dia y mes

Estas en el tema de Ordenar por dia y mes en el foro de PHP en Foros del Web. Veran, tengo un problema al ordenar unas fechas extraidas de un Json, el problema es que por lo visto solo me lo ordena por el ...
  #1 (permalink)  
Antiguo 26/12/2016, 03:27
 
Fecha de Ingreso: enero-2008
Ubicación: Valencia
Mensajes: 65
Antigüedad: 16 años, 3 meses
Puntos: 2
Ordenar por dia y mes

Veran, tengo un problema al ordenar unas fechas extraidas de un Json, el problema es que por lo visto solo me lo ordena por el dia sin tener en cuenta el mes, puesto que es como me lo hace. Tengo 3 fechas con el mes 12, y una con el mes 10, la de Octubre me sale la tercera, ¿ como lo puedo solucionar?, Hay alguna manera de simplificar este .php puesto que son muchos los que e de poner?

Código:
<?php 

$jornada9 = 'http://juveniles.esy.es/Temp_Actual/jornadas_array/a.php';
       
$ch = curl_init($jornada9);
curl_setopt($ch, CURLOPT_TIMEOUT, 5);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
$data= curl_exec($ch);
curl_close($ch);          

$jornadas  = json_decode($data);  

setlocale(LC_ALL,"es_ES");
$date0 = DateTime::createFromFormat("d/m/Y", $jornadas[0]->fecha.'/2016');
$date1 = DateTime::createFromFormat("d/m/Y", $jornadas[1]->fecha.'/2016');
$date2 = DateTime::createFromFormat("d/m/Y", $jornadas[2]->fecha.'/2016');
$date3 = DateTime::createFromFormat("d/m/Y", $jornadas[3]->fecha.'/2016');

$date100 = str_replace(array($jornadas[0]->fecha),strftime("%d/%m/%Y",$date0->getTimestamp()),$data);
$date101 = str_replace(array($jornadas[1]->fecha),strftime("%d/%m/%Y",$date1->getTimestamp()),$date100);
$date102 = str_replace(array($jornadas[2]->fecha),strftime("%d/%m/%Y",$date2->getTimestamp()),$date101);
$date103 = str_replace(array($jornadas[3]->fecha),strftime("%d/%m/%Y",$date3->getTimestamp()),$date102);


$jornadas2  = json_decode($date103);  

$fecha[0]->fecha . hora . abreviaturaEstado . estadoPartido . idLocal . idClubLocal . nomLocal . resulLocal . escudoLocal . idVisitante . idClubVisitante . nomVisitante . resulVisitante . escudoVisitante . codInfo . hayActa;
$fecha[1]->fecha . hora . abreviaturaEstado . estadoPartido . idLocal . idClubLocal . nomLocal . resulLocal . escudoLocal . idVisitante . idClubVisitante . nomVisitante . resulVisitante . escudoVisitante . codInfo . hayActa;
$fecha[2]->fecha . hora . abreviaturaEstado . estadoPartido . idLocal . idClubLocal . nomLocal . resulLocal . escudoLocal . idVisitante . idClubVisitante . nomVisitante . resulVisitante . escudoVisitante . codInfo . hayActa;
$fecha[3]->fecha . hora . abreviaturaEstado . estadoPartido . idLocal . idClubLocal . nomLocal . resulLocal . escudoLocal . idVisitante . idClubVisitante . nomVisitante . resulVisitante . escudoVisitante . codInfo . hayActa;  

    
rsort ($jornadas2);

echo json_encode ($jornadas2);
?>
Gracias
  #2 (permalink)  
Antiguo 21/01/2017, 12:57
 
Fecha de Ingreso: agosto-2011
Mensajes: 306
Antigüedad: 12 años, 7 meses
Puntos: 5
Respuesta: Ordenar por dia y mes

hola, intentare ayudarte con este pequello codigo espero que sea lo que buscas.
Código PHP:
Ver original
  1. //creamos array para trabajar en el orden de fechas
  2. $orden_productos=array();
  3. $orden_fechas=array();
  4. $jornada9 = 'http://juveniles.esy.es/Temp_Actual/jornadas_array/a.php';
  5. $data = file_get_contents($jornada9);
  6. $productos = json_decode($data, true);
  7. //recorremos los productos
  8. foreach ($productos as $producto) {
  9.     //convertimos fecha valida y creamos objeto datetime para trabajar con condicional
  10.     $mes=str_replace("/","-",$producto["fecha"])."-2000";
  11.     $fecha_des=$mes." ".$producto["hora"];
  12.     $fecha_obj = new DateTime($fecha_des);
  13.     $fecha_ord=$fecha_obj->format('d/m H:i');
  14.     //insertamos nuestro primer producto al empezar
  15.     if(count($orden_fechas)>0){
  16.         //recorremos las fechas al encontrar una fecha mas reciente la inseramos al inicio y salimos del bucle
  17.         //asin las recientes nos quedaran siempre las primeras
  18.         foreach($orden_fechas as $fecha){
  19.             if($fecha_ord<$fecha){
  20.                 array_unshift($orden_fechas,$fecha_ord);
  21.                 array_unshift($orden_productos,$producto);
  22.                 break;
  23.             }
  24.         }
  25.     }else{
  26.         $orden_fechas[]=$fecha_ord;
  27.         $orden_productos[]=$producto;
  28.     }
  29. }
  30. //salida json
  31. echo json_encode ($orden_productos);
saludos

Etiquetas: dia, fecha
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 05:00.