我有一个从下面创建的XML对象:
<?xml version="1.0" encoding="UTF-8"?>
<pdfDoc>
  <XMLOutput>
    <webservice>
      <residentLocationData>
        <addressDataMap>
          <entry>
            <key>Zip</key>
            <value>08094</value>
          </entry>
          <entry>
            <key>CountyCode</key>
            <value>015</value>
          </entry>
          <entry>
            <key>StateName</key>
            <value>New Jersey</value>
          </entry>
        </addressDataMap>
      </residentLocationData>
    </webservice>
  </XMLOutput>
<pdfDoc>我正在尝试提取"New Jersey“的字符串值。为了获取"value“元素本身,我使用:
//addressDataMap/entry/key[text() = 'StateName']/following-sibling::value但是我还没有在网上看到任何关于如何仅使用XPath本身来获取该元素的xmlText的字符串值的内容。我可以使用我正在使用的语言(Coldfusion)中的代码来获取该字符串:
<cfset theState = xmlSearch(L.xmlObj, "//addressDataMap/entry/key[text() = 'StateName']/following-sibling::value")[1].xmlText>但我不清楚如何仅使用XPath来获取字符串"New Jersey“。
发布于 2021-04-29 10:31:19
这个XPath,
//entry[key='StateName']/value/text()将根据请求选择与'StateName' key关联的"New Jersey" value。
发布于 2021-04-29 07:11:27
//addressDataMap/entry/key[text() = 'StateName']/following-sibling::value/text()
或
string(//addressDataMap/entry/key[text() = 'StateName']/following-sibling::value)
应该行得通。
发布于 2021-04-29 09:32:51
尝试使用
//addressDataMap/entry[key/text()='StateName']/value/text()它应该会给出字符串"New Jersey“。
https://stackoverflow.com/questions/67309032
复制相似问题