gpt4 book ai didi

xml - 具有多个命名空间的 VBA SelectSingleNode xpath

转载 作者:数据小太阳 更新时间:2023-10-29 02:29:42 27 4
gpt4 key购买 nike

我遇到了与其他人类似的问题,他们试图通过具有两个 namespace 的 XML 使用 xPath 进行搜索,但仍在寻找其他主题,但它似乎不起作用:

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 propoerty:

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

然后尝试搜索特定节点,但找不到该节点:

Set oAttribute = doc.SelectSingleNode("/IE515/Zgloszenie/Towar[1]/@OpisTowaru")`

您能解释一下命名空间属性应该如何运作吗?如果我有,我可以做到这一点

最佳答案

在设置SelectionNamespaces 属性时,您需要为命名空间分配前缀,以便您稍后可以在xpath 中使用该前缀:

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

关于xml - 具有多个命名空间的 VBA SelectSingleNode xpath,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29747444/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com