4

我一直试图让 SPARQLWrapper 将一个简单的三元组插入到 GraphDB 中,但没有成功。我对选择查询没有任何问题。这是失败的 Python 测试代码:

db = sparqlw.SPARQLWrapper(endpoint)
query = '''
INSERT {<http://example.com/123456789876> a owl:Thing .}
WHERE {}
'''
db.setQuery(query)
db.method = sparqlw.POST
db.setReturnFormat(sparqlw.JSON)
db.queryType= sparqlw.INSERT
result = db.query()

它返回以下错误:

"urllib.error.HTTPError: HTTP Error 400: Bad Request"

"SPARQLWrapper.SPARQLExceptions.QueryBadFormed: QueryBadFormed: a bad 
request has been sent to the endpoint, probably the sparql query is bad 
formed."

响应:b'缺少参数:查询'

我到处寻找并尝试了所有建议的方法,但无法使其正常工作。感谢任何好的线索。

请参阅我添加的关于验证查询的评论。问题是重复的并且已经回答的建议不适用。

4

1 回答 1

2

GraphDB 公开了芝麻风格的端点 URL。
下面是 GraphDB 8.3 Workbench 帮助页面的截图(我使用的是免费版)。


帮助


以下 Python 代码适用于我(repositoryIDis wikidata):

from SPARQLWrapper import SPARQLWrapper, BASIC

db = SPARQLWrapper("http://localhost:7200/repositories/wikidata/statements")
query = '''
INSERT {<http://example.com/123456789879> a owl:Thing .}
WHERE {}
'''
db.setHTTPAuth(BASIC)
db.setCredentials('login', 'password')
db.setQuery(query)
db.method = "POST"
db.setReturnFormat('json')
db.queryType = "INSERT"
result = db.query()
于 2017-09-18T16:07:22.407 回答