2

我正在使用以下使用 SPARQLWrapper 的 sparql 查询,如下所示。

from SPARQLWrapper import SPARQLWrapper, JSON
sparql = SPARQLWrapper("http://live.dbpedia.org/sparql")
sparql.setReturnFormat(JSON)
sparql.setQuery(" ASK { dbc:Meteorological_concepts skos:broader{1,7} dbc:Medicine } ")
results = sparql.query().convert()
print(results['boolean'])

此查询返回False正确的输出。

category name我尝试通过将查询转换为参数化查询(通过使用如下变量)来修改上述代码。

from SPARQLWrapper import SPARQLWrapper, JSON
sparql = SPARQLWrapper("http://live.dbpedia.org/sparql")
sparql.setReturnFormat(JSON)

my_variable = 'dbc:Meteorological_concepts'

sparql.setQuery(" ASK { ?my_variable skos:broader{1,7} dbc:Medicine } ")
results = sparql.query().convert()
print(results['boolean'])

做了这个修改后,现在代码返回True,这是不正确的。只是想知道我在哪里弄错了我的代码。

如果需要,我很乐意提供更多详细信息。

4

3 回答 3

2

如果你使用 Python 3.6+,你可以使用 f-strings:

f" ASK {{ {my_variable}  skos:broader{{1,7}} dbc:Medicine }} "

将会

' ASK { dbc:Meteorological_concepts  skos:broader{1,7} dbc:Medicine } '

对于旧版本,您可以使用format

" ASK {{ {}  skos:broader{{1,7}} dbc:Medicine }} ".format(my_variable)

产生相同的输出。

于 2019-02-22T12:30:19.830 回答
1

因为要引入变量的值,所以必须出字符串。并且您不要使用 a 来?执行此操作,而是使用字符串开头your_variable++ 字符串结尾的连接来执行此操作。

from SPARQLWrapper import SPARQLWrapper, JSON
sparql = SPARQLWrapper("http://live.dbpedia.org/sparql")
sparql.setReturnFormat(JSON)

my_variable = 'dbc:Meteorological_concepts'

sparql.setQuery(" ASK { "+my_variable+" skos:broader{1,7} dbc:Medicine } ")
results = sparql.query().convert()
print(results['boolean'])
于 2019-02-22T12:25:31.550 回答
1

此代码应该可以解决您的问题,请查看。

from SPARQLWrapper import SPARQLWrapper, JSON
sparql = SPARQLWrapper("http://dbpedia.org/sparql")
sparql.setQuery("\n"
                    "    PREFIX dbpedia: <http://dbpedia.org/resource/>"
                    " PREFIX dbo: <http://dbpedia.org/ontology/>"
                    "PREFIX dbp: <http://dbpedia.org/property/>\n"
                    "PREFIX foaf: <http://xmlns.com/foaf/0.1/>\n"
                    "PREFIX rdfs:   <http://www.w3.org/2000/01/rdf-schema#>\n"
                    "PREFIX dct:    <http://purl.org/dc/terms/>\n"
                    "SELECT DISTINCT ?name  ?birthDate   WHERE {\n"
                   "dbpedia:"+d+" foaf:name ?name\n"
                    "}\n"
                    "                   ")
于 2019-02-24T21:42:49.627 回答