r - 通过调用列名将列名提取到向量

标签 r dataframe

我们有一个 data.frame这里:

df <- data.frame(x1=rnorm(20),x2=rnorm(20),x3=rnorm(20),x4=rnorm(20),x5=rnorm(20),x6=rnorm(20),x7=rnorm(20),x8=rnorm(20),x9=rnorm(20),x10=rnorm(20),x11=rnorm(20),x12=rnorm(20),x13=c(2,1,1,2,2,1,2,1,2,2,1,1,2,1,2,2,1,2,1,1))

我知道我可以轻松地查看列名
colnames(df)
[1] "x1"  "x2"  "x3"  "x4"  "x5"  "x6"  "x7"  "x8"  "x9"  "x10" "x11" "x12" "x13"

打印上面的行。

我还可以使用 colnames(df[...]) 获取单个列的名称,例如
colnames(df[2])
[1] "x2"

我似乎无法弄清楚如何通过调用 colnames() 来提取单个列名带有列的名称,例如
colnames(df$x2)
NULL

我敢打赌,解决方案非常简单,但我只是没有找到有关此问题的任何有用信息。

最佳答案

单括号生成数据框的子集,只有一列。因此,新数据框的唯一一列有一个名称。

> class(df[2])
[1] "data.frame"
> colnames(df[2])
[1] "x2"

双括号[[或美元 $提取单列的内容,在您的情况下是数字。因此它没有任何列名,因为它不是数据框。
> class(df$x2)
[1] "numeric"

如果您只想要第二列的名称,您应该这样做
> colnames(df)[2]
[1] "x2"

关于r - 通过调用列名将列名提取到向量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30664012/

相关文章:

dataframe - 根据共享值将一列从一个数据帧添加到另一个数据帧

python - Pandas :嵌套数据框

python - 在 Pandas Dataframes 中查找单个文件的第一行和最后一行

r - 如何将 R 文本+图像输出捕获到一个文件(html、doc、pdf 等)中?

R:dplyr。改变对行中值为 0 的列进行计数的列

r - 根据多行值计算新列

r - 一个可以将DNA序列翻译成二进制代码的函数

r - ggplot用geom_bar中的百分比替换计数

python - 如何将两个数据帧中的两列合并到新数据帧(pandas)的一列中?

python - 在 2 列上合并 pandas 数据帧,但顺序不限