我使用下面的XQuery代码来选择exist-db集合中的所有.html文档。脚本应该使用文档URI和标题(作为第一个H1元素存储)创建一个XML文档(序列化为JSON)。然而,元素仍然是空的。为什么?
xquery version "3.0";
declare option exist:serialize "method=json media-type=text/javascript";
<result> {
let $data-collection := '/db/output'
for $doc in collection($data-collection)
where contains(base-uri($doc), '.html')
return
<item>
<url>{base-uri($doc)}</url>
<title>{$doc/h1/text()}</title>
</item>
}
</result>发布于 2014-06-30 13:47:24
我简化了对HTML文档的查找,但我认为您的h1元素不是文档的根,相反,我假设它可能在文档中的任何位置,因此使用了descendant-or-self轴,例如//,而且由于您的HTML可能位于名称空间中,所以我使用了*:前缀来指示任何名称空间。
xquery version "3.0";
declare option exist:serialize "method=json media-type=text/javascript";
<result> {
let $data-collection := '/db/output'
for $doc in collection($data-collection)[ends-with(base-uri(.), '.html')]
return
<item>
<url>{base-uri($doc)}</url>
<title>{$doc//*:h1/text()}</title>
</item>
}
</result>https://stackoverflow.com/questions/24490993
复制相似问题