我在城市之间有美国贸易数据。我有关于城市(节点)和交易(边缘)的属性数据。
考虑以下图表:
library(igraph)
gg <- graph.atlas(711)
V(gg)$name <- 1:7
V(gg)$city <- c("BOISE","NEW YORK","NEW YORK","BOISE","BOISE","LA","LA")
V(gg)$color <- ifelse(V(gg)$city=="BOISE", "orange","yellow")
gg <- delete.edges(gg, E(gg,P=c(1,2,2,3,2,7,7,6,7,3,3,4,3,5,4,5,5,6,6,1)))
gg <- add.edges(gg,c(1,4,4,5,5,1),attr=list(trade=1))
gg <- add.edges(gg,c(7,5,5,4,4,7),attr=list(trade=2))
gg <- add.edges(gg,c(7,3,3,5,5,7),attr=list(trade=3))
gg <- add.edges(gg,c(2,7,7,6,6,2),attr=list(trade=4))
gg <- add.edges(gg,c(6,4),attr=list(trade=5))
plot(gg, edge.label=E(gg)$trade)
生成以下内容:
trade network http://i60.tinypic.com/34teolg.png
由此,我想将包含edge属性的edgelist导出到文本文件中。
例如:
[CITY 1], [CITY 2], [TRADE]
有关我如何做到这一点的任何帮助?这似乎很容易,但我真的被卡住了。
答案 0 :(得分:2)
您可以提取边列表,然后使用它来获取vertrex属性并将其与边属性组合。例如
el <- as_edgelist(gg)
data.frame(city1=V(gg)[el[,1]]$city,
city2=V(gg)[el[,2]]$city,
trade=E(gg)$trade)
# city1 city2 trade
# 1 BOISE BOISE 1
# 2 BOISE BOISE 1
# 3 BOISE BOISE 1
# 4 BOISE LA 2
# 5 BOISE BOISE 2
# 6 BOISE LA 2
# 7 NEW YORK LA 3
# 8 NEW YORK BOISE 3
# 9 BOISE LA 3
# 10 NEW YORK LA 4
# 11 LA LA 4
# 12 NEW YORK LA 4
# 13 BOISE LA 5
数据看起来有点奇怪,因为您有多个具有相同城市名称的顶点。不确定这是不是你的意图。