&reftitle.examples;
Uso básico de SimpleXML
Varios ejemplos de este capítulo requieren una cadena XML. En lugar de
repetirla en cada ejemplo, se colocará en un archivo que se incluirá en
cada uno de ellos. El contenido de este archivo se ilustra con el ejemplo
que sigue. De lo contrario, puede crearse un documento XML y leerse con
simplexml_load_file.
Ejemplo de archivo incluido examples/simplexml-data.php con una cadena XMLPHP: Behind the ParserMs. CoderOnlivia ActoraMr. CoderEl ActÓr
So, this language. It's like, a programming language. Or is it a
scripting language? All is revealed in this thrilling horror spoof
of a documentary.
PHP solves all my web problems75
XML;
?>
]]>
La simplicidad de SimpleXML se hace más evidente cuando se intenta
extraer una cadena o un número de un documento XML básico.
Lectura de <plot>
movie[0]->plot;
?>
]]>
&example.outputs;
El acceso a los elementos de un documento XML que contiene caracteres no permitidos
según la convención de nombres de PHP (por ejemplo, palabras clave) es posible
encapsulando el nombre del elemento entre corchetes y comillas simples.
Recuperación de <line>
movie->{'great-lines'}->line;
?>
]]>
&example.outputs;
Acceder a un elemento no único con SimpleXML
Cuando existen múltiples instancias de un elemento como hijos de un
elemento padre único, pueden aplicarse las técnicas normales de iteración.
, se muestra un . */
foreach ($movies->movie->characters->character as $character) {
echo $character->name, ' played by ', $character->actor, PHP_EOL;
}
?>
]]>
&example.outputs;
Las propiedades ($movies->movie en nuestro ejemplo anterior)
no son arrays. Son objetos
iterables y
accesibles.
Uso de atributos
Hasta ahora, solo se ha cubierto la lectura de los nombres de los elementos
y sus valores. SimpleXML también puede acceder a sus atributos.
El acceso a los atributos de un elemento se realiza de la misma manera que
el acceso a los elementos de un array.
del primer .
* Mostrar también los atributos de . */
foreach ($movies->movie[0]->rating as $rating) {
switch((string) $rating['type']) { // Obtener atributos como índices de elementos
case 'thumbs':
echo $rating, ' thumbs up';
break;
case 'stars':
echo $rating, ' stars';
break;
}
}
?>
]]>
&example.outputs;
Comparación de elementos y atributos con texto
Para comparar un elemento o un atributo con una cadena de caracteres
o para pasarlo a una función que requiera una cadena de caracteres,
debe convertirse en una cadena utilizando
(string).
De lo contrario, PHP tratará el elemento como un objeto.
movie->title == 'PHP: Behind the Parser') {
print 'My favorite movie.';
}
echo htmlentities((string) $movies->movie->title);
?>
]]>
&example.outputs;
Comparación de 2 elementos
Dos objetos SimpleXMLElement
se consideran diferentes incluso si
apuntan al mismo elemento.
]]>
&example.outputs;
Uso de XPath
SimpleXML incluye soporte integrado para XPath.
Para encontrar todos los elementos <character>.
'//' actúa como comodín. Para especificar una ruta absoluta,
se elimina una barra.
xpath('//character') as $character) {
echo $character->name, ' played by ', $character->actor, PHP_EOL;
}
?>
]]>
&example.outputs;
Asignación de valores
Los datos en SimpleXML no tienen que ser constantes. El objeto permite
la manipulación de todos estos elementos.
movie[0]->characters->character[0]->name = 'Miss Coder';
echo $movies->asXML();
?>
]]>
&example.outputs;
PHP: Behind the ParserMiss CoderOnlivia ActoraMr. CoderEl ActÓr
So, this language. It's like, a programming language. Or is it a
scripting language? All is revealed in this thrilling horror spoof
of a documentary.
PHP solves all my web problems75
]]>
Añadir elementos y atributos
SimpleXML es capaz de añadir fácilmente
hijos y atributos.
movie[0]->characters->addChild('character');
$character->addChild('name', 'Mr. Parser');
$character->addChild('actor', 'John Doe');
$rating = $movies->movie[0]->addChild('rating', 'PG');
$rating->addAttribute('type', 'mpaa');
echo $movies->asXML();
?>
]]>
&example.outputs;
PHP: Behind the ParserMs. CoderOnlivia ActoraMr. CoderEl ActÓrMr. ParserJohn Doe
So, this language. It's like, a programming language. Or is it a
scripting language? All is revealed in this thrilling horror spoof
of a documentary.
PHP solves all my web problems75PG
]]>
Interoperabilidad DOM
PHP tiene un mecanismo para convertir nodos XML entre los formatos
SimpleXML y DOM. Este ejemplo muestra cómo cambiar un elemento DOM a
SimpleXML.
loadXML('blah');
if (!$dom) {
echo 'Error al analizar el documento';
exit;
}
$books = simplexml_import_dom($dom);
echo $books->book[0]->title;
?>
]]>
&example.outputs;
Uso de espacios de nombresOnlivia Actora
XML;
$movies = simplexml_load_string($data);
// El espacio de nombres http://www.w3.org/XML/1998/namespace está disponible bajo el nombre "xml".
echo $movies->movie->attributes("xml", true)["id"] . "\n";
// Los atributos con espacio de nombres pueden recuperarse con attributes().
echo $movies->movie->attributes("a", true)["link"] . "\n";
// El uso de la URI del espacio de nombres permite usar cualquier alias en el documento.
echo $movies->movie->attributes("http://a")["link"] . "\n";
// Los hijos pueden recuperarse con children().
echo $movies->movie->children("http://a")->actor . "\n";
// El uso de xpath() con un espacio de nombres requiere registrarlo primero.
$movies->registerXPathNamespace("a", "http://a");
echo count($movies->xpath("//a:actor")) . "\n";
// Incluso el espacio de nombres por defecto debe registrarse.
$movies->registerXPathNamespace("default", "http://default");
echo count($movies->xpath("//default:movie")) . "\n";
// Esto está vacío.
echo count($movies->xpath("//movie")) . "\n";
?>
]]>
Manejo de errores XML
El manejo de errores XML al cargar un documento es
una tarea sencilla. Utilizando las funcionalidades
libxml, es posible suprimir
todos los errores XML al cargar un documento, y luego recorrerlos.
El objeto LibXMLError, devuelto por la función
libxml_get_errors, contiene varias propiedades
como el mensaje,
la línea y la
columna (posición) del error.
Carga de cadenas XML rotas");
if ($sxe === false) {
echo "Error al cargar el XML\n";
foreach(libxml_get_errors() as $error) {
echo "\t", $error->message;
}
}
?>
]]>
&example.outputs;
' expected
Opening and ending tag mismatch: xml line 1 and broken
Premature end of data in tag broken line 1
]]>
&reftitle.seealso;
libxml_use_internal_errorslibxml_get_errors