首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在XQuery 3.0中获取标记内容(exist-db)

在XQuery 3.0中获取标记内容(exist-db)
EN

Stack Overflow用户
提问于 2014-06-30 13:14:17
回答 1查看 80关注 0票数 1

我使用下面的XQuery代码来选择exist-db集合中的所有.html文档。脚本应该使用文档URI和标题(作为第一个H1元素存储)创建一个XML文档(序列化为JSON)。然而,元素仍然是空的。为什么?

代码语言:javascript
复制
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>
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-06-30 13:47:24

我简化了对HTML文档的查找,但我认为您的h1元素不是文档的根,相反,我假设它可能在文档中的任何位置,因此使用了descendant-or-self轴,例如//,而且由于您的HTML可能位于名称空间中,所以我使用了*:前缀来指示任何名称空间。

代码语言:javascript
复制
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>
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24490993

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档