Gremlin / Bulbflow:如何从execute()中获取整数结果

时间:2013-09-08 22:11:14

标签: python django neo4j gremlin bulbs

很抱歉,如果这个问题太愚蠢,不能问......我是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'

有谁能告诉我我做错了什么? 非常感谢!

1 个答案:

答案 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)

请参阅...