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

How to extract sub-categories of different levels from a root category using DBPedia?

我想使用 DBPedia 提取 "psychology" 的所有子类别(特别是,我认为 this page 作为起点)。

我在 SPARQL endpoint 中写了这个查询,但它 returns 是一个空集:

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是根,我想从所有级别提取子类别不仅是根的直接子类别。以心理学为例,我该怎么做?

(此答案是针对最初发布的问题)

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

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

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

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