我希望能够针对以下具有我不关心的讨厌的 xmlns 属性的 XML评估普通XPath 表达式:
<?xml version="1.0" encoding="UTF-8"?>
<?xml-stylesheet type="text/xsl" href="AuthorIT.xslt"?>
<AuthorIT version="6.0.8" xmlns="http://www.authorit.com/xml/authorit" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.authorit.com/xml/authorit AuthorIT.xsd">
<Objects>
<Book>
<Object>
<CreatedBy>Me</CreatedBy>
<CreatedDate>2012-11-20T12:35:33</CreatedDate>
<Description>String I want to get</Description>
<FolderID>12345</FolderID>
<GUID>abcdefg1234567abcdefg1234567abcd</GUID>
<ID>99999</ID>
</Object>
</Book>
</Objects>
</AuthorIT>
在 XMLSpy(或这个免费的网络工具)中,“我想要获取的字符串”的表达式如下:
/AuthorIT/Objects/Book/Object/Description
这就是我在 c# 中指定命名空间的方式:
XPathDocument document = new XPathDocument("/path/to/my/file");
XPathNavigator navigator = document.CreateNavigator();
XmlNamespaceManager manager = new XmlNamespaceManager(navigator.NameTable);
manager.AddNamespace("abc", "http://www.authorit.com/xml/authorit");
一旦我指定了命名空间,下面是我必须修改完美的 XPath 表达式以获得相同结果的方法:
/abc:AuthorIT/abc:Objects/abc:Book/abc:Object/abc:Description
可怕,不是吗?!有没有一种方法可以评估绕过并完全忽略 AuthorIT 根元素上这个极其讨厌的“xmlns”属性的存在的 XPath 表达式?如果我完全剥离了根元素,使其单独存在,我不需要指定命名空间,我可以使用普通表达式。有没有办法告诉 .NET 就像一开始就没有“xmlns”垃圾一样工作?