如何更改XPath查询返回的节点的值?

时间:2012-07-24 17:04:48

标签: xpath

例如,我需要我的结果为

形式
<result>
  <French>
    <country>country-name</country>
    <country>country-name</country>
    ...
  </French>
  <German>
    <country>country-name</country>
    <country>country-name</country>
    ...
  </German>
</result>

但目前,我的结果是

形式
  <language percentage="100">German</language>
  <language percentage="32">French</language>
  <language percentage="1">German</language>
  <language percentage="100">French</language>
  <language percentage="100">French</language>
  <language percentage="100">German</language>
  <language percentage="99">French</language>
  <language percentage="100">French</language>
  <language percentage="10">French</language>
  <language percentage="32">German</language>
  <language percentage="100">French</language>
  <language percentage="18">French</language>
  <language percentage="65">German</language>

这是我的疑问:

 doc("countries.xml")//country/language[contains(text(), "French") or contains(text(), "German")]

原始数据如下所示:

<country name="Afghanistan" population="22664136" area="647500">
    <language percentage="11">Turkic</language>
    <language percentage="35">Pashtu</language>
    <language percentage="50">Afghan Persian</language>
</country>

3 个答案:

答案 0 :(得分:1)

使用XQuery,这将解决问题:

  <result>
  {
    for $language in distinct-values(doc("countries.xml")//language)
    return
      element {translate($language, " ", "_")}
      {
        for $country in doc("countries.xml")//country[language = $language]
        return element country {string($country/@name)}
      }
  }
  </result>

请注意,该语言不能立即用作标记名称,因为它包含空格(如“阿富汗波斯语”) - 因此调用translate

如果您只想要命名的语言,请用

替换for子句
    for $language in ("French", "German")

答案 1 :(得分:0)

您可以使用LinQ to XML / Object,使用GroupBy创建查询并使用XMLWriter重写XML,或者将XML StyleSheet Transform与xml / xsl一起使用。

答案 2 :(得分:0)

XPath只能选择输入文档中的节点。如果要构造新的输出文档,可以使用XSLT或XQuery执行此操作,两者都使用XPath从输入中选择节点,并添加工具以在输出中构造新节点。