[英]Read xml Element value WITHOUT cdata?
我有这个简单的xml:
<AllBands>
<Band>
<Name ID="1234" started="1962">Beatles<![CDATA[lalala]]></Name>
<Last>1</Last>
<Salary>2</Salary>
</Band>
<Band>
<Name ID="222" started="1968">Doors<![CDATA[lalala]]></Name>
<Last>1</Last>
<Salary>2</Salary>
</Band>
</AllBands>
我想从Name
元素中读取“ bealtes
”值
通过
using (var stream = new StringReader(result))
{
XDocument xmlFile = XDocument.Load(stream);
var query = from c in xmlFile.Descendants("Band") select c;
foreach (XElement band in query)
{
if (band.Element("Name").Value ==...) // this expression is beatleslalala
// and not beatles alone...
}
}
这是为什么? 为什么他包括cdata? 我怎么才能得到“披头士乐队”?
您的<Name>
元素节点包含两个子节点:文本节点和CDATA节点。
该Value
的元素节点为级联的子节点的所有值。
如果需要文本节点的值,则需要获取文本节点的Value
,而不是元素。
请注意,在读取XML文件时区分文本节点和CDATA节点是很不寻常的。 文件的作者应该能够使用他们喜欢的任何东西。
您有一个文本值和一个CDATA节点作为Name的子代,这就是为什么。
如果你在名称节点内挖掘,你将能够找到这两个部分,但你可能想要重新修改你的xml结构
<Name ID="1234" started="1962">Beatles<Lyrics><![CDATA[lalala]]></Lyrics></Name>
实际上,它的xsd会变得混乱。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.