我有一个XML流,其中包含以下XML内容:
<WebError Key="A">
<Message>B</Message>
<Parameters>
<Parameter name="C">D</Parameter>
</Parameters>
</WebError>
我找不到一种方法使XmlReader
读取Key
属性,以便reader.NodeType
为XmlNodeType.Attribute
,而reader.LocalName
为"Key"
。以下是如何初始化XmlReader
:
XmlReader.Create(stream, new XmlReaderSettings { CloseInput = true, IgnoreWhitespace = true });
这个读取器经过多个方法级别的处理,最终到达我的解析器函数。
这里是我尝试获取读取器读取该元素的所有替代代码。为了让您只看到实际调用的函数,我从代码中剥离了控制结构。
第一次尝试,通过调用MoveToFirstAttribute()
移动到属性:
reader.Read(); // true
reader.IsStartElement("WebError"); // true
using (var nodeReader = reader.ReadSubtree()) {
nodeReader.HasAttributes; // true
nodeReader.MoveToFirstAttribute(); // false
nodeReader.Read(); // true
nodeReader.NodeType; // XmlNodeType.Element
nodeReader.LocalName; // "WebError"
using (var subLevelReader = nodeReader.ReadSubtree()) {
}
nodeReader.Read(); // false
}
显然,
MoveToFirstAttribute
并不移动读取器。作为副作用,通常用于解析内部 XmlElement
节点的 subLevelReader
现在抓取整个 WebError
节点,并在 subLevelReader
被处理时,整个 WebError
节点被跳过。第二次尝试,请调用
MoveToContent()
并搜索属性:reader.Read(); // true
reader.IsStartElement("WebError"); // true
using (var nodeReader = reader.ReadSubtree()) {
nodeReader.MoveToContent(); // XmlNodeType.Element
nodeReader.LocalName; // "WebError"
nodeReader.Read(); // true
nodeReader.NodeType; // XmlNodeType.Element
nodeReader.LocalName; // "Message"
...
}
显然,当我调用
MoveToContent()
时,我已经进展太远了,因为它移动到了WebError
开始标签的末尾。
第三次尝试,在调用MoveToContent()
之前读取属性:
reader.Read(); // true
reader.IsStartElement("WebError"); // true
using (var nodeReader = reader.ReadSubtree()) {
nodeReader.MoveToAttribute("Key"); // false
nodeReader.MoveToContent(); // XmlNodeType.Element
nodeReader.LocalName; // "WebError"
nodeReader.Read(); // true
nodeReader.NodeType; // XmlNodeType.Element
nodeReader.LocalName; // "Message"
...
}
这也不起作用。那么,我该如何进入WebError@Key
节点?