Ver Mensaje Individual
  #1 (permalink)  
Antiguo 09/01/2010, 22:05
neck
 
Fecha de Ingreso: mayo-2006
Mensajes: 71
Antigüedad: 18 años, 6 meses
Puntos: 0
Ordenar fechas utilizando Simplexml

Hola, ya hace tiempo que me di cuenta de las maravillas de xml, sobretodo – lo digo por mi – a la hora de obtener datos de otras fuentes. Poco a poco voy aprendiendo y haciendo mis pinitos pero todavía estoy bastante colgado en esto. Cada vez que tengo algún problema miro en el foro o en otras webs y mas o menos los voy solventando, pero otras veces por mas que miro no logro entender o simplemente pienso “PHP no me puede hacer esto ami” jeje. En definitiva, no quiero por nada en el mundo reprogramar algo que tanto trabajo me ha costado.

Pues esta vez lo que necesito es poder ordenar por la hora y fecha los resultados que muestro en pantalla obtenidos de una base de datos xml. El xml que utilizo no tiene los datos ordenados y para mi es importante mostrar primero los últimos añadidos. En php utilizo Simplexml, por eso, por su simplicidad.

Este es el xml (reducido) que utilizo:

Código XML:
Ver original
  1. <?xml version="1.0" encoding="ISO-8859-1" ?>
  2. <xml>
  3. <alimentos>
  4. <documento id="0001">
  5. <fecha_ini>2010-01-01 09:53</fecha_ini>
  6.         <tipo>alimento</tipo>
  7.     <name>Arroz Blanco</name>
  8.     <calorias>354</calorias>
  9.     <proteinas>7.6</proteinas>
  10.     <lipidos>1.7</lipidos>
  11.     <carbohidratos>77</carbohidratos>
  12.     <descripcion></descripcion>
  13. </documento>
  14. <documento id="0002">
  15. <fecha_ini>2010-01-03 12:45</fecha_ini>
  16.         <tipo>alimento</tipo>
  17.     <name>Arroz integral</name>
  18.     <calorias>350</calorias>
  19.     <proteinas>8</proteinas>
  20.     <lipidos>1.1</lipidos>
  21.     <carbohidratos>77</carbohidratos>
  22.     <descripcion></descripcion>
  23. </documento>
  24. <documento id="0003">
  25. <fecha_ini>2009-10-12 09:34</fecha_ini>
  26.         <tipo>alimento</tipo>
  27.     <name>Arroz vaporizado</name>
  28.     <calorias>343</calorias>
  29.     <proteinas>8</proteinas>
  30.     <lipidos>1.2</lipidos>
  31.     <carbohidratos>75</carbohidratos>
  32.     <descripcion></descripcion>
  33. </documento>
  34. </alimentos>
  35. </xml>
La fecha y hora si las podría obtener en otro formato.

Y este es el codigo que programe:

Código PHP:
Ver original
  1. <?php
  2. echo "<table border='1' >";
  3. echo "<tr>";
  4. echo "<td>Fecha</td>";
  5. echo "<td>Nombre</td>";
  6. echo "<td>Proteinas</td>";
  7. echo "<td>Carbohidratos</td>";
  8. echo "<td>Grasas</td>";
  9. echo "<td>Calorias</td>";
  10. echo "</tr>";
  11. echo "<tr>";
  12.  
  13.  
  14. $data = simplexml_load_file('xml.xml');
  15. foreach($data->alimentos->documento as $documento){
  16.  
  17. echo "<td>" . $documento->fecha_ini . "</td>";
  18. echo "<td>" . $documento->name . "</td>";
  19. echo "<td>" . $documento->proteinas . "</td>";
  20. echo "<td>" . $documento->carbohidratos . "</td>";
  21. echo "<td>" . $documento->lipidos . "</td>";
  22. echo "<td>" . $documento->calorias . "</td>";
  23. echo "</tr>";
  24. }
  25. echo "</table>";
  26. ?>


¿Habria alguna forma de poder ordenar los resultados que mi xml me de sin que se alterara demasiado el codigo original?. Gracias de antemano...