Création de documents XML avec des préfixes de nœud
Lors de la construction de documents XML à l'aide de XElement, il est crucial pour gérer correctement les préfixes d’espace de noms. Tenter de créer directement un élément avec un préfixe, par exemple new XElement("sphinx:docset"), entraînera une exception.
Solution utilisant l'espace de noms
LINQ to XML fournit une solution élégante pour cela :
XNamespace ns = "sphinx"; XElement element = new XElement(ns + "docset");
Cette approche ajoute l'espace de noms au nom de l'élément, garantissant la présence du préfixe souhaité.
Personnalisation des préfixes
Vous pouvez également personnaliser le préfixe pour qu'il corresponde à votre structure XML existante :
XNamespace ns = "http://url/for/sphinx"; XElement element = new XElement("container", new XAttribute(XNamespace.Xmlns + "sphinx", ns), new XElement(ns + "docset", new XElement(ns + "schema"), new XElement(ns + "field", new XAttribute("name", "subject")), new XElement(ns + "field", new XAttribute("name", "content")), new XElement(ns + "attr", new XAttribute("name", "published"), new XAttribute("type", "timestamp"))));
Ceci le code génère du XML qui ressemble à votre exemple fourni :
<container xmlns:sphinx="http://url/for/sphinx"> <sphinx:docset> <sphinx:schema /> <sphinx:field name="subject" /> <sphinx:field name="content" /> <sphinx:attr name="published" type="timestamp" /> </sphinx:docset> </container>
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!