很抱歉,如果这个问题太愚蠢,不能问......我是Python + Django + Bulbs + Neo4j的新手。
我正在尝试 - 没有成功 - 在使用Python + Django shell时获取由g.gremlin.execute()生成的整数,如下所述。
首先,Neo4j的Gremlin控制台中的查询:
gremlin> g.v(2).out
==> v[6]
==> v[4]
==> v[8]
==> v[7]
gremlin> g.v(2).out.count()
==> 4
我打算如何在Python + Django shell中获取此结果,并将其传递给变量,如下所示:
>>> from bulbs.neo4jserver import Graph
>>> from bulbs.model import Node,Relationship
>>> g = Graph()
>>> sc = " g.v(vertex_id).out.count()"
>>> params = dict(vertex_id = 2)
>>> val = g.gremlin.execute(sc,params)
>>> val
<bulbs.neo4jserver.client.Neo4jResponse object at 0x243cfd0>
从现在开始我无法再进一步了。
>>> val.one()
<bulbs.neo4jserver.client.Neo4jResult object at 0x2446b90>
>>> val.one().data
>>> val.one().results
Traceback (most recent call last):
File "<console>", line 1, in <module>
AttributeError: 'Neo4jResult' object has no attribute 'results'
有谁能告诉我我做错了什么? 非常感谢!
答案 0 :(得分:1)
原始结果数据将位于Result对象的raw
属性中:
>>> from bulbs.neo4jserver import Graph
>>> from bulbs.model import Node,Relationship
>>> g = Graph()
>>> script = " g.v(vertex_id).out.count()"
>>> params = dict(vertex_id = 2)
>>> resp = g.gremlin.execute(script,params)
>>> result = resp.one()
>>> result.raw
注意:result.data
返回一个元素的属性数据,因此它将为空,除非您返回顶点或边缘,即Neo4j用语中的节点或关系。
请参阅...
要查看Neo4j服务器在服务器响应中返回的内容,您可以输出Response
标题和内容:
>>> from bulbs.neo4jserver import Graph
>>> from bulbs.model import Node,Relationship
>>> g = Graph()
>>> script = "g.v(vertex_id).out.count()"
>>> params = dict(vertex_id = 2)
>>> resp = g.gremlin.execute(script,params)
>>> resp.headers
>>> resp.content
如果您在DEBUG
中将日志级别设置为Config
,您将能够看到每个请求上发送到服务器的内容。启用DEBUG
后,灯泡还会在raw
对象上设置Response
属性(不要与raw
上始终设置的Result
属性混淆对象)。 Response.raw
将包含原始服务器响应:
>>> from bulbs.neo4jserver import Graph, DEBUG
>>> from bulbs.model import Node,Relationship
>>> g = Graph()
>>> g.config.set_logger(DEBUG)
>>> script = " g.v(vertex_id).out.count()"
>>> params = dict(vertex_id = 2)
>>> resp = g.gremlin.execute(script,params)
>>> resp.raw
请参阅...
要关闭DEBUG
,请将日志级别设置回ERROR
:
>>> from bulbs.neo4jserver import ERROR
>>> g.config.set_logger(ERROR)
请参阅...