例如,我需要我的结果为
形式<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>
答案 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从输入中选择节点,并添加工具以在输出中构造新节点。