R读取文件报错及read.x()函数用法小结

有时候用R读取一个乱七八糟的表格的时候会出错,特别是一个格子中存在大量标点符号的时候。这里有一个9951*9的表格,利用下面的代码读取:

gogmt = read.table("04. GeneSet_GO(Shared).gmt",header = T, sep = "\t",stringsAsFactors = FALSE)

会报错:

报错
读取的结果只有一部分, 没有读取完:
数据缺失
我们只要再加上一个参数:quote = "" 即可

gogmt = read.table("04. GeneSet_GO(Shared).gmt",header = T, sep = "\t",stringsAsFactors = FALSE, quote = "")

则不会在报错了。
数据完整了

下面在简单介绍一些read.x的常用参数:
(1)file:需要读取的文件名
(2)header:指出一个文件是否包含表头,默认为F
(3)sep:分隔符是什么,默认为sep=""
(4)quote:对于有特殊字符的字符串划定界限的字符串,默认为双引号或单引号
(5)dec:指明数据文件中的小数的小数点
(6)numerals:字符串类型。用于指定文件中的数字转换为双精度数据时丢失精度的情况下如何进行转换。
(7)row.names:保存行名的向量。可以使用此参数以向量的形式给出每行的实际行名。或者要读取的表中包含行名称的列序号或列名字符串。在数据文件中有行头且首行的字段名比数据列少一个的情况下,数据文件中第1列将被视为行名称。除此情况外,在没有给定row.names参数时,读取的行名将会自动编号。可以使用row.names = NULL强制行进行编号。
(8)col.names:指定列名的向量。
注意区分:
rownames、colnames是base包中的行名、列名函数;
而row.names、col.names是read.table函数中的行名、参数
(9)as.is
该参数用于确定read.table()函数读取字符型数据时是否转换为因子型变量。当其取值为FALSE时,该函数将把字符型数据转换为因子型数据,取值为TRUE时,仍将其保留为字符型数据。其取值可以是逻辑值向量(必要时可以循环赋值),数值型向量或字符型向量,以控制哪些列不被转换为因子。
注意:可以通过设置参数 colClasses = "character"来阻止所有列转换为因子,包括数值型的列。
(10)na.strings
可选的用于表示缺失值的字符向量。
na.strings=c("-9","?")把-9和?值在读取数据时候转换成NA
(11)colClasses
用于指定列所属类的字符串向量。
(12)nrows
整型数。用于指定从文件中读取的最大行数。负数或其它无效值将会被忽略。
(13)skip
整型数。读取数据时忽略的行数。
(14)check.names
逻辑值。该参数值设置为TRUE时,数据框中的变量名将会被检查,以确保符在语法上是有效的变量名称。
(15)fill
逻辑值。在没有忽略空白行的情况下(即blank.lines.skip=FLASE),且fill设置为TRUE时,如果数据文件中某行的数据少于其他行,则自动添加空白域。
(16)strip.white
逻辑值,默认为FALSE。此参数只在指定了sep参数时有效。当此参数设置为TRUE时,数据文件中没有包围的字符串域的前边和后边的空格将会被去掉。
(17)blank.lines.skip
逻辑值,此参数值设置为TRUE时,数据文件中的空白行将被忽略。默认值为TRUE。
(18)comment.char
字符型。包含单个字符或空字符的向量。代表注释字符的开始字符。可以使用""关闭注释。
(19)allowEscapes
逻辑值。类似“\n”这种C风格的转义符。如果这种转义符并不是包含在字符串中,该函数可能解释为字段分隔符。
(20)flush
逻辑值。默认值为FALSE。当该参数值设置为TRUE时,则该函数读取完指定列数后将转到下一行。这允许用户在最后一个字段后面添加注释。
(21)stringsAsFactors
逻辑值,标记处字符向量是否需要转化为因子,默认是TRUE。

首先,明确String与Factor的区别。String是字符串,可用于记录琐细信息(比如发现UFO者的口头描述内容)。Factor是因此,用于给一行记录做“分类标记”,比如人的性别factors可以设置为“男”、“女”,工作效率最高日期的factors可以是“Mon”、"Tue",对于工作效率也可以有“high”、“low”等。对于Factor类型属性,R语言可以自动统计数据的factor水平(level),比如,男,有多少,Mon有多少等。
stringsAsFactors = F意味着,“在读入数据时,遇到字符串之后,不将其转换为factors,仍然保留为字符串格式”。

(22)fileEncoding
字符串类型,指定文件的编码方式。如果指定了该参数,则文本数据按照指定的格式重新编码。
(23)encoding
假定输入字符串的编码方式。
(24)text
字符串类型。当未提供file参数时,则函数可以通过一个文本链接从text中读取数据。
(25)skipNul
逻辑值。是否忽略空值。默认为FALSE。

后面read.x部分的参考资料:R语言_read.table()函数用法

你可能感兴趣的:(R读取文件报错及read.x()函数用法小结)