繁体   English   中英

R igraph重命名顶点

[英]R igraph rename vertices

是否有可能重命名igraph中的顶点。 我想在顶点上用不同的符号多次绘制某个图形。 鉴于以下igraph az:

> az
IGRAPH DN-- 24 23 -- 
+ attr: name (v/c), label (v/c), color (v/c), fill (v/c), width (e/n)

> V(az)
Vertex sequence:
 [1] "x1"  "x2"  "x3"  "x4"  "x5"  "x7"  "x8"  "x9"  "x10" "x11" "x12" "x13"
[13] "x14" "x15" "x16" "x19" "x20" "x21" "x22" "x23" "x24" "x25" "x26" "x27"

我想改变顶点,让我们说y1-y27然而,

V(az)$name <- paste("y",1:27,sep="")

不管用。 我怎样才能做到这一点? 提前致谢。

干杯

编辑:为了记录。

V(az)$name <- paste("y",1:27,sep="")

以这种方式工作,以便它返回:

 > V(az)
    Vertex sequence:
     [1] "y1"  "y2"  "y3"  "y4"  "y5"  "y7"  "y8"  "y9"  "y10" "y11" "y12" "y13"
    [13] "y14" "y15" "y16" "y19" "y20" "y21" "y22" "y23" "y24" "y25" "y26" "y27"

但是,plot(az)stills返回带有x个节点的图形

您可以使用

ay <- set.vertex.attribute(az, "name", value=paste("y",1:27,sep=""))

也适用于"label"而不是"name"

如果V(az)同时具有一组“名称”属性和一组“标签”属性,则会绘制“标签”属性。

> gt <- graph.tree(24, children = 4, mode=c("out", "in", "undirected"))
> V(gt)$name <- letters[1:24]
> plot(gt)   # So 'name's get displayed if no label is present
> V(gt)$label <- LETTERS[1:24]
> plot(gt)    # Labels get displayed
> V(gt)$name <- letters[1:24]  # see if then get overwritten 
> plot(gt)    # Still plots with 'label's

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM