R语言同一组数据header=T报错,header=F不报错为什么

Python012

R语言同一组数据header=T报错,header=F不报错为什么,第1张

你的问题我不是特别清楚。不过,看你的warning里,header不是一个数而是一列数,再有,header看起来像是因子型不是布尔型(R里面称logical)。我觉得应该是你已经对T进行赋值了,T覆盖了原有的TRUE的含义,所以你可以单独拿出T看看。还有一个小提醒,布尔型数据在R里面最好写全,TRUE,FALSE,不然有时会报出意想不到的错。

读入数据的时候遇到行名有重复而报错的情况,如下图

mydata<-read.table("data_RNA_Seq_v2_mRNA_median_ Zscores.txt", header = T, row.names=1, check.names = F)

报错:Error in read.table("data_RNA_Seq_v2_mRNA_median _Zscores.txt", header = T,  :   'row.names'里不能有重复的名字

此时可以使用base包中的make.names()函数

使用方法:

1.先不设置行名将数据读进去

mydata<-read.table("data_RNA_Seq_v2_mRNA_median_ Zscores.txt", header = T, check.names = F)

2.使用make.names函数将第一列作为行名

row.names(mydata<-make.names(mydata[,1],TRUE)

关于make.names函数的使用方法可以通过?make.names获得

3. 删除第一列

mydata<-mydata[,-1]

4.查看数据前五行前五列看是否行名修改完成

mydata[1:5,1:5]