如何使用R语言将一个数据框的行名利用另一个数据替换?

Python0212

如何使用R语言将一个数据框的行名利用另一个数据替换?,第1张

Data Frame每一列有列名,每一行也可以指定行名。如果不指定行名,那么就是从1开始自增的Sequence来标识每一行。初始化使用data.frame函数就可以初始化一个Data Frame。比如我们要初始化一个student的Data Frame其中包含ID和Name还有Gender以及Birthdate,那么代码为:student<-data.frame(ID=c(11,12,13),Name=c("Devin","Edward","Wenli"),Gender=c("M","M","F"),Birthdate=c("1984-12-29","1983-5-6","1986-8-8”))另外也可以使用read.table() read.csv()读取一个文本文件,

read.xlsx(filename,sheet=1,head=T)

如果你的第一行是数据,head=T会让第一列数据就会被强制为变量名,head=F则相反,这个需要xlsx包。

如果已经载入数据,数据名为a,那么使用colnames(a)=a[1,],就可以把a的行名变成a的第一行数据,然后a=a[-1,],删除第一行数据,就可以了。当然如果需要,也可以保留第一行数据。

扩展资料:

注意事项

header=T表示将文件中第一行设为列名字。row.names= 1表示第一列设为行名。

例如:

data = read.csv("test.csv",row.names= 1) #表示第一行作为列名,第一列作为行名

data = read.csv("test.csv",header=F)  #表示读入没有指定行列名的矩阵数据

因此header=T为默认条件,默认条件下没有行名,如果第一列为行名,则需在读入时指定row.names= 1。

R语言读入表格的函数有:

read.table()

read.csv(

read.csv2()

read.delim()

read.delim2()

其中,读入表格常常要考虑行名和列名的显示方式,例如你读入的表格第一行是否为各列的列名,第一列是否为各行的行名等等。

假如已经将上面的数据读入了R中的data.frame中,并保存为df变量

library(stringr)

df$ID <- row.names(df)

df$ID <- str_extract(df$ID, '\\d+')##提取数字