我已经有一个算法来检索 Xml 的 XPath 表达式:
但是,它不完善、不安全,并且需要大量额外的修饰来格式化获得的表达式。(对于所需格式的示例,我的意思是:Get avaliable XPaths and its element names using HtmlAgilityPack)
然后,我最近发现了XPathNavigator类,为了以任何方式提高我当前代码的可靠性,我想知道使用XPathNavigator
该类是否可以检索 Xml 文档的所有 XPath 表达式,因为这样我的算法可以是基于.Net框架逻辑及其规则的效率,而不是单个程序员的不完善逻辑。
我在 C# 或 Vb.Net 中搜索解决方案。
这是我尝试过的:
Dim xDoc As XDocument =
<?xml version="1.0"?>
<Document>
<Tests>
<Test>
<Name>A</Name>
<Value>0.01</Value>
<Result>Pass</Result>
</Test>
<Test>
<Name>A</Name>
<Value>0.02</Value>
<Result>Pass</Result>
</Test>
<Test>
<Name>B</Name>
<Value>1.01</Value>
<Result>Fail</Result>
</Test>
</Tests>
</Document>
Dim ms As New MemoryStream
xDoc.Save(ms, SaveOptions.None)
ms.Seek(0, SeekOrigin.Begin)
Dim xpathDoc As New XPathDocument(ms)
Dim xpathNavigator As XPathNavigator = xpathDoc.CreateNavigator
Dim nodes As XPathNodeIterator = xpathNavigator.Select(".//*")
For Each item As XPathNavigator In nodes
Console.WriteLine(item.Name)
Next
使用该代码,我只能设法获得这种(不希望的)输出:
Document
Tests
Test
Name
Value
Result
Test
Name
Value
Result
Test
Name
Value
Result
Test
Name
Value
Result
是否可能使用XPathNavigator类提取所有 XPath 表达式?