R的数据结构
R语言中的数据结构包括标量、向量、矩阵、数组、列表以及数据框
目录
1 向量
向量是用于存储单一数据类型(数值、字符、逻辑值)的一维数组,示例如下:
a <- c(1,2,3,4,5) #数值
mode(a)
b <- c('a','b','c','d') #字符
mode(b)
c <- c(T,F,F,T) #逻辑
mode(c)
值得注意的是R的标量是向量的特例,是单一的元素的向量:
a <- 1
b <- 'c'
c <- T
虽然向量必须具有单一的数据类型,但是也存在着如下的情况:
a <- c('a',2,3) #数值转换为字符
mode(a)
b <- c(1,T,1,0) #TRUE转换为1,FALSE转换为0
mode(b)
R中内置了seq函数以快速生成有序的向量:
seq(from = 1,to = 50,by = 10) #缩写:seq(1,50,10)
seq(length = 10,from = 1,to = 40)
内置了rep函数以快速生成循环向量:
rep(1,10)
rep(c(1,5,6),3)
rep(1:4,each = 3)
内置了字母序列letters:
letters[2:15]
对于已经创建的向量,该如何操作向量?下面将演示几个比较常见的向量操作示例:
a <- c(1,4,6,8,2,3,5,6)
# 1.给向量命名
names(a) <- c('x1','x2','x3','x4','x5','x6','x7','x8')
# 2.提取数值4
a[2] #向量的元素下标取值是以1开始
a[[2]] #不含元素名
a[-2] #提取除了元素位置2的所有元素
# 3.提取数值4&8
a[c(2,4)] #提取多个元素使用元素下标向量
# 4.提取前4个元素
a[1:4] #提取连续的位置的元素
# 5.提取数值大于4的元素
a[a>4] #a>4:逻辑向量
# 6.向量的添加
b <- c(a,x9 = 5) #x9为元素名
b <- append(b,0,after = 4) #after确定添加在元素位置4后
names(b) <- c('x1','x2','x3','x4','x5','x6','x7','x8','x9','x10')
c <- c(a,b) #合并向量
# 7.向量排序
order(a) #输出排序后的各个向量位置
sort(a) #输出排序后的结果,等价于:a[order(a)]
# 8.which函数:返回元素坐标
which(a==4)
which(a>5) #等价于:a>5
which.max(a)
which.min(a)
最后将演示下R中的向量比较与运算,示例如下:
# 1.向量的比较
a <- runif(5,1,20)
b <- rnorm(5)
a>b #元素逐一比较
identical(a,b) #向量整体比较
all.equal(a,b)
a <- 1:3
b <- 1:5
a>b #长度不一致无法比较
# 2.向量的运算
a <- runif(5,1,20)
b <- rnorm(5)
a+b
a <- 1:3
b <- 1:5
a-b #长度不一致,a循环补充
R的数据结构的更多相关文章
- 【R】数据结构
之前一阵子,在EDX上学习了R语言的一门基础课程,这里做个总结.这门课程主要侧重于R的数据结构的介绍,当然也介绍了它的基本的绘图手段. 工作空间相关 ls() ## character(0) rm(a ...
- R语言-数据结构
1.向量 向量是用来存储数值型.字符型或逻辑性数据的一维数组,用函数c()创建向量 a <- c(1,2,5,6,4) b <- c("one","two&q ...
- R语言数据结构
5. 数据结构 5.1 数据结构简介 (1)向量 一个向量的所有元素必须有相同的类型(模式) (2)列表 列表可以非同质的 列表可按位置索引:lst[[2]] 抽取子列表:lst[c(2,5)] 列表 ...
- 第二章 R语言数据结构
R语言存储数据的结构包括:标量.向量.矩阵.数组.数据框和列表:可以处理的数据类型包括:数值型.字符型.逻辑型.复数型和原生型. 数据结构 向量 向量是用来存储数值型.字符型或逻辑型数据的一维数组.单 ...
- Advanced R之数据结构
看了几本R语言语法相关的书籍,感觉都不怎么好,在实际使用过程中仍然遇到很多难以理解的问题,后来看了Hadley Wickham的Advanced R,好多问题迎刃而解,今天重温了该书的第一章即数据结构 ...
- R语言数据结构二
上节我们讲到R语言中的基本数据类型,包括数值型,复数型,字符型,逻辑型以及对应的操作和不同数值类型之间的转换.众所周知,R语言的优势在于进行数据挖掘,大数据处理等方面,因此单个的数据并不能满足我们的需 ...
- R语言数据结构一
R是面向对象的语言,它跟其他编程语言的数据类型差不多,有四种,分别为:数值型,复数型,逻辑性和字符型 数值型:即数字,分为整数型和双精度型.数字可以用科学技术法表示,形式为Xe+m,意为x乘10的m次 ...
- (数据科学学习手札01)Python与R基本数据结构之异同
Python 1.列表(list) list1 = [i for i in range(10)] list1[0, 1, 2, 3, 4, 5, 6, 7, 8, 9] 特点:可遍历,可索引,可切片 ...
- R的数据结构--数组
数组:可以认为数组是矩阵的扩展,它将矩阵扩展到2维以上.如果给定的数组是1维的则相当于向量,2维的相当于矩阵. R语言中的数组元素的类型也是单一的,可以是数值型,逻辑型,字符型或复数型 参数解释 ar ...
随机推荐
- 【[USACO08JAN]haybale猜测Haybale Guessing】
抄题解.jpg 完全完全不会啊,这道题简直太神了 不过抄题解可真开心 首先这道题目保证了每一个位置上的数都是不同的,那么就能得到第一种判断不合法的方式 如果两个区间的最小值一样,但是两个区间的交集为空 ...
- Java集合源码 -- Map映射和Set集合
Map接口 Map接口是有一个映射表, 存储键和值, 它提供了两个通用的接口HashMap 和 TreeMap HashMap 是散列映射表, 对键散列; Tree是树映射表, 对键进行排序,并将其组 ...
- TensorFlow学习('utf-8' codec can't decode byte 0xff in position 0: invalid start byte)
使用语句: image_raw_data = tf.gfile.GFile("./picture.jpg", "r").read() 读取图像时报错如下: Un ...
- gdbt与adboost(或者说boosting)区别
boosting 是一种将弱分类器转化为强分类器的方法统称,而adaboost是其中的一种,或者说AdaBoost是Boosting算法框架中的一种实现 https://www.zhihu.com/q ...
- 算法——(5)B/B+/红黑树
1. B树——lgdN B树是平衡多路查找树,主要用于文件系统的索引. 1)定义: 对于一个度数为d的B树, 每个结点最多有d个孩子 如果根结点不是叶子结点,那它至少有两个孩子 每个非叶子结点(非根结 ...
- 使用arcpy替换栅格数据异常
使用arcpy替换mxd中的栅格图层数据源时,发现导出的图片异常. 修改代码把修改后的mxd保存后发现修改后的数据源不是我传入参数的数据源 比如我设置的参数是 “2019_3_2_2f8091e2d4 ...
- C# 4.0 不要跨程序集用dynamic指向匿名类型 (转载)
今天写代码时偷懒用了dynamic,结果遇到问题,运行时始终无法获取dynamic对象的属性.原问题简化后如下: 程序集A包含SampleClass类,有一个静态方法,接收一个dynamic类型参数并 ...
- Web | 一小时看懂前端基本语法
自从H5出来之后,web前端的势头好像就有点燎原之势.国内互联网的发展就是这样,像之前的移动App(iOS.Android),简直是火的一塌糊涂.所以不管是培训机构也好,自学成才也好,都是一种途径,能 ...
- nginx+uwsgi+flask+supervisor 项目部署
环境 - Linux: Ubuntu 16.04 - uWSGI 2.0.18 - Flask 1.0.2 - supervisor 3.2.0 - nginx/1.8.1 首先区分几个概念 WSGI ...
- iframe 框架 父页面与子界面之间的变量、函数、元素获取
1.获取页面上的iframe 1-1. document.getElementById('iframeId'): 1-2. window.frames[0].window.frames['frameN ...