node_link_data#
- node_link_data(G, attrs=None, *, source='source', target='target', name='id', key='key', link='links')[source]#
Returns data in node-link format that is suitable for JSON serialization and use in Javascript documents.
- Parameters:
- GNetworkX graph
- attrsdict
A dictionary that contains five keys ‘source’, ‘target’, ‘name’, ‘key’ and ‘link’. The corresponding values provide the attribute names for storing NetworkX-internal graph data. The values should be unique. Default value:
dict(source='source', target='target', name='id', key='key', link='links')
If some user-defined graph data use these attribute names as data keys, they may be silently dropped.
Deprecated since version 2.8.6: The
attrskeyword argument will be replaced withsource,target,name,keyandlink. in networkx 3.2If the
attrskeyword and the new keywords are both used in a single function call (not recommended) theattrskeyword argument will take precedence.The values of the keywords must be unique.
- sourcestring
A string that provides the ‘source’ attribute name for storing NetworkX-internal graph data.
- targetstring
A string that provides the ‘target’ attribute name for storing NetworkX-internal graph data.
- namestring
A string that provides the ‘name’ attribute name for storing NetworkX-internal graph data.
- keystring
A string that provides the ‘key’ attribute name for storing NetworkX-internal graph data.
- linkstring
A string that provides the ‘link’ attribute name for storing NetworkX-internal graph data.
- Returns:
- datadict
A dictionary with node-link formatted data.
- Raises:
- NetworkXError
If the values of ‘source’, ‘target’ and ‘key’ are not unique.
See also
Notes
Graph, node, and link attributes are stored in this format. Note that attribute keys will be converted to strings in order to comply with JSON.
Attribute ‘key’ is only used for multigraphs.
To use
node_link_datain conjunction withnode_link_graph, the keyword names for the attributes must match.Examples
>>> G = nx.Graph([("A", "B")]) >>> data1 = nx.node_link_data(G) >>> data1 {'directed': False, 'multigraph': False, 'graph': {}, 'nodes': [{'id': 'A'}, {'id': 'B'}], 'links': [{'source': 'A', 'target': 'B'}]}
To serialize with JSON
>>> import json >>> s1 = json.dumps(data1) >>> s1 '{"directed": false, "multigraph": false, "graph": {}, "nodes": [{"id": "A"}, {"id": "B"}], "links": [{"source": "A", "target": "B"}]}'
A graph can also be serialized by passing
node_link_dataas an encoder function. The two methods are equivalent.>>> s1 = json.dumps(G, default=nx.node_link_data) >>> s1 '{"directed": false, "multigraph": false, "graph": {}, "nodes": [{"id": "A"}, {"id": "B"}], "links": [{"source": "A", "target": "B"}]}'
The attribute names for storing NetworkX-internal graph data can be specified as keyword options.
>>> H = nx.gn_graph(2) >>> data2 = nx.node_link_data(H, link="edges", source="from", target="to") >>> data2 {'directed': True, 'multigraph': False, 'graph': {}, 'nodes': [{'id': 0}, {'id': 1}], 'edges': [{'from': 1, 'to': 0}]}