python - 如何将tinkergraph上传到python/gremlin?

标签 python graph gremlin tinkerpop gremlinpython

我正在尝试在 python 中使用 gremlin。我导入了以下内容:

from gremlin_python.driver.driver_remote_connection import DriverRemoteConnection
from gremlin_python.structure.graph import Graph
from gremlin_python import statics
from gremlin_python.process.graph_traversal import __
from gremlin_python.process.strategies import *
from gremlin_python.process.traversal import *
import asyncio
statics.load_statics(globals()) 

当我运行这个时:

graph = TinkerGraph.open() 
graph.io(graphml()).readGraph('air-routes.graphml') 

我收到以下错误:

NameError: name 'TinkerGraph' is not defined

如何解决这个问题?

最佳答案

Python 中没有 TinkerGraph。在 gremlin-python 中,您只能获得对服务器上远程图的引用,这可能是 TinkerGraph 或其他东西。如果您想以这种方式加载数据,则必须通过 Client 实例以脚本形式发出该命令:

client = Client('ws://localhost:45940/gremlin', 'g')
client.submit("graph.io(graphml()).readGraph('air-routes.graphml');[]").all().result()

其中该脚本中的“graph”是服务器上已存在的Graph实例(并且可能为空)。如果您使用 Gremlin Server,您可能会考虑将其作为 Gremlin Server startup 的一部分单独加载,然后仅使用 gremlin-python 来查询该数据。在本例中这可能是最好的,因为数据只会在服务器启动时出现。

请注意,在 3.4.0 中,我们引入了 io() 步骤,该步骤将直接成为 gremlin-python 的一部分,此时您可以直接执行以下操作:

g.io('air-routes.xml').read()

在 native python 中,它会正常工作(同样,Graph 实例必须远程定义),尽管该文件必须可由服务器读取。

这是我在 Python shell 中提交脚本的工作示例,首先出现 Tornado 错误,然后没有:

$ env/bin/python
Python 3.4.3 (default, Nov 28 2017, 16:41:13) 
[GCC 4.8.4] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> from gremlin_python.driver.client import Client
>>> client = Client('ws://localhost:8182/gremlin', 'g')
>>> client.submit("g.V()").all().result()
Traceback (most recent call last):
  File "/home/smallette/git/apache/incubator-tinkerpop/gremlin-python/target/python3/gremlin_python/driver/client.py", line 51, in __init__
    from gremlin_python.driver.tornado.transport import (
  File "/home/smallette/git/apache/incubator-tinkerpop/gremlin-python/target/python3/gremlin_python/driver/tornado/transport.py", line 19, in <module>
    from tornado import ioloop, websocket
ImportError: No module named 'tornado'

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/home/smallette/git/apache/incubator-tinkerpop/gremlin-python/target/python3/gremlin_python/driver/driver_remote_connection.py", line 45, in __init__
    password=password)
  File "/home/smallette/git/apache/incubator-tinkerpop/gremlin-python/target/python3/gremlin_python/driver/client.py", line 54, in __init__
    raise Exception("Please install Tornado or pass"
Exception: Please install Tornado or passcustom transport factory
>>> exit
Use exit() or Ctrl-D (i.e. EOF) to exit
>>> exit()
$ env/bin/pip install tornado
Collecting tornado
Collecting backports-abc>=0.4 (from tornado)
  Using cached https://files.pythonhosted.org/packages/7d/56/6f3ac1b816d0cd8994e83d0c4e55bc64567532f7dc543378bd87f81cebc7/backports_abc-0.5-py2.py3-none-any.whl
Installing collected packages: backports-abc, tornado
Successfully installed backports-abc-0.5 tornado-5.1.1
smallette@ubuntu:~/git/apache/incubator-tinkerpop/gremlin-python/target/python3$ env/bin/python
Python 3.4.3 (default, Nov 28 2017, 16:41:13) 
[GCC 4.8.4] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> from gremlin_python import statics
>>> client = Client('ws://localhost:8182/gremlin', 'g')
>>> client.submit("g.V()").all().result()
[v[0]]

关于python - 如何将tinkergraph上传到python/gremlin?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53708193/

相关文章:

gremlin 路口操作

c# - Azure Cosmos DB 快速入门示例不起作用

python - IPython 笔记本和 SQL : 'ImportError: No module named sql' when running '%load_ext sql'

python - 在 Python 字典中存储和更新列表 : why does this happen?

algorithm - graph - 如何使用 Tree Isomorphic 解决语言模式匹配问题?

c++ - 检查顶点之间的平行边 : edge_range does not work with directed graph

gremlin - 索引键上的 Titan 查找速度非常慢?

python - Pylint 错误消息 : "E1101: Module ' lxml. etree'没有 'strip_tags' 成员'”

python - 字符串变量的索引方法,在条件循环内,未返回所需的结果

graph - arangosh 无法加载图形模块