是否可以将Networkx Graph对象存储在CBOR对象中(通过CBOR序列化数据)?我有相当大的NetworkX图,需要序列化和存储以供进一步分析。Pickle似乎太慢了,并且创建了太大的文件。我没有看到关于CBOR的足够文档,无法正确确定我的任务是否可行。
发布于 2016-02-05 06:57:07
我不知道CBOR的性能如何。据我所知,使用json似乎非常有效。所以我测试了序列化,它工作得很好:
from networkx.readwrite import json_graph
import cbor
G = nx.Graph()
G.add_weighted_edges_from([('a1', 'a2', 1.0), ('a2', 'a3', 0.5),
('a3', 'a5', 1.0), ('a4', 'a8', 1.0), ('a8', 'a9', 0.8)])
# Serialize graph
res = json_graph.node_link_data(G) # export Networkx to JSON
serialized = cbor.dumps(res) # serialize in binary format
deserialized = cbor.loads(serialized) # deserialize
H = json_graph.node_link_graph(deserialized) # Get back to original graphhttps://stackoverflow.com/questions/35209635
复制相似问题