1

我必须在一个 turtle/n3 文件中执行一些过滤,返回另一个相同类型的文件。我处理的基本数据元素(位置)是这样的:

:pt0001
     vcard:category "Poste e Telegrafi"
    ; vcard:fn "Ufficio Bologna 1"
    ; vcard:extended-address "Via Cairoli 9, Bologna BO, Italy"
    ; vcard:latitude "44.504192"
    ; vcard:longitude "11.338661"
    ; vcard:tel "051 243425"
    ; vcard:fax "051 244459"
    ; cs:opening "Mon, Tue, Wed, Thu, Fri: 0800-1330. Sat: 0800-1230."
    ; cs:closing "01-01, 01-06, P, LA, 04-25, 05-01, 06-02, 08-15, 11-01, 12-08, 12-25, 12-26: .".

例如,我想搜索具有特定名称或纬度或类别的元素 (ptxxxx)。我已经被建议在查询中使用构造从 rdf 中检索三元组,因此我可以将它们添加到我正在构建的新图形/rdf 中。事实是,如果我使用正则表达式过滤器功能过滤三元组以按(不区分大小写)名称进行搜索,我只会得到一个三元组,在这种情况下定义我正在寻找的名称。例如,是否可以搜索名称为(谓词)“Ufficio Bologna 1”(宾语)的主题(ptxxxx)?

4

2 回答 2

4

如果您想获得具有该名称的主题的三元组,您可以做一个简单的描述:

describe ?s where { ?s vcard:fn "Ufficio Bologna 1". }

否则,如果您想使用正则表达式,您可以稍微修改查询

describe ?s where { ?s vcard:fn ? name. filter (regex(?name, "regex goes here")). }

需要注意的是,大型数据集上的正则表达式可能会很昂贵。许多系统提供对 SPARQL 的扩展,它将全文索引您的文字值,然后您可以使用更正常的搜索语法进行搜索。

于 2012-04-20T12:33:21.483 回答
3

我这样解决:

CONSTRUCT {?s ?p ?o}
        WHERE {
                ?s ?p ?o;
                vcard:fn ?name.
                FILTER regex (?name ,"^ufficio bologna 1$", "i")
                }
于 2012-04-21T13:20:46.663 回答