xmllint提取没有xpath的值

问题描述 投票:1回答:1

我需要在xml中验证元素的xml textvalue,如下所示,到目前为止,我得到了所有dmdindex:字段的值,但我只需要最后一个drep.rightsFacet结果输出。请记住,xmllint版本我没有xpath所以我不得不求助于xmllint --shell。任何帮助表示赞赏。

这是xml文件片段:

<?xml version="1.0" encoding="UTF-8"?>
<dmdindex:dmdindex xmlns:dmdindex="http://www.example.com/example/dmdindex/"
                   xmlns:functx="http://www.functx.com"
                   xmlns:xs="http://www.w3.org/2001/XMLSchema"
                   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
   <dmdindex:record>
      <dmdindex:field name="drep.yearStart">1881</dmdindex:field>
      <dmdindex:field name="drep.pubConcat">[Detroit : Parke, Davis &amp; Co., 1881?]</dmdindex:field>
      <dmdindex:field name="drep.rights">blahblahblah</dmdindex:field>
      <dmdindex:field name="drep.rightsLink">https://creativecommons.org/publicdomain/mark/1.0/</dmdindex:field>
      <dmdindex:field name="drep.rightsFacet">Public domain</dmdindex:field>
   </dmdindex:record>
</dmdindex:dmdindex>

这是我用过的命令

echo "cat //*[local-name()='dmdindex']/*[local-name()='record']/*[local-name()='field']" | xmllint --shell example.xml | sed '/^\/ >/d' | sed 's/<[^>]*.//g'

哪个回来了

 -------
Philadelphia : Sunshine Press, [1897]
 -------
blahblahblah
 -------
https://creativecommons.org/publicdomain/mark/1.0/
 -------
Public domain

我只需要抓住“公共领域”的价值而忽略其余的。谢谢!

xml-parsing xmllint
1个回答
1
投票

您可以在xpath中添加谓词来测试name属性的值...

echo "cat //*[local-name()='dmdindex']/*[local-name()='record']/*[local-name()='field'][@name='drep.rightsFacet']/text()" | xmllint --shell example.xml | sed '/^\/ >/d'
© www.soinside.com 2019 - 2024. All rights reserved.