SPARQL 查询以获取定义了命名空间前缀的所有类标签

RN *_*wan 5 semantic-web sparql

我想获取存储在芝麻存储库中的所有类。

这是我的查询

SELECT ?class ?classLabel
WHERE {
?class rdf:type rdfs:Class.
?class rdfs:label ?classLabel.
}
Run Code Online (Sandbox Code Playgroud)

它返回带有标签的类的所有 URI。例如,

"http://example.com/A_Class" "A_Class"
"http://example.com/B_Class" "B_Class"
Run Code Online (Sandbox Code Playgroud)

但是,如果已经定义了命名空间前缀,我想获取定义了命名空间的标签。例如,如果我已经为“ http://example.com/ ”定义了名称空间前缀“ex”,则结果变为

"http://example.com/A_Class" "ex:A_Class"
"http://example.com/B_Class" "ex:B_Class"
Run Code Online (Sandbox Code Playgroud)

Ste*_*ris 5

您想将 URI 前缀添加到标签字符串的前面吗?

我想您可能对 URI 前缀的作用感到困惑。它们只是完整 URI 的简写,不是 URI 的一部分,并且与字符串没有任何关系。

你可以做你想做的事情

SELECT ?class (CONCAT("ex:", ?classLabel) AS ?label
WHERE {
   ?class rdf:type rdfs:Class.
   ?class rdfs:label ?classLabel.
}
Run Code Online (Sandbox Code Playgroud)

但前缀不依赖于 URI 的前缀。

你可以有一个 IF() 链来测试 STR(?class) 的起始字符,但它很快就会变得丑陋:

BIND(IF(STRSTARTS(STR(?class), "http://example.com/"), "ex:", "other:") as ?prefix)
Run Code Online (Sandbox Code Playgroud)

然后

SELECT ... (CONCAT(?prefix, ?classLabel) AS ?label
Run Code Online (Sandbox Code Playgroud)

几乎可以肯定,有一种比在 SPARQL 中更简单的方法来获得你想要的东西:)


Jos*_*lor 5

我同意其他答案,这些答案说你正在尝试做一件奇怪的事情,至少正如问题中所述。将前缀与 the 关联起来rdfs:label并不是很有用,因为生成的字符串可能代表也可能不代表该类的实际 URI。假设您想要做的实际上是在给定一组前缀定义的情况下找出 URI 的前缀名称,您可以在 SPARQL 中执行此操作,而不需要大量嵌套IFVALUES您可以使用 a和 a来完成FILTER

给定这样的数据,其中定义了许多类(我在这里没有定义任何标签,因为它们对于本示例来说不是必需的),

@prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#> .
@prefix ex1: <http://example1.com/> .
@prefix ex2: <http://example2.com/> .
@prefix ex3: <http://example3.com/> .
@prefix ex4: <http://example4.com/> .

ex1:A a rdfs:Class .
ex1:B1 a rdfs:Class .

ex2:A a rdfs:Class .
ex2:B2 a rdfs:Class .

ex3:A a rdfs:Class .
ex3:B3 a rdfs:Class .

ex3:A a rdfs:Class .
ex3:B4 a rdfs:Class .

ex4:A a rdfs:Class .
ex4:B4 a rdfs:Class .
Run Code Online (Sandbox Code Playgroud)

您可以编写这样的查询来选择所有类,检查它们的 URI 是否以多个定义的名称空间之一开头,如果是,则返回该类和前缀形式:

prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#> 

select ?class (group_concat(?prefixedName ; separator = "") as ?prefName) where {
  values (?prefix ?ns) { 
    ( "ex1:" <http://example1.com/> )
    ( "ex2:" <http://example2.com/> )
    ( "ex3:" <http://example3.com/> )
  }
  ?class a rdfs:Class .
  bind( if( strStarts( str(?class), str(?ns) ),
            concat( ?prefix, strafter( str(?class), str(?ns) )),
            "" ) 
        as ?prefixedName )
}
group by ?class
order by ?class
Run Code Online (Sandbox Code Playgroud)

结果如下:

$ arq --data data.n3 --query query.sparql
---------------------------------------
| class                    | prefName |
=======================================
| <http://example1.com/A>  | "ex1:A"  |
| <http://example1.com/B1> | "ex1:B1" |
| <http://example2.com/A>  | "ex2:A"  |
| <http://example2.com/B2> | "ex2:B2" |
| <http://example3.com/A>  | "ex3:A"  |
| <http://example3.com/B3> | "ex3:B3" |
| <http://example3.com/B4> | "ex3:B4" |
| <http://example4.com/A>  | ""       |
| <http://example4.com/B4> | ""       |
---------------------------------------
Run Code Online (Sandbox Code Playgroud)