python - gremlin python - 向顶点添加多个但未知数量的属性
问题描述
我想向一个顶点添加多个属性,但从一开始就没有明确知道这些属性可能是什么。例如,假设要将一个人作为顶点添加到图中,我们有以下属性字典:
人 1
{
"id": 1,
"first_name": "bob",
"age": 25,
"height": 177
}
也许要添加另一个顶点,一个人具有以下属性:
人 2
{
"id": 2,
"first_name": "joe",
"surname": "bloggs",
"occupation": "lawyer",
"birthday": "12 September"
}
有没有办法在不将属性键和值显式硬编码到 Gremlin属性函数中的情况下将两个人都添加到图中?
此链接提供了正确方向的答案。更多有用的信息可以在这里找到。以下行反映了建议的解决方案,按预期执行,并将新顶点添加到图中。伟大的。
g.addV("person").property("id", 1, "first_name", "bob", "age", 25, "height", 177).next()
但是,它仅在输入被硬编码时才寻求工作。我已将属性字典转换为 (k1, v1, k2, v2, ..., kn, vn) 形式的值元组,但我无法以编程方式传递值。例如
tup_vals = ("id", 1, "first_name", "bob", "age", 25, "height", 177)
但无论出于何种原因,我不能打电话:
g.addV("person").property(*tup_vals).next()
上面的行没有抛出异常,只是没有按预期执行(即没有传入属性)
有没有人知道如何以计算方式将这些属性字典传递给 Gremlin 属性函数?
更新:天真/低效的解决方案
下面提供了一个解决方案,但这是一个糟糕的解决方案,因为它每次迭代都会查询 gremlin 服务器。理想情况下,我想同时添加所有属性。并且只有在 id 是唯一的情况下才能真正按预期工作。
g.addV("person").property('id', id).next()
for k,v in property_dictionary[id].items():
g.V().has('id', id).property(k, v).iterate()
回答
感谢丹尼尔的回答。我已经修改了他的答案(如下)以符合 gremlin_python 包。
此答案的重要说明:在给定的上下文中keys
,values
应从此处的源代码中的 Column 枚举导入。
from gremlin_python.process.graph_traversal import __
from gremlin_python.process.traversal import Column
persons = [{"id":1,"first_name":"bob","age":25,"height": 177}, {"id":2,"first_name":"joe","surname":"bloggs","occupation":"lawyer","birthday":"12 September"}]
g.inject(persons).unfold().as_('entity').\
addV('entity').as_('v').\
sideEffect(__.select('entity').unfold().as_('kv').select('v').\
property(__.select('kv').by(Column.keys),
__.select('kv').by(Column.values)
)
).iterate()
解决方案
您可以将地图/字典注入遍历中,为每个字典创建一个顶点,然后遍历所有字典/地图条目并将它们设置为属性。在 Gremlin 中,看起来像这样:
g.inject(persons).unfold().as('person').
addV('person').as('v').
sideEffect(select('person').unfold().as('kv').
select('v').
property(select('kv').by(keys), select('kv').by(values))).
iterate()
例子:
gremlin> persons = [["id":1,"first_name":"bob","age":25,"height": 177]
......1> ,["id":2,"first_name":"joe","surname":"bloggs",
"occupation":"lawyer","birthday":"12 September"]]
==>[id:1,first_name:bob,age:25,height:177]
==>[id:2,first_name:joe,surname:bloggs,occupation:lawyer,birthday:12 September]
gremlin> g = TinkerGraph.open().traversal()
==>graphtraversalsource[tinkergraph[vertices:0 edges:0], standard]
gremlin> g.inject(persons).unfold().as('person').
......1> addV('person').as('v').
......2> sideEffect(select('person').unfold().as('kv').
......3> select('v').
......4> property(select('kv').by(keys), select('kv').by(values))).
......5> valueMap()
==>[id:[1],first_name:[bob],age:[25],height:[177]]
==>[birthday:[12 September],occupation:[lawyer],surname:[bloggs],id:[2],first_name:[joe]]
推荐阅读
- crystal-reports - Crystal 报表中的数字格式
- python-3.x - 由于 psyscreez FilenotFoundError 无法安装 pyautogui:'README.md'
- r - R中的非线性最小二乘误差
- javascript - 如何从数据集的末尾开始加载 Flatlist
- java - java在一行中声明多个对象
- r - 将具有不同长度的列表转换为R中的数据框或数据表
- git - 使用 git 从仓库推/拉时使用不安全的 ssh 代理转发
- python - 每次函数结束后显示无
- git - git diff 用于存储中的单个文件
- javascript - 导航栏只有两个按钮,一个在左边,一个在右边,中间是一个矩形标志?