gpt4 book ai didi

sparql - dbpedia 以英语以外的语言获取实体

转载 作者:行者123 更新时间:2023-12-04 14:42:11 26 4
gpt4 key购买 nike

我正在尝试使用 sparql 从 dbpedia 中提取包含人名等的实体字典。

PREFIX owl: <http://dbpedia.org/ontology/>
PREFIX dbpprop: <http://dbpedia.org/property/>
SELECT ?name
WHERE {
?person a owl:Person .

?person dbpprop:name ?name . FILTER(lang(?name) = "en")
}

上面的查询确实成功了,但是当我将语言名称更改为 fr 时,没有什么可取的。

如何获取其他语言的名称?

此外,为什么我不能使用下面的查询过滤语言?
SELECT ?name
WHERE {
?person a owl:Person .
?person dbpprop:language "English"
?person dbpprop:name ?name .
}
// this query returns nothing

我尝试使用获取所有语言
SELECT DISTINCT ?lanName
WHERE {
?person a owl:Person .
?person dbpprop:language ?lanName .
}

结果集包含 English .

最佳答案

您需要根据属性值的语言进行过滤。并非每个属性都有不同语言的值,但有些属性会有。从你的例子看来, dbprop:名称 不是每种语言都有值(value)。如果您查看其他语言特定的 DBpediae,您可能会在其他语言中找到更多值。

然而,对于像名字这样的东西,如果你使用 ,你可能会得到多语言的结果。 rdfs:标签属性(property)。例如,要获取俄语版 Barack Obama、Daniel Webster 和 Johnny Cash 的名字,您可以执行以下操作:

select ?label {
values ?person { dbpedia:Johnny_Cash dbpedia:Barack_Obama dbpedia:Daniel_Webster }
?person rdfs:label ?label .
filter langMatches(lang(?label),"ru")
}

SPARQL results

顺便说一句,请注意 langMatches 的使用而不是匹配语言标签的平等。这通常是一种更好的方法,因为它会正确处理一种语言中的不同语言标记。例如(来自 SPARQL 规范),您可以找到两种法语文字:
"Cette Série des Années Soixante-dix"@fr .
"Cette Série des Années Septante"@fr-BE .

langMatches(lang(?title),"fr") ,但只有第一个 lang(?title) = "fr" .

关于sparql - dbpedia 以英语以外的语言获取实体,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29069479/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com