假设我有一个支离破碎的XML,如下所示.
<A>
<B></B>
</A>
<A>
<B></B>
</A>
Run Code Online (Sandbox Code Playgroud)
我可以使用XmlReaderFragment选项来解析这个not completeXML字符串.
XmlReaderSettings settings = new XmlReaderSettings();
settings.ConformanceLevel = ConformanceLevel.Fragment;
XmlReader reader;
using (StringReader stringReader = new StringReader(inputXml))
{
reader = XmlReader.Create(stringReader, settings);
}
XPathDocument xPathDoc = new XPathDocument(reader);
XPathNavigator rootNode = xPathDoc.CreateNavigator();
XPathNodeIterator pipeUnits = rootNode.SelectChildren("A", string.Empty);
while (pipeUnits.MoveNext())
Run Code Online (Sandbox Code Playgroud)
我可以使用Linq进行碎片化的XML字符串解析吗?
使用该XNode.ReadFrom()方法,您可以轻松创建一个返回XNodes 序列的方法:
public static IEnumerable<XNode> ParseXml(string xml)
{
var settings = new XmlReaderSettings
{
ConformanceLevel = ConformanceLevel.Fragment,
IgnoreWhitespace = true
};
using (var stringReader = new StringReader(xml))
using (var xmlReader = XmlReader.Create(stringReader, settings))
{
xmlReader.MoveToContent();
while (xmlReader.ReadState != ReadState.EndOfFile)
{
yield return XNode.ReadFrom(xmlReader);
}
}
}
Run Code Online (Sandbox Code Playgroud)