You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I cannot work out how to get edges from a pandas table using add_graph_from_df.
The add_graph_from_df code takes an edges tuple. edges=tuple() with comment that the first item is the source edge and the second is the target edge.
However the pandas notebook example does not set any edges and it is unclear what the tuple is supposed to represent.
As it is not a list of edges I guess that it might be the column names or indexes in the data frame that represent edges.
setting edges to (3,4) also returns an empty edges array.
even trying something like edges=('node-1', 'node-2') creates no edges.
Reviewing the source code for add_graph_from_df we see an edge is created with source set to the first tuple item and target set to the second.
if not all(edges):
...
graph_edges.append(
Edge(
data={
"id": index,
"source": edges[0],
"target": edges[1],
"classes": classes,
}
)
)
This means the edge is only added if one of the items in the tuple is false.
if we set edges to (0,1,False) we get an edge added [Edge(data={'id': 0, 'source': 0, 'target': 1, 'classes': ''})]
we also get the 0 and 1 nodes reset with no name data although I'm not clear why.
and no matter how many times we run through the iterator we will only get the one link. Although n identical edges are added they appear to be de-duplicated.
No visible line is drawn between the nodes. - this appears if id is removed from the edge.
Is the edges tuple supposed to be some kind of function that returns successive values?
The text was updated successfully, but these errors were encountered:
Problem
I cannot work out how to get edges from a pandas table using add_graph_from_df.
The add_graph_from_df code takes an edges tuple. edges=tuple() with comment that the first item is the source edge and the second is the target edge.
However the pandas notebook example does not set any edges and it is unclear what the tuple is supposed to represent.
As it is not a list of edges I guess that it might be the column names or indexes in the data frame that represent edges.
Testing with this code
creates the following cyw.graph.nodes
but cyw.graph.edges is and empty array []
setting edges to (3,4) also returns an empty edges array.
even trying something like edges=('node-1', 'node-2') creates no edges.
Reviewing the source code for add_graph_from_df we see an edge is created with source set to the first tuple item and target set to the second.
This means the edge is only added if one of the items in the tuple is false.
if we set edges to (0,1,False) we get an edge added
[Edge(data={'id': 0, 'source': 0, 'target': 1, 'classes': ''})]
we also get the 0 and 1 nodes reset with no name data although I'm not clear why.
and no matter how many times we run through the iterator we will only get the one link. Although n identical edges are added they appear to be de-duplicated.
No visible line is drawn between the nodes. - this appears if id is removed from the edge.
Is the edges tuple supposed to be some kind of function that returns successive values?
The text was updated successfully, but these errors were encountered: