本文原创,转载请注明出处,本人Q1273314690(交流学习)
说明:本文曾经在15年11月在CSDN发过,但是由于CSDN不支持为知笔记的发布为博客的API功能,所以,自今天起,转移到博客园(幸好原来的CSDN也就五六篇哈~)。
 
###############################################
总结:
mode:表示对象在内存中的存储类型
基本数据类型'atomic' mode:
numeric(Integer/double), complex, character和logical
递归的对象(recursive object):
'list' 或 'function'
 
class:是一种抽象类型,或者理解为一种数据结构(数据框,因子,列表)
他主要是用来给泛型函数(参考java中泛型的概念)识别参数用。
所以当给函数传参数的时候如果发生错误,就查看class属性
class返回的是matrix,array,factor(还在Date)之类的数据结构类型
class(x)
  (一)基本类型情况(参考java中的基本数据类型理解)
(1)当x是单个值,或者向量的时候,
返回的结果和mode一致,如numeric,character
  (二)Object类型情况(参考java中引用数据类型情况理解)
(2)其他情况(矩阵,数组,日期,因子),
         class返回(matrix,array,Date,factor)
         mode返回(x中元素的类型——在内存中的存储类型)
(3)当x是数据框的时候,class返回dataframe,mode返回list
         当x是列表的时候,class和mode都返回list
 (4)当x是列表的时候,class和mode都返回list
为何数据框和列表不再适用于第二条mode返回x中元素的类型了呢?
1因为数据框其实是列表的一种特殊情况
2list和dataframe中的数据类型可以不一致,所以没法返回一个类型代表多种元素类型
 
 
 
########################################
在R中,他并不提供直接访问存储在内存中的数据的方法,而是提供特定的数据结构(我们将之称为对象)
 
mode:表示对象在内存中的存储类型
基本数据类型'atomic' mode: 
numeric(Integer/double), complex, character和logical
递归的对象(recursive object):
'list' 或 'function' 
 
class:是一种抽象类型,或者理解为一种数据结构
他主要是用来给泛型函数(参考java中泛型的概念)识别参数用。
如下例,你可以看到数据在内存中是列表的形式存储,却被包装成数据框来操作。(数据框其实是一种特殊的列表)
例子1
  1. d <- data.frame(V1=c(1,2))  
  2. class(d)    #"data.frame"
  3. mode(d)     #"list"
再看一个例子2
  1. 例子2.1
  2.  
  3. x1<-c(1,2,3)
  4. x2<-c(2,3,4)
  5. x3<-c(3,4,5)
  6. xmerge<-data.frame(x1,x2,x3)
  7. class(xmerge)   #dataframe
  8. mode(xmerge)   #list
  1.  
  2. 例子2.2
  3. >class(xmerge[1,])
  4. [1]"data.frame"
  5. > mode(xmerge[1,])
  6. [1]"list"
  7. > xmerge[1,]
  8. x1 x2 x3
  9. 1123
  1.  
  2. 例子2.3
  3.  
  4. > x1<-c(2,6,3)
  5. > x2<-c(3,7,4)
  6. > x3<-c(9,4,5)
  7. > xmerge<-data.frame(x1,x2,x3)
  8. >class(xmerge[,1])
  9. [1]"numeric"
  10. > mode(xmerge[,1])
  11. [1]"numeric"
  12. > xmerge[,1]
  13. [1]263
  14. > xmerge
  15. x1 x2 x3
  16. 1239
  17. 2674
  18. 3345
从例子1得知,数据框的class是dataframe,而其mode是list,例子2.1加强了这个结论。
例子2.2 说明数据框的每一行class仍然是data.frame,而其mode是list,即每一行仍然是一个数据框。(因为每一行会含有不同的数据类型)
例子2.3说明数据框的每一列的class和mode都是numeric(因为列的数据类型相同,而且我们没有vector类型的说法)
 
例子3.1
  1. x1 = array(rep(1,6),dim=c(2,3))
  2. class(x1)    #matrix
  3. mode(x1)     #numeric
例子3.2
  1. x = array(rep("a",6),dim=c(2,3))#矩阵是数组的二维特殊情形
  2. class(x) #matrix
  3. mode(x)  #character
例子3.3
  1. x5 = array(rep("a",9),dim=c(3,3,3))
  2. x5      
  3. ,,1
  4.      [,1][,2][,3]
  5. [1,]"a"  "a"  "a" 
  6. [2,]"a"  "a"  "a" 
  7. [3,]"a"  "a"  "a" 
  8. ,,2
  9.      [,1][,2][,3]
  10. [1,]"a"  "a"  "a" 
  11. [2,]"a"  "a"  "a" 
  12. [3,]"a"  "a"  "a" 
  13. ,,3
  14.      [,1][,2][,3]
  15. [1,]"a"  "a"  "a" 
  16. [2,]"a"  "a"  "a" 
  17. [3,]"a"  "a"  "a"        
  18. class(x5)  #"array"       数据结构是数组
  19. mode(x5)   #"character"
  20.  
  21. x51<-x5[,,1]
  22.  
  23. class(x51)#"matrix"
例子3.4
  1. gl(2,5)            #新建一个因子
  2. class(gl(2,5))     #"factor"    数据结构是因子
  3. mode(gl(2,5))      #"numeric"
而例子3.1-3.4 说明一个问题:
class返回的是matrix,array,factor之类的数据结构类型。(在class中的参数是一个向量或者单个值的时候,返回值和mode相同,不会返回vector,不过可以使用is.vector()返回值是T验证其确实是向量)
而mode返回的,是每一个元素的类型。
既然你说是每个元素的类型,那么为什么dataframe中mode返回的是list呢?
 
 
=============================================
例子4.1
  1. xl =list(fruit=c("apple","banana","pear"),
  2.           price=c(1,1,1.5),
  3.           market=c("newabest"))
  4. class(xl)    # "list"           数据结构是列表
  5. mode(xl)     # "list"
  6.  
  7. #也就是说,;列表中的每一项都是列表
  8. #class(xl$fruit) #"character"
例子4.1说明,列表中class和mode都是list
但是class(xl$fruit) 得到的是"character"
 
先说明下
1list[[index]] 得到的是元素(组件)
2list[index]   得到的是子列表 这点请见《R语言经典实例》P119-121
  1. > jj<-list(name=c("jos","xuan"),salary=55000,union=T)
  2. > jj[[1]]
  3. [1]"jos""xuan"
  4.  
  5. >class(jj[[1]]) #mode返回值也是character
  6. [1]"character"
  7.  
  8. > jj[1]
  9. $name
  10. [1]"jos""xuan"
  11. >class(jj[1]) #mode返回值也是list
  12. [1]"list"
  13.  
  14.  
  15.  
  16. > jj[[2]]
  17.  
  18. [1]55000
  19.  
  20. >class(jj[[2]])
  21. [1]"numeric"
  22.  
  23. > jj[2]
  24.  
  25. $salary
  26. [1]55000
  27. >class(jj[2])
  28.  
  29. [1]"list"
  30.  
  31. > jj[[1]][1]
  32.  
  33. [1]"jos"
  34. >class(jj[[1]][1])
  35.  
  36. [1]"character"
  37.  
  38. > mode(jj[[1]][1])
  39. [1]"character"
  40.  
  41. > jj[[3]
  42.  
  43. [1] TRUE
  44.  
  45. > jj[3]
  46.  
  47. $union
  48. [1] TRUE
  49. >is.vector(jj[[1]])
  50. [1] TRUE
  51. >is.vector(jj[[2]])
  52. [1] TRUE
  53.  
  54. >is.numeric(jj[[1]])
  55. [1] FALSE
  56. >is.numeric(jj[[2]])
  57. [1] TRUE
  58.  
  59. >is.vector(jj[[3]])
  60. [1] TRUE
  61. >is.list(jj[1])
  62. [1] TRUE
  63.  
  64. >is.vector(jj[1])
  65. [1] TRUE
因为s.vector(jj[1])返回值都是T,这个结果似乎,不是很令人信服
于是,搜索?is.vector()
查看帮助说明之后,我们知道了,原来默认的情况下是any,对于任意的原生类型和list以及表达式,都会返回T
例子5
 
  1.  
  2. 例子5.1
  3. > x <- c(a =1, b =2)
  4. > x
  5. a b
  6. 12
  7. >class(x)
  8. [1]"numeric"
  9. >is.vector(x)
  10. [1] TRUE
  11. >is.vector(x,"double")  
  12. #默认是双精度的,要是整型,要加L
  13. [1] TRUE
  14. >is.vector(x,"Integer")
  15. [1] FALSE
  16.  
  17. 例子5.2
  18. >is.vector(jj[[1]],"list")
  19. [1] FALSE
  20. >is.vector(jj[1],"list")
  21. [1] TRUE
说明,jj[1]实质上是一种list,而非向量
 
 
再看?mode()这一句中帮助文档的写法
Description
Get or set the type or storage mode of an object.
value   
a character string giving the desired mode or ‘storage mode’ (type) of the object.
mode(x) <- "newmode"(修改x的数据类型为新的类型newmode)
changes the mode of object x to newmode. This is only supported if there is an appropriate as.newmode function, for example "logical", "integer", "double", "complex", "raw", "character", "list", "expression", "name", "symbol" and "function". Attributes are preserved (but see below).
 
 
 
 
 
 
 

关于R中的mode()和class()的区别的更多相关文章

  1. R中一切都是vector

    0.可以说R语言中一切结构体的基础是vector! R中一切都是vector,vecotor的每个component必须类型一致(character,numeric,integer....)!vect ...

  2. 简单介绍一下R中的几种统计分布及常用模型

    统计学上分布有很多,在R中基本都有描述.因能力有限,我们就挑选几个常用的.比较重要的简单介绍一下每种分布的定义,公式,以及在R中的展示. 统计分布每一种分布有四个函数:d――density(密度函数) ...

  3. R中的par()函数的参数

    把R中par()函数的主要参数整理了一下(另外本来还整理了每个参数的帮助文档中文解释,但是太长,就分类之后,整理为图表,excel不便放上来,就放了这些表的截图)

  4. R中的name命名系列函数总结

    本文原创,转载请注明出处,本人Q1273314690 R中关于给行列赋名称的函数有 dimnames,names,rowname,colname,row.names 这五个函数,初学的时候往往分不清楚 ...

  5. 总结——R中查看属性的函数

    本文原创,转载注明出处,本人Q1273314690 R中知道一个变量的主要内容和结构,对我们编写代码是很重要的,也可以帮我们避免很多错误. 但是,R中有好几个关于属性查看的函数,我们往往不知道什么时候 ...

  6. R中创建not-yet-evaluated对象

    create not-yet-evaluated object在R中创建 not-yet-evaluated(就是some code we will evaluated later!!)对象;然后执行 ...

  7. R中,去掉dataframe中的NA行

    R中使用complete.cases 和 na.omit来去掉包含NA的行 现在有个一data.frame  datafile如下所示 Date        sulfate nitrate ID 1 ...

  8. 机器学习:形如抛物线的散点图在python和R中的非线性回归拟合方法

    对于样本数据的散点图形如函数y=ax2+bx+c的图像的数据, 在python中的拟合过程为: ##最小二乘法 import numpy as np import scipy as sp import ...

  9. 在R中整理数据

    原始数据一般分散杂乱,并含有缺失和错误值,因此在进行数据分析前首先要对数据进行整理. 一.首先,了解原始数据的结构. 可使用如下函数(归属baseR)来查看数据结构: class(dataobject ...

随机推荐

  1. setjmp()、longjmp() Linux Exception Handling/Error Handling、no-local goto

    目录 . 应用场景 . Use Case Code Analysis . 和setjmp.longjmp有关的glibc and eglibc 2.5, 2.7, 2.13 - Buffer Over ...

  2. iOS GCD中的dispatch_group

    假如有一组任务,A,B,C,D,其中ABC是可以并行的,D是必须在ABC任务完成后再执行的. (举个场景,比如吃饭前必须先做菜.做饭和买饮料,然后才能开吃) 1.关于ABC的并行: 采用多线程的方式就 ...

  3. 帝国cms栏目自定义字段首页调用

    例如:增加栏目自定义字段:chushi_bpic 用下面的灵动标签和调用: [e:loop={"select C.classid,C.classname,C.classimg,D.chush ...

  4. 基本概率分布Basic Concept of Probability Distributions 2: Poisson Distribution

    PDF version PMF A discrete random variable $X$ is said to have a Poisson distribution with parameter ...

  5. UVa 11149 Power of Matrix(倍增法、矩阵快速幂)

    题目链接: 传送门 Power of Matrix Time Limit: 3000MS      Description 给一个n阶方阵,求A1+A2+A3+......Ak. 思路 A1+A2+. ...

  6. VC++ 比较两个字符串是否相等,字母大小写相关。

    1.strcmp 这是用于ANSI标准字符串的函数(如string和char *),此函数接受两个字符串缓冲区做为参数,如果两个字符串是相同的则返回零.否则若第一个传入的字符串的值大于第二个字符串返回 ...

  7. OpenGLES入门笔记一

    学习地址:http://www.raywenderlich.com/3664/opengl-tutorial-for-ios-opengl-es-2-0 中文翻译:http://www.cnblogs ...

  8. [COCI2012Final]Pro1

    校内OJ上的题. 数据范围非常小,用暴搜就可以,加点剪枝阶乘级别的复杂度竟然可以跑得比$O(N^4)$的算法还要快QAQ. 我用的是Floyd,参考了别人的代码.大概就是先跑个Floyd把点点之间路径 ...

  9. HDU1392Surround the Trees(凸包判断 + 求周长)

    http://www.cnblogs.com/hmhard/archive/2013/02/05/2893035.html 这是判断三角区域那块写的不好. 判断凸包的方法: 1.将所有点按照y从小到大 ...

  10. python模块app登陆认证(M2Crypto数字证书加密)

    需求: 1.通过数字证书,非对称加密方式传送对称秘钥给服务端 2.用户名.密码使用对称秘钥加密,发送服务端验证 3.传送数据使用字节流方式 实现思路: 1.了解python的struct模块,用于字节 ...