xQuery:始终相同的错误:括号未关闭

问题描述

我想使用xQuery将此XML文档(factbook.xml)转换为HTML。
但是代码(可以在下面的XML下找到)无效。

我总是遇到相同的错误(我使用BaseX 9.4.2)

错误
停在C:/ Program Files(x86)/ BaseX / etc / file2,9/6:
[XPST0003]期望为“}”,发现为“ {”

我不明白为什么总是出现相同的错误,所有括号都闭合。

这是我的XML文件:(部分)

<mondial>
 <continent id="f0_119" name="Europe"/>
 <continent id="f0_123" name="Asia"/>
 ...
<country id="f0_136" name="Albania"
 capital="f0_1461" population="3249136" total_area="28750">
 <city id="f0_1461" country="f0_136">
 <name>Tirane</name>
 <population>192000</population>
 </city>
 ...
 <encompassed continent="f0_119" percentage="100"/>
 </country>
<country id="f0_149" name="Austria"
 capital="f0_1467" population="8023244" total_area="83850">
 <province id="f0_17448" name="Upper Austria"
 capital="f0_2267" population="1373000">
 <city id="f0_2267">
 <name>Linz</name>
 <population>203000</population>
 </city>
 </province>
 <province id="f0_17447" name="Vienna"
 capital="f0_1467" population="1583000">
 <city id="f0_1467">
 <name>Vienna</name>
 <population>1583000</population>
 </city>
 </province>
 ...
 <encompassed continent="f0_119" percentage="100"/>
 </country>
 ...
<country id="f0_670" name="Turkey"
 capital="f0_1797" population="62484480" total_area="780580">
 <province id="f0_19040" name="Ankara"
 capital="f0_1797" population="3236626">
 <city id="f0_1797">
 <name>Ankara</name>
 <population>2782200</population>
 </city>
 </province>
 ...
 <encompassed continent="f0_119" percentage="32"/>
 <encompassed continent="f0_123" percentage="68"/>
 </country>
</mondial>

这是我的xQuery代码

let $db := /mondial
let $html := 
<html>
<body>
{
  for $cont in $db/continent
  order by $cont/@name
  return <h1>""{$cont/@name}</h1> 
     {
      for $coun in $db/country
      order by $coun/@name
      where $cont/@id = $count//encompassed/@continent
      return <p>
         <h2>{coun/@name}</h2>
         <b>Capital:</b>
         {
           for $cap in $coun//city 
           where $coun/@capital = $cap/@id
           return $cap/name
         }
         <b>Total Area "in" {$cont/@name}:</b>
         {
           for $area in $coun//encompassed[@continent = $cont/@id]/percentage
           return data($coun/@total_area) * ($area div 100)
         }    
      </p>
    }
} </body> </html>
return $html

预先感谢您的帮助

解决方法

Saxon报告相同的错误:

Analyzing query from test.xq
Static error near {.../@name}</h1> { for} on line 8 at column 6 of file:/***/test.xq 
  XPST0003  expected "}",found "{"
Static error(s) in query

我不得不承认这不是立即显而易见的。但是问题出在return <h1>""{$cont/@name}</h1> 之后的“ {”。我认为(从缩进来看),您可能希望此块成为return子句的一部分,在这种情况下,它必须是

let $db := /mondial
let $html := 
<html>
<body>
{
  for $cont in $db/continent
  order by $cont/@name
  return (<h1>""{$cont/@name}</h1>,for $coun in $db/country
      order by $coun/@name
      where $cont/@id = $count//encompassed/@continent
      return <p>
         <h2>{coun/@name}</h2>
         <b>Capital:</b>
         {
           for $cap in $coun//city 
           where $coun/@capital = $cap/@id
           return $cap/name
         }
         <b>Total Area "in" {$cont/@name}:</b>
         {
           for $area in $coun//encompassed[@continent = $cont/@id]/percentage
           return data($coun/@total_area) * ($area div 100)
         }    
      </p>
    )
} </body> </html>
return $html

然后对于未解析的变量$count的引用,我得到一个错误,但我认为那是一个错字。

这里有两个常见错误:

  • 元素构造函数(例如<x/>)是有效的XQuery表达式,但是元素构造函数的序列(例如<x/><y/>)不是:它需要逗号(<x/>,<y/>)。
  • 如果在return之后放置一个包含逗号运算符的表达式,则需要在其周围加上括号。

另一个错误不太常见:构造"{" expr "}"不是有效的表达式。花括号只能在非常特定的位置使用,没有通用的花括号分隔块表达式可以在任何地方使用。