我有一个如下所示的数据框:
> mydf
val1 val2
hsa-let-7a 2.139890 -0.03477569
hsa-let-7b 2.102590 0.04108795
hsa-let-7c 2.061705 0.02375882
hsa-let-7d 1.938950 -0.04364545
hsa-let-7e 1.889000 -0.10575235
hsa-let-7f 2.264296 0.08465690
Run Code Online (Sandbox Code Playgroud)
请注意,从3列只有第2和第3列是名称.我想要做的是命名第一列(加上重命名第二和第三列).
但为什么这个命令失败了?
colnames(mydf) <- c("COL1","VAL1","VAL2");
Run Code Online (Sandbox Code Playgroud)
什么是正确的方法呢?
它给了我:
Error in `colnames<-`(`*tmp*`, value = c("COL1", "VAL1", "VAL2" :
'names' attribute [3] must be the same length as the vector [2]
Run Code Online (Sandbox Code Playgroud)
小智 17
您可以将行名称连接到数据框,如下所示:
mydf <- cbind(rownames(mydf), mydf)
rownames(mydf) <- NULL
colnames(mydf) <- c("COL1","VAL1","VAL2")
Run Code Online (Sandbox Code Playgroud)
或者,一步到位:
setNames(cbind(rownames(mydf), mydf, row.names = NULL),
c("COL1", "VAL1", "VAL2"))
# COL1 VAL1 VAL2
# 1 hsa-let-7a 2.139890 -0.03477569
# 2 hsa-let-7b 2.102590 0.04108795
# 3 hsa-let-7c 2.061705 0.02375882
# 4 hsa-let-7d 1.938950 -0.04364545
# 5 hsa-let-7e 1.889000 -0.10575235
# 6 hsa-let-7f 2.264296 0.08465690
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
22526 次 |
最近记录: |