xml - 使用命名空间属性和 SelectSingleNode 属性的 XPATH

标签 xml excel xpath namespaces vba

我有这个 XML - 它是 Excel 功能区的 _rels 文件:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<Relationships xmlns="http://schemas.openxmlformats.org/package/2006/relationships">
<Relationship Id="rId3" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/extended-properties" Target="docProps/app.xml"/>
<Relationship Id="rId2" Type="http://schemas.openxmlformats.org/package/2006/relationships/metadata/core-properties" Target="docProps/core.xml"/>
<Relationship Id="rId1" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument" Target="xl/workbook.xml"/>
<Relationship Id="cuID14" Type="http://schemas.microsoft.com/office/2007/relationships/ui/extensibility" Target="customUI/customUI14.xml"/>
</Relationships>

我尝试使用 SelectSingleNode 通过检查其 Type 属性来检查最后一个关系元素(ID 为“cuID14”的元素)是否存在。如果关系元素没有 xmlns 属性,即,如果我将第二行更改为 Relationships>,我的代码就可以工作。我正在尝试正确执行此操作,但无法使语法正常工作。这是我的代码,其中包含 SelectSingleNode 函数,无需 xmlns 复杂性即可工作:

Sub CheckForAttribute()
Dim oXMLDoc As MSXML2.DOMDocument60
Dim oXMLElement As MSXML2.IXMLDOMElement
Dim XmlRelsNamespace As String

XmlRelsNamespace = "xmlns:rels='http://schemas.openxmlformats.org/package/2006/relationships'"
Set oXMLDoc = New MSXML2.DOMDocument60
oXMLDoc.SetProperty "SelectionNamespaces", XmlRelsNamespace
oXMLDoc.Load "C:\Users\doug\XPATH_TESTER.xml"
'The following line works if the Relationships element to just <Relationships>
Set oXMLElement = oXMLDoc.SelectSingleNode("//Relationship[@Type='http://schemas.microsoft.com/office/2007/relationships/ui/extensibility']")
End Sub

我找到了很多示例,但没有任何示例使用具有定义的命名空间的属性。我尝试过诸如 oXMLDoc.SelectSingleNode("//rels:Relationship[@rels:Type='http:...

最佳答案

您的第二次尝试非常接近。

而不是

//rels:Relationship[@rels:Type='http:...`

你应该使用

//rels:Relationship[@Type='http:...

因为属性不属于默认命名空间——只是元素。

另请参阅:

关于xml - 使用命名空间属性和 SelectSingleNode 属性的 XPATH,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47384719/

相关文章:

c# - 更改数据行字段值

Excel从字符串的任意部分提取一个单词

python - 如何使用 Selenium WebDriver 和 Python 提取元素中的文本?

xml - 在同一级别为同一 XML 元素呈现不同的模板

java - Jaxb 不保留包中命名空间的大小写

excel - 如何创建一个列出包含 "yes"的先前字段的标题的字段?

mysql - 使用 XPATH fn :concat in MySQL ExtractValue does not process more than two arguments

xpath - XPath 中是否有 "if -then - else "语句?

java xml注释获取带有命名空间的字段,<aaa :bbb>value</aaa:bbb>

安卓 XML 错误信息