Come ottenere il valore degli elementi con Linq To XML
-
05-07-2019 - |
Domanda
Utilizzando Linq To XML, come posso ottenere il valore space_id (720) dall'xml seguente?
Sto leggendo questo ma penso che lo spazio dei nomi nel xml è il mio ostacolo.
<r25:spaces xmlns:r25="http://www.collegenet.com/r25" pubdate="2009-05-05T12:18:18-04:00">
<r25:space id="VE1QOjRhMDAyZThhXzFfMWRkNGY4MA==" crc="" status="new">
<r25:space_id>720</r25:space_id>
<r25:space_name>SPACE_720</r25:space_name>
<r25:max_capacity>0</r25:max_capacity>
</r25:space>
</r25:spaces>
Modifica
Ecco dove sono:
private int GetIDFromXML(string xml)
{
XDocument xDoc = XDocument.Parse(xml);
// hmmm....
}
Soluzione
Puoi anche andare con (leggera variazione del codice sopra il quale penso sia un po 'più leggibile)
XNamespace ns = "http://www.collegenet.com/r25";
string id = doc.Descendants(ns.GetName("space_id").Single().Value;
Altri suggerimenti
Se vuoi solo il solo elemento space_id
, senza query ecc:
XNamespace ns = "http://www.collegenet.com/r25";
string id = doc.Descendants(ns + "space_id")
.Single()
.Value;
(Dove doc
è un XDocument
- o un XElement
).
Un po 'più prolisso sulla risposta di Jon Skeets ...
string xml = @"<r25:spaces xmlns:r25=""http://www.collegenet.com/r25"" pubdate=""2009-05-05T12:18:18-04:00"">"
+ @"<r25:space id=""VE1QOjRhMDAyZThhXzFfMWRkNGY4MA=="" crc="""" status=""new"">"
+ @"<r25:space_id>720</r25:space_id>"
+ @"<r25:space_name>SPACE_720</r25:space_name>"
+ @"<r25:max_capacity>0</r25:max_capacity>"
+ @"</r25:space>"
+ @"</r25:spaces>";
XDocument xdoc = XDocument.Parse(xml);
XNamespace ns = "http://www.collegenet.com/r25";
var value = (from z in xdoc.Elements(ns.GetName("spaces"))
.Elements(ns.GetName("space"))
.Elements(ns.GetName("space_id"))
select z.Value).FirstOrDefault();
Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow