我正在使用 xpathdocument 通过它们的 xpath 表达式获取一些值,直到涉及到命名空间。
xml:
?xml version="1.0" encoding="ISO-8859-1"?>
<?xml-stylesheet href="vsstyle_xml.cgi" type="text/css"?>
<vs120data version="0x1210019" build="21.0.117" label="D21.00.117SAEN060223"
xmlns:html="http://www.w3.org/1999/xhtml" SIMATIC_VS_Escaped="1">
VS120 Data from 192.168.0.43 (MAC: 08:00:06:71:8C:EE) Time Sync Info: Source was PC:
PC=192.168.0.1 - TZ is GMT/UTC +1h. Last Synchronization: Feb 27, 2006, 16:41:08.
Current Timestamp: Feb 27, 2006, 16:44:14. HWVers: 0x34<html:title>VS120
Data from 192.168.0.43 (MAC: 08:00:06:71:8C:EE) at Feb 27, 2006, 16:44:14.
</html:title>
<Standard-Parameters>
Standard-Parameters
<Startup-Request>
...
<Images>
Images
<Scene>
Scene<html:img alt="html:img" src="data:image/png;base64...."
'
C#代码:
XmlNamespaceManager mgr = new XmlNamespaceManager(nav.NameTable);
mgr.AddNamespace("html", "http://www.w3.org/1999/xhtml");
XPathNavigator hc = nav.SelectSingleNode("//html:img", mgr);
我在这里只得到空节点。
当我通过 xpath 表达式使用 sandart xpath 解析时
parseXPath("/vs120data/Model/Images/Scene/html:img/@src");
我得到了命名空间问题,缺少一些前缀的东西。