问题描述
对于尝试通过具有两个名称空间的XML使用xPath进行搜索的其他人,我遇到了类似的问题,但仍在寻找似乎不起作用的其他主题:
I have simillar problem to others trying to search with xPath through XML with two namespaces but still looking on other topics it dosen't seem to work:
XML:
<?xml version="1.0" encoding="utf-8"?>
<IE515 xmlns:ds="http://www.w3.org/2000/09/xmldsig#" xmlns="http://www.mf.gov.pl/xsd/ECS/IE515_v1-0.xsd" NrWlasny=""
EmailPodmiotu="">
<Zgloszenie UCWywozu="" UCWyprowadzenia="PL441010"
P1a="EX" P1b="A" LiczbaPozycji="" LiczbaOpakowan="" CRN=""
KrajWysylki="" KrajPrzeznaczenia="" Kontenery="0" MasaBrutto="">
<Nadawca TIN="" Nazwa="" UlicaNumer="" KodPocztowy="" Miejscowosc=""
Kraj="" EORI=""/>
<Odbiorca Nazwa="" UlicaNumer="" KodPocztowy=""
Miejscowosc="" Kraj=""/>
<ZglaszajacyPrzedstawiciel KodPocztowy=""
Miejscowosc="" Kraj="" Nazwa="" TIN="" EORI="" UlicaNumer=""
Wskaznik="00300" Przedstawicielstwo="1"/>
<TransportWewnetrzny
Rodzaj="5"/>
<TransportNaGranicy Rodzaj="4" Znaki="SAMOLOT"
Kraj="DE"/>
<Lokalizacja UC=""/>
<WarunkiDostawy Kod=""
MiejsceKod="" Miejsce=""/>
<Transakcja Waluta="" Wartosc=""
Kurs=""/>
<MiejsceData Miejsce="" NazwiskoImie="" Telefon=""
Data=""/>
<Towar Nr="1" OpisTowaru="TestName" KodTowarowy="30000" KodTaric="00"
KrajPochodzenia="PL" ProceduraWnioskowana="10"
ProceduraPoprzednia="00" MasaNetto="1.4">
<IloscTowaru Jm="NAR"
KwalifikatorJm="G" Ilosc="8"/>
<Opakowanie Rodzaj="PA" Znaki=","
LiczbaOpakowan="2"/>
<KodDodatkowyUE Kod="4099"/>
<DokumentWymagany
Kod="9DK8" Nr="Oswiadczenie"/>
<DokumentWymagany Kod="N380"
Nr="OUT1"></DokumentWymagany>
<DokumentWymagany Kod="Y903"
Nr=","/>
<DokumentWymagany Kod="Y935" Nr=","/>
<DokumentWymagany
Kod="Y922" Nr=","/>
<InformacjaDodatkowa Kod="30400"/>
<WartoscTowaru
Waluta="PLN" WartoscStatystyczna="953">
<Korekta Kod="1STW"
Wartosc="-200"/>
</WartoscTowaru>
</Towar>
</Zgloszenie>
</IE515>
在我的代码中,我试图像这样设置NameSpace属性:
in my code I'm trying to set NameSpace propoerty like this:
xmlNameSpaces = "xmlns='http://www.mf.gov.pl/xsd/ECS/IE515_v1-0.xsd' xmlns:ds='http://www.w3.org/2000/09/xmldsig#'"
doc.setProperty "SelectionNamespaces", xmlNameSpaces
,然后尝试搜索特定的节点,但找不到该节点:
and then try to search for the specific node, but it dosen't find the node:
Set oAttribute = doc.SelectSingleNode("/IE515/Zgloszenie/Towar[1]/@OpisTowaru")`
您能解释一下命名空间属性如何使其发挥作用吗?如果有,我可以这样做
Can you explain how the namespace propperty should look like to make it work? I can do this if I have onl
推荐答案
在设置 SelectionNamespaces
属性时,需要为名称空间分配前缀,以便稍后可以在xpath中使用该前缀:
You need to assign prefix to the namespace when setting SelectionNamespaces
property, so that you can use the prefix in your xpath later on :
xmlNameSpaces = "xmlns:d='http://www.mf.gov.pl/xsd/ECS/IE515_v1-0.xsd'"
doc.setProperty "SelectionNamespaces", xmlNameSpaces
Set oAttribute = doc.SelectSingleNode("/d:IE515/d:Zgloszenie/d:Towar[1]/@OpisTowaru")
xpath上方的
通知前缀 d:
对应于 xmlNameSpaces
中的 xmlns:d
.
Notice prefix d:
in above xpath corresponds to the xmlns:d
in xmlNameSpaces
.
这篇关于具有多个名称空间的VBA SelectSingleNode xpath的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!