【问题标题】:VBA SelectSingleNode xpath with multiple namespace具有多个命名空间的 VBA SelectSingleNode xpath
【发布时间】:2015-04-20 20:46:18
【问题描述】:

对于其他尝试使用 xPath 通过 XML 和两个命名空间进行搜索但仍在寻找其他似乎不起作用的主题的人,我遇到了类似的问题:

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")`

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

【问题讨论】:

  • "如果我只有...",你介意完成你的句子吗?
  • 对不起,有些东西被删掉了,当我删除第二个名字时它可以工作:xmlns="http://www.mf.gov.pl/xsd/ECS/IE515_v1-0.xsd 但是当我有两个时,它不会:/

标签: xml vba excel xpath


【解决方案1】:

您需要在设置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

【讨论】:

  • 这不起作用:/它仅在我通过向 sceond 命名空间添加前缀(例如 S)来修改 xml(仅用于测试)时才有效,然后它可以正常工作 &lt;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=""&gt; 但我可以t改变xml ..
  • 嗨@user3313162,请再次仔细查看答案。无需更改您的XML,您只需在xmlNameSpaces 变量中添加前缀,并在SelectSingleNode() 参数中添加xpath。
  • 如果您最终仍然无法让它工作,请发布您的更新代码,展示您是如何尝试实施建议的解决方案的。
猜你喜欢
  • 2016-03-24
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多