如何使用DBPedia从根类别中提取不同级别的子类别?

时间:2016-06-02 15:30:51

标签: sparql dbpedia

我想使用DBPedia提取“心理学”的所有子类别(特别是,我认为this page为起点)。

SPARQL endpoint我写了这个查询,但它返回一个空集:

PREFIX  dbo:  <http://dbpedia.org/ontology/>
PREFIX  dbp:  <http://dbpedia.org/property/>

SELECT  ?branch ?discipline 
WHERE 
{
   ?branch a yago:BranchesOfPsychology
   OPTIONAL  { ?branch  dbo:academicDiscipline ?discipline }
}
ORDER BY  ?branch

此查询提取所有直接子类别。

假设Branches of psychology是一个根,我想从所有级别中提取子类别不仅提取根的直接子级。我怎么能以心理学为榜样呢?

1 个答案:

答案 0 :(得分:3)

(这个答案是最初发布的问题)

此查询存在三个问题。一个是rdfs:label对象的语法,第二个是dct:subject的方向。当这两个更正后,您的查询将如下所示:

select distinct ?subject
where {
?concept rdfs:label "Branches of psychology"@en .
?concept ^dct:subject ?subject .
} 
LIMIT 100

第三个是查询的性能。在您的情况下,如果增加执行超时,您将获得结果。 Here they are

此外,我建议避免使用字符串的三重模式。它们容易出错。