我使用SKOS创建了一个本体,它包含两个概念,concept1
和concept2
。我在Temperature Sensor
中添加了一个首选标签Temperature@en
和三个替代标签Temp@en
,T@en
和concept1
。
我希望当我向包含Temp
,T
或Temperature
的目标概念发送请求时,SKOS会以相同的概念回复Temperature Sensor
(其中在优选标签中定义)。
我怎样才能做到这一点?是否可以使用SKOS实现这一目标? rdf
文件的一部分如下所示。
<skos:Concept rdf:about="TemperatureSensor">
<skos:altLabel xml:lang="en">T</skos:altLabel>
<skos:altLabel xml:lang="en">Temp</skos:altLabel>
<skos:altLabel xml:lang="en">Temperature</skos:altLabel>
<skos:prefLabel xml:lang="en">TemperatureSensor</skos:prefLabel>
<skos:inScheme rdf:resource="conceptSchemeSensors"/></skos:Concept>
答案 0 :(得分:1)
您提供的数据尚未完成;它缺少一些前缀声明,它使用相对IRI,但没有定义基本IRI。以下是我们可以使用的完整数据:
<rdf:RDF
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:skos="http://www.w3.org/2004/02/skos/core#">
<skos:Concept rdf:about="http://stackoverflow.com/q/27958866/1281433/TemperatureSensor">
<skos:altLabel xml:lang="en">T</skos:altLabel>
<skos:altLabel xml:lang="en">Temp</skos:altLabel>
<skos:altLabel xml:lang="en">Temperature</skos:altLabel>
<skos:prefLabel xml:lang="en">TemperatureSensor</skos:prefLabel>
<skos:inScheme rdf:resource="http://stackoverflow.com/q/27958866/1281433/conceptSchemeSensors"/>
</skos:Concept>
</rdf:RDF>
这是我们可以在同一数据上运行的SPARQL查询。它检索所有概念,它们的首选标签以及它们的替代标签。然后它使用 coalesce 来获取任何首选标签,如果没有这些标签,则为该概念的任何替代标签。
prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>
prefix skos: <http://www.w3.org/2004/02/skos/core#>
prefix : <http://stackoverflow.com/q/27958866/1281433/>
select ?concept (coalesce(sample(?prefLabel),sample(?altLabel)) as ?label) where {
?concept skos:altLabel ?altLabel ;
skos:prefLabel ?prefLabel .
}
group by ?concept
-----------------------------------------------
| concept | label |
===============================================
| :TemperatureSensor | "TemperatureSensor"@en |
-----------------------------------------------