如何选择使用默认命名空间的节点?

Joh*_*ith 1 c# xml xpath xsd xml-namespaces

XML文件的结构大致如下:

<?xml version="1.0" encoding="UTF-8"?>
<a xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="url1" xsi:schemaLocation="url2 url3">
   <b>
     <c></c>
     <c></c>
     <c></c>
   </b>
</a>
Run Code Online (Sandbox Code Playgroud)

我的目标是选择所有“c”元素,但以下 xpath 表达式不起作用:“//a/b/c”。

IE:

XmlDocument doc= new XmlDocument();
doc.Load(filepath);
XmlNodeList l = doc.SelectNodes("//a/b/c"); // 0 nodes
Run Code Online (Sandbox Code Playgroud)

我测试过的唯一有效的 xpath 表达式是 /*(1 个节点)和 //*(所有节点)。

这个问题是否与 XML 命名空间有关?如果是这样,设置 XMLDocument 对象的正确方法是什么?

        XmlDocument doc= new XmlDocument();
        doc.Load(filepath);
        XmlNamespaceManager m = new XmlNamespaceManager(doc.NameTable);
        m.AddNamespace(/* what goes here? */);
        XmlNodeList l = doc.SelectNodes("//a/b/c", m);
Run Code Online (Sandbox Code Playgroud)

JLR*_*she 6

您需要为文档使用的默认名称空间分配名称空间前缀,然后在您的 XPath 中使用它:

XmlDocument doc= new XmlDocument();
doc.Load(filepath);

XmlNamespaceManager m = new XmlNamespaceManager(doc.NameTable);
m.AddNamespace("myns", "url1");

XmlNodeList l = doc.SelectNodes("/myns:a/myns:b/myns:c", m);
Run Code Online (Sandbox Code Playgroud)

只要第 4 行和 XPath 之间保持一致,并且正确分配给第 4 行中的“url1”命名空间,您就可以用任何东西(没有空格的字母数字)替换前缀“myns”。

  • 是只有我一个人觉得这样还是每次我们必须处理命名空间时,API 都感觉像一块石头?我的意思是它是默认名称空间......并且添加名称空间对于这些标签是强制性的。愚蠢的。我知道 xml 可能包含命名空间和非命名空间部分。至少他们可以允许`SelectNodes("/:a/:b/:c")`,但是没有...... (3认同)