所以我创建了一个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:
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
谢谢你的帮助,我很感激你的每一个回答:)
2条答案
按热度按时间lxkprmvk1#
您可以根据位置修改某些列名,但需要将
[]
方括号放在colnames
函数外部:enxuqcxy2#
你也可以试试下面的代码。
k
值允许修改名字中的空格:输出: