我编写了一个快速脚本,通过Neo4j的遍历框架REST API运行遍历查询:
from py2neo import neo4j
import requests
import json
dbURI = 'http://localhost:7474/db/data/'
def graphTraversal (nodeId):
returnType = 'path'
payload = {
'order': 'breadth_first',
'uniqueness': 'node_global',
'relationships': [{
'direction': 'all',
'type': 'associatedMusicalArtist'
}],
'max_depth': 2
}
payload = json.dumps(payload)
headers = {
'Accept': 'application/json; charset=UTF-8',
'Content-Type': 'application/json'
}
uri = dbURI + '/node/' + nodeId + '/traverse/' + returnType
print '\n> Traversal of ' + uri + ' ...'
res = requests.post(uri, data=payload, headers=headers)
print res.text
return res.json();
def getNodeByUri (db, key, value):
return db.get_indexed_node('nodeIdx', key, value)
def getNodeId (node):
return str(node._id)
def main ():
db = neo4j.GraphDatabaseService(dbURI)
node = getNodeByUri(db, '__URI__', 'http://dbpedia.org/resource/Jimi_Hendrix')
nodeId = getNodeId(node)
rels = graphTraversal(nodeId)
if __name__ == '__main__':
main()
代码运行正常,但我有一个问题:
我知道Java驱动程序允许这样做但是对于Python来说,文档并不清楚如何做到这一点。
提前致谢!
编辑:这是指向我Neo4j's traversal framework REST API的文档的链接。
答案 0 :(得分:2)
没有直接的方法可以做到这一点,遍历端点都是单节点。
您可以使用Batch API在单个HTTP请求中发送大量遍历请求。看看这里:
http://docs.neo4j.org/chunked/stable/rest-api-batch-ops.html
<强>然而强>
对于您正在运行的Traversal,您可以轻松地在Cypher中表达它,然后您就可以给它多个起点,如下所示:
START n=node(1,2,3,4,5) MATCH (n)-[:associatedMusicalArtist*0..2]-(other) RETURN other
然后您可以将其发送到事务端点:
http://docs.neo4j.org/chunked/stable/rest-api-transactional.html