VBA使用多个命名空间的xpath选择单个节点

4
我有类似于其他人的问题,尝试通过具有两个命名空间的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属性,就像这样:
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")`

你能解释一下命名空间属性应该是什么样子才能使它起作用吗?如果只有 ... 我就可以做到这一点。

1
如果我只有……,我就可以做到这件事情”,请问您能完成您的句子吗? - har07
抱歉,有些东西被切掉了。当我删除第二个名称空间 xmlns="http://www.mf.gov.pl/xsd/ECS/IE515_v1-0.xsd 时,它可以工作,但是当我有两个时,就不行了 :/ - Baki
1个回答

4

当设置 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(仅供测试)时,通过为第二个命名空间添加前缀(例如S),它才能正常工作 <IE515 xmlns:ds="http://www.w3.org/2000/09/xmldsig#" xmlns:s="http://www.mf.gov.pl/xsd/ECS/IE515_v1-0.xsd" NrWlasny="" EmailPodmiotu=""> 但我不能改变xml.. - Baki
嗨@user3313162,请仔细再看一下答案。无需更改您的XML,您只需要在xmlNameSpaces变量和SelectSingleNode()参数中添加前缀即可。 - har07
如果最终你仍然无法使其正常工作,请发布你的更新代码,展示你如何尝试实现建议的解决方案。 - har07

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接