加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

Gremlin Python返回空图

发布时间:2020-12-20 12:34:39 所属栏目:Python 来源:网络整理
导读:我开始玩gremlin- python包装器来与我的gremlin服务器进行交互. 我做了以下步骤: ./bin/gremlin.sh 一旦Gremlin控制台打开,我使用以下命令加载配置: graph = JanusGraphFactory.open('conf/gremlin-server/janusgraph-cassandra-es.properties')g = graph.
我开始玩gremlin- python包装器来与我的gremlin服务器进行交互.

我做了以下步骤:

./bin/gremlin.sh

一旦Gremlin控制台打开,我使用以下命令加载配置:

graph = JanusGraphFactory.open('conf/gremlin-server/janusgraph-cassandra-es.properties')
g = graph.traversal()
saturn = g.V().has('name','saturn')

gremlin shell中的上面一组代码工作得很好,我可以看到列出的脊椎,但是当我尝试在python中做同样的事情时,我得到一个空图.以下是我的python代码:

graph = Graph()
g = graph.traversal().withRemote(DriverRemoteConnection('ws://localhost:8182/gremlin','g'))
print(g)

它返回:
graphtraversalsource [图表[空]]

为什么我得到空图?据我所知,它无法连接到相同的Graph源.有什么我想念的吗?

请注意:

JanusGraphFactory.open('conf/gremlin-server/janusgraph-cassandra-es.properties')

提供的配置文件名是用于启动gremlin服务器的文件名.

任何帮助都非常感谢.

谢谢

解决方法

你看到graph [empty]的原因是因为那是Python图形对象的实际字符串表示 – 请参阅 code here.图表实际上可能包含数据,所以如果它像graph [remote]或者更好的话会更好图[]代替.我打开了一个 issue来解决这个问题.

开箱即用,JanusGraph未配置Python.您可以在Apache TinkerPop docs中找到有关如何执行此操作的文档.首先安装gremlin-python.假设您正在使用使用TinkerPop 3.2.3的JanusGraph 0.1.1,这是命令:

bin/gremlin-server.sh -i org.apache.tinkerpop gremlin-python 3.2.3

接下来修改conf / gremlin-server / gremlin-server.yaml以添加gremlin-python脚本引擎:

scriptEngines: {
  gremlin-groovy: {
    imports: [java.lang.Math],staticImports: [java.lang.Math.PI],scripts: [scripts/empty-sample.groovy]},gremlin-jython: {},gremlin-python: {}
}

要使用Gremlin Python,您需要浏览Gremlin Server,因此启动JanusGraph pre-packaged distribution:

bin/janusgraph.sh start

从Gremlin控制台:

gremlin> graph = JanusGraphFactory.open('conf/janusgraph-cassandra-es.properties')
==>standardjanusgraph[cassandrathrift:[127.0.0.1]]
gremlin> GraphOfTheGodsFactory.load(graph)
==>null
gremlin> g = graph.traversal()
==>graphtraversalsource[standardjanusgraph[cassandrathrift:[127.0.0.1]],standard]
gremlin> g.V().count()
14:51:58 WARN  org.janusgraph.graphdb.transaction.StandardJanusGraphTx  - Query requires iterating over all vertices [()]. For better performance,use indexes
==>12

安装Gremlin-Python驱动程序,再次匹配TinkerPop版本:

pip install gremlinpython==3.2.3

从Python 3 shell:

>>> from gremlin_python import statics
>>> from gremlin_python.structure.graph import Graph
>>> from gremlin_python.process.graph_traversal import __
>>> from gremlin_python.process.strategies import *
>>> from gremlin_python.driver.driver_remote_connection import DriverRemoteConnection
>>> graph = Graph()
>>> g = graph.traversal().withRemote(DriverRemoteConnection('ws://localhost:8182/gremlin','g'))
>>> print(graph)
graph[empty]
>>> print(g)
graphtraversalsource[graph[empty]]
>>> g.V().count().next()
12
>>> g.addV('god').property('name','mars').property('age',3500).next()
v[4280]
>>> g.V().count().next()
13

请记住,当您在Python shell中工作时,图形遍历不会自动迭代,因此您需要确保使用iterate()或next()或toList()迭代遍历.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读