Archive for 23 septiembre 2007

Accediendo a XML con XPath y PHP5

septiembre 23, 2007

Bien, hasta ahora vimos como acceder al documento XML con PHP 5 accediendo a los nodos directamente e iterando colecciones.

Pero qué pasa si queremos acceder a un nodo en particular, sin tener que recorrer el documento.

Esto se puede hacer mediante XPath. XPath es un lenguaje de expresiones para acceder a partes de un documento XML. También permite hacer cálculos.

La base es considerar al documento como un arbol de directorios de unix donde cada nodo es un directorio. De esta manera si queremos acceder al título de un documento XHTML basta con consultar el elemento: “/html/head/title”. Si queremos acceder todas las entradas de un feed RSS. la consulta será a “entry”. Esto devolverá un array con todos los nodos de tipo entry donde cada elemento del array será un nodo.

También podemos acceder por los atributos. Supongamos que tenemos un documento XML en donde guardamos contactos. Cada nodo “contacto” tiene un atributo que se llama “tipo” y entre sus valores posibles están “Personales”, “Negocios”, etc. Si queremos listar todos los contactos de tipo “Personales”:

$xml = simplexml_load_file('contactos.xml');
$res = $xml->xpath("contacto[@tipo=Personales]");

foreach ($res as $contacto)
{
  //hacer algo con los contactos...
}

Es decir invocamos al método xpath de la clase SimpleXML pasándole por parámetro nuestra consulta XPath. Como queremos filtrar por atributos ponemos entre corchetes el atributo precedido por una @ e igualamos al valor que queremos filtrar. En el ej:[@tipo=Personales].

Esto es solo la punta del iceberg, ya que se pueden hacer cálculos, consultas complejas acceder a nodos relativos, por ejemplo, el nodo padre de los nodos que tengan cierto valor en cierto atributo.

Cualquier duda o comentario, pregunten. Saludos!

Anuncios

SPIP y las palabras clave

septiembre 20, 2007

SPIP tiene un mecanismo muy poderoso de categorizar contenidos por palabras clave.

Por un lado propone las secciones para cargar artículos asociados a una temática. Un ejemplo sería una comunidad en particular que quiere publicar noticias y opiniones, cada uno con su formato particular.

De golpe en el contexto ocurre un evento, por ejemplo: la comunidad es una comunidad de jugadores de rugby y a su vez está ocurriendo el Mundial de Rugby de Francia. Este mundial genera noticias (resultados, fixtures, etc) y por otra parte opiniones (comentarios de partidos, amistosas sugerencia, etc)

Si quisieramos armar una página especial por el mundial de Rugby podríamos armar una sección nueva y cargar todos las noticias y las opiniones ahí. Pero surgiría el problema del formato. Además, ¿que pasaría si yo quisiera que las noticias del mundial salgan con las noticias de la comunidad, lo mismo que las opiniones?

Las palabras clave vienen al rescate. SPIP permite definir grupos de palabras clave a los cuales se les asocian diversas palabras clave. En nuestro ejemplo podríamos definir un Grupo de Palabras Clave que se llama Torneos y en ese grupo una palabra clave concreta: “Mundial de Rugby Francia 2007”. Podríamos crear otras palabras Clave: “Campeonato de la URBA”, “Gira a Nueva Zelanda” y así las que queramos.

Bastará con crear un esqueleto con el contenido estático y el recorrido de las palabras clave que estemos usando.

Podríamos incluso abrir un canal RSS dedicado solo al evento mediante el mismo uso de la palabras clave.

Como se puede ver tiene muchas posibilidades. Espero que haya sido útil. Nos vemos y vamo’ lo’ puma’!

Leyendo xml con PHP 5

septiembre 12, 2007

Estoy necesitando parsear XML con PHP. La idea es ir armando una maqueta para un sitio que muestra artículos que obtiene de unos archivos XML.

Parsear XML en PHP4 era lento y poco práctico, razón por la cual siempre traté de evitarlo. Si hacía falta sacar algo de un archivo XML lo recorría como un archivo plano y extraía los datos con expresiones regulares.

Por otra parte entre las novedades PHP 5, el soporte para XML fue optimizado. Esto se basa en una nueva clase que envuelve la funcionalidad de una biblioteca que llama libxml: SimpleXML.

¿Por donde empezar?

La biblioteca es muy cómoda de utilizar. Acepta iteradores y permite acceder a los nodos hijos como atributos del nodo/objeto padre.


$archivo = 'entrada.xml';

//Caso 1: Directamente trayendo el archivo
$xml = simplexml_load_file($entrada);

$cadena = file_get_contents($entrada);

//Caso 2: Teniendo el contenido de texto
$xml = simplexml_load_string($cadena);

//Caso 3: O como instancia de la Clase SimpleXML
$xml = new SimpleXML($cadena);

En cualquiera de los 3 casos voy a tener un objeto $xml que representa al nodo raíz.

Supongamos que queremos mostrar links a los posts más recientes de un blog mediante feeds RSS. Mediante CURL o file_get_contents obtuvimos los datos en la variable $cadena.

$xml = new SimpleXML($cadena);

echo "Fuente :<a href=\\"".
$xml->channel->link ."\\">".
$xml->channel->title."</a>
\\n";

echo "
<ul>";
foreach ($xml->channel->item as $item)
{
echo "
	<li><a href=\\""
.$item->link ."\\">"
.$item->title."</a></li>
\\n";
}
echo "</ul>
";

Así de fácil podemos recorrer el RSS. Hay que tener encuenta que el objeto $xml es el elemento raíz de la cadena pasada (<rss> en este caso).

La próxima vez vamos a hablar de XPath, y de como acceder a los hijos y a los atributos del documento xml.

Montar iso en XP

septiembre 10, 2007

Encontré cómo montar archivos iso en Windows XP sin tener que usar ni Alcohol, ni Nero Imagedrive.

Es cuestión de copiar un archivo al directorio %systemroot%\system32\drivers y usar un programita cliente.

Chapeau!

maldito disco

septiembre 6, 2007

Será posible, el disco rígido está a punto de fenecer. Me tira errores el SMART en booteo y me sugiere que backupee todo y lo cambie.

Sospecho que tengo problemas con la corriente. Voy a tener que rendirme y comprar un estabilizador de corriente. @#!