【发布时间】:2020-11-23 14:44:12
【问题描述】:
所以我创建了一个 data.frame,其中有 n 列,如下所示:
df <- as.data.frame(matrix(nrow = 3, ncol = 15))
看起来像这样:
V1 V2 V3 V4 V5 V6 V7 V8 V9 V10 V11 V12 V13 V14 V15
1 NA NA NA NA NA NA NA NA NA NA NA NA NA NA NA
2 NA NA NA NA NA NA NA NA NA NA NA NA NA NA NA
3 NA NA NA NA NA NA NA NA NA NA NA NA NA NA NA
我希望每第 N 个列名更改一次,所以它看起来像这样:
A V2 V3 B V5 V6 C V8 V9 D V11 V12 E V14 V15
1 NA NA NA NA NA NA NA NA NA NA NA NA NA NA NA
2 NA NA NA NA NA NA NA NA NA NA NA NA NA NA NA
3 NA NA NA NA NA NA NA NA NA NA NA NA NA NA NA
我已经制作了这个序列,它给了我想要的列名:
colnames(df[,seq(1,ncol(df),3)])
输出:
[1] "V1" "V4" "V7" "V10" "V13"
但是当我尝试更改名称时没有任何反应:
colnames(df[,seq(1,ncol(df),3)]) <- c("A","B","C","D","E")
我也试过了,但它只改变了第一列并且它给出了警告信息:
names <- colnames(df[,seq(1,ncol(df),3)])
colnames(df)[colnames(df) == names] <- c("A","B","C","D","E")
警告信息:
Warning message:
In colnames(df)[colnames(df) == names] <- c("A", "B", "C", "D", :
number of items to replace is not a multiple of replacement length
提前感谢您的帮助,感谢您的每一个回答:)
【问题讨论】:
-
试试
colnames(df)[seq(1,ncol(df),3)] <- c("A","B","C","D","E")。 -
现在我重置了 RStudio。可能是一些错误:/
标签: r dataframe columnname