请注意这个问题是专用于XmlReader
而不是是否使用XDocument
或XmlReader
。为什么XmlReader会跳过元素?
我有一个XML片段:
private string GetXmlFragment()
{
return @"<bookstore>
<book genre='novel' ISBN='10-861003-324'>
<title>The Handmaid's Tale</title>
<price>19.95</price>
</book>
<book genre='novel' ISBN='1-861001-57-5'>
<title>Pride And Prejudice</title>
<price>24.95</price>
</book>
</bookstore>";
}
我也有一个扩展的方法:
public static IEnumerable<XElement> GetElement(this XmlReader reader, string elementName)
{
reader.MoveToElement();
while (reader.Read())
{
if (reader.NodeType == XmlNodeType.Element
&& reader.Name.Equals(elementName, StringComparison.InvariantCulture))
{
yield return XNode.ReadFrom(reader) as XElement;
}
}
}
然后我尝试做让两个book
元素:
var xmlReaderSettings = new XmlReaderSettings
{
CheckCharacters = false,
ConformanceLevel = ConformanceLevel.Fragment,
IgnoreComments = true,
IgnoreWhitespace = true,
IgnoreProcessingInstructions = true
};
using (var stringReader = new StringReader(this.GetXmlFragment()))
using (var xmlReader = XmlReader.Create(stringReader, xmlReaderSettings))
{
xmlReader.GetElement("book").Count().ShouldBe(2);
}
但是我只获得第一个元素,调试ging表明,只要我得到第一个元素,阅读器跳到第二个book
元素的title
。
溶液从HERE
任何帮助的启发是非常赞赏。
无法重现。你的方法在我的机器上产生一个包含两个元素的序列。你确定'this.GetXmlFragment()'生成你提供的XML吗? –
奇怪的是,我已经更新了问题以包含方法 – babayi
请参阅https://dotnetfiddle.net/ssrAG1。不知怎的,你的调试干扰了吗? –