Linq To XMLで要素の値を取得する方法
-
05-07-2019 - |
質問
Linq To XMLを使用して、以下のxmlからspace_id値(720)を取得するにはどうすればよいですか?
これを読んでいますが、 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>
編集
ここに私がいます:
private int GetIDFromXML(string xml)
{
XDocument xDoc = XDocument.Parse(xml);
// hmmm....
}
解決
あなたも一緒に行くことができます(上記のコードのわずかなバリエーションで、もう少し読みやすいと思います)
XNamespace ns = "http://www.collegenet.com/r25";
string id = doc.Descendants(ns.GetName("space_id").Single().Value;
他のヒント
クエリなどを行わずに、唯一の space_id
要素が必要な場合:
XNamespace ns = "http://www.collegenet.com/r25";
string id = doc.Descendants(ns + "space_id")
.Single()
.Value;
( doc
が XDocument
-または XElement
の場合)。
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();
所属していません StackOverflow