本文原创,转载请注明出处,本人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. iOS 采用个推时,未收到推送消息,测试DeviceToken无效

    一般在调试时我们使用任何boundleID,即为*的profile文件 但在使用推送后进行调试,除了创建和上传APN证书,还需要重新生成 (1)特定程序的BoundleID (2)包含Push Not ...

  2. PHP守护进程

    php也是可以直接进行守护进程的启动与终止的,相对于shell来说会简单很多,理解更方便,当然了php的守护进程要实现自动重启还是要依赖于shell的crontab日程表,每隔一段时间去执行一次脚本看 ...

  3. MVC-12 ActionMethodSelectorAttribute

    ActionMethodSelectorAttribute 其实微软对方法的起名都比较规范和通俗易懂的,从名字上来看就知道这是方法选择器 我们在action上加上 HttpGet.HttpPost . ...

  4. POJ 2823 Sliding Window + 单调队列

    一.概念介绍 1. 双端队列 双端队列是一种线性表,是一种特殊的队列,遵守先进先出的原则.双端队列支持以下4种操作: (1)   从队首删除 (2)   从队尾删除 (3)   从队尾插入 (4)   ...

  5. 【Beta版本】冲刺-Day3

    队伍:606notconnected 会议时间:12月11日 目录 一.行与思 二.站立式会议图片 三.燃尽图 四.代码Check-in 一.行与思 张斯巍(433) 今日进展:学习了很多androi ...

  6. spring+hibernate ---laobai

    biz包: package com.etc.biz; import java.util.List; import org.springframework.orm.hibernate3.support. ...

  7. BZOJ树链剖分题目汇总

    1036,2157,2243,4034,4196;2325,2908,3083,3159,3531,3626,3999;可以不树剖:1146;2819,2843,4448,4530.

  8. 线性回归和批量梯度下降法python

    通过学习斯坦福公开课的线性规划和梯度下降,参考他人代码自己做了测试,写了个类以后有时间再去扩展,代码注释以后再加,作业好多: import numpy as np import matplotlib. ...

  9. electron打包

    1.全局安装electron-packager npm install -g electron-packager 2.在项目目录下执行命令 electron-packager ./ --platfor ...

  10. UINT数相减

    UINT32 i = ; UINT32 j = ; i - j > //这个将永远为真,因为他是将将结果按照无符号解析 int = i -j; //这个是-1,是按照有符号解析 今天发现代码里面 ...