## 1. 数据输入 ##
a$b         # 数据框中的变量
a = 15      # 赋值
a <- 15     # 赋值
a = c(1,2,3,4,5)    # 数组(向量)
b = a[1]            # 数组下标,从1开始
b = a[1:5]          # 子数组
b = a[-2]           # 子数组:扣除第2个的子数组
b = a[c(1,3)]       # 子数组:访问第1,3个元素
b = c(a0,a1,a2)     # 连接多个数组
a = rep(c(1,2,3,4),each=8)  # 生成重复数列,支持每个重复和整个重复
a = seq(from=1,to=4,by=1)   # 生成等差数列
b = cbind(a0,a1,a2,a3)      # 按列合并,生成二维数组
b = a[,1]           # 取第1列
b = a[1:4,1]
b = a[,c(1,3,4)]
a = vector(length=8)        # 生成向量
a = matrix(1:20, nrow=8,ncol=4) # 生成矩阵
colnames(a) = c("A","B","C","D")    # 列名称。!! 函数作为左值
b = as.matrix(cbind(a1,a2,a3))      # 利用cbind直接生成矩阵
b = data.frame(b1 = a1,b2 = a2)     # 生成数据框
b = list(c(1,2,3),c("a","b","c","d"),matrix(nrow=2,ncol=2))     # 生成散列
b = a$c == 1    # 生成一个用于筛选的向量 !!较难理解
d = a[b,0]      # 生成符合条件的子集
d = a[a$c == 1,]
b = order(a$c)  # 生成一个用于排序的向量 !!较难理解
a[b,]           # 排序结果
b = merge(a1,a2,by = "Sample",all = "TRUE")     # join两个数据框
a$fb = factor(a$b)  # 因子化
tapply(X=a$b,INDEX=a$c,FUN=mean)    # 对所有子集作函数运算
sapply(a,FUN=mean)  # 对所有列作函数运算,输出向量
lapply(a,FUN=mean)  # 对所有列作函数运算,输出列表
summary(a)          # 计算所有列的基本统计信息
table(a$b)          # 计算列联表
table(a$b,a$c)
paste("a","b",sep=",")  # 连接字符串 

##2. 载入和输出数据 ##
b = read.table(file="C:/data.txt",header=TRUE,dec=".")  # 读取CSV数据
library(RODBC)      # 载入ODBC工具
odbcConnect("MyDb.mdb") # 连接ODBC数据库
b = sqlFetch(channel,"MyTable")     # 取表
write.table(a,file="temp.txt",sep=" ",quote = FALSE, append=FALSE,na="NA")  # 输出

## 3. 绘图 ##
plot(x=a$b,y=a$c,xlab="X",ylab="Y",main="Title",xlim=c(0,10),ylim=c(0,100),pch=1,col=2,cex=1.5) # 散点图,参数多支持向量
lines()         # 曲线
jpeg(file="any.jpg")    # 打开一个jpg文件
dev.off()       # 关闭图片文件

## 4. 语法 ##
for (i in 1:10) {do sth...} # for循环
a = function(a,b="n") {     # 构造函数
    do sht...
}

## A. 函数  ##
# 运算 #
colSums()   # 按列求和
max()
median()    # 中位数
min()
paste()     # 连接字符串
rowSums()   # 按行求和
solve()     # 矩阵求拟
sqrt()      #
sum()       # na.rm=TRUE 忽略NA值
t()         # 矩阵转置

# 数据定义 #
attach()    # 添加数据框为路径
as.matrix() # 作为矩阵
as.data.frame() # 作为数据框
c()         # 连接向量
cbind()     # 按列连接,生成二维
colnames()  # 列名
detach()    # 去除数据框作为路径
dim()       # 行数、列数
factor()    # 因子化
is.matrix() # 是否矩阵
is.data.frame() # 是否数据框
lapply()    # 对所有列作函数运算,输出列表
matrix()    # 生成矩阵
names()     # 查看list的元素名称
nrow()      # 行数
ncol()      # 列数
order()     # 数据框排序
rbind()     # 按行连接
rep()       # 重复数列。 each 自身重复
rm()        # 删除变量
rownames()  # 行名
sapply()    # 对所有列作函数运算,输出向量
seq()       # 等差数列
str()       # 数据框的每个属性
summary()   # 计算所有列的基本统计信息
table()     # 计算列联表
tapply()    # 对所有子集作函数运算
unique()    # 查找剔重值
vector()    # 生成向量

# 环境与载入、输出数据
read.table()    # 读取数据文件
scan()      # 读取数据文件
setwd()     # 设置当前工作目录
write.table()   # 输出文件

# 绘图
jpeg()      # 打开JPG图片
plot()      # 散点图
dev.off()   # 关闭图片文件

R语言语法笔记的更多相关文章

  1. C语言语法笔记 – 高级用法 指针数组 指针的指针 二维数组指针 结构体指针 链表 | IT宅.com

    原文:C语言语法笔记 – 高级用法 指针数组 指针的指针 二维数组指针 结构体指针 链表 | IT宅.com C语言语法笔记 – 高级用法 指针数组 指针的指针 二维数组指针 结构体指针 链表 | I ...

  2. R语言语法基础二

    R语言语法基础二 重塑数据 增加行和列 # 创建向量 city = c("Tampa","Seattle","Hartford"," ...

  3. R语言语法基础一

    R语言语法基础一 Hello world #这里是注释 myString = "hello world" print(myString) [1] "hello world ...

  4. R语言学习笔记:因子

    R语言中的因子就是factor,用来表示分类变量(categorical variables),这类变量不能用来计算而只能用来分类或者计数. 可以排序的因子称为有序因子(ordered factor) ...

  5. R语言学习笔记:字符串处理

    想在R语言中生成一个图形文件的文件名,前缀是fitbit,后面跟上月份,再加上".jpg",先不百度,试了试其它语言的类似语法,没一个可行的: C#中:"fitbit&q ...

  6. R语言学习笔记:向量

    向量是R语言最基本的数据类型. 单个数值(标量)其实没有单独的数据类型,它只不过是只有一个元素的向量. x <- c(1, 2, 4, 9) x <- c(x[1:3], 88, x[4] ...

  7. R语言学习笔记︱Echarts与R的可视化包——地区地图

    笔者寄语:感谢CDA DSC训练营周末上完课,常老师.曾柯老师加了小课,讲了echart与R结合的函数包recharts的一些基本用法.通过对比谢益辉老师GitHub的说明文档,曾柯老师极大地简化了一 ...

  8. R语言学习笔记(五)绘图(1)

      R是一个惊艳的图形构建平台,这也是R语言的强大之处.本文将分享R语言简单的绘图命令.   本文所使用的数据或者来自R语言自带的数据(mtcars)或者自行创建.   首先,让我们来看一个简单例子: ...

  9. R语言学习笔记1——R语言中的基本对象

    R语言,一种自由软件编程语言与操作环境,主要用于统计分析.绘图.数据挖掘.R本来是由来自新西兰奥克兰大学的Ross Ihaka和Robert Gentleman开发(也因此称为R),现在由“R开发核心 ...

随机推荐

  1. 打开已存在 Android项目及常见的问题

    Eclipse 打开已存在 Android项目及常见的问题   1.  点击菜单“File”-- "Import",会弹出 Import 对话框:   2,  选择“General ...

  2. mysql聚合函数

    1.统计一下插入的数据总数 SELECT COUNT(giftCertificateId) AS number FROM gift_certificate WHERE giftCertificateN ...

  3. 【转】java静态代码块和构造方法执行顺序

    先看看下面几个类,然后判断它们的输出public class A { static{System.out.print(1);}public A(){System.out.print(2);}} pub ...

  4. Spring任务调度

    任务调度是大多数应用系统的常见需求之一,拿论坛来说:每个半个小时生成精华文章的RSS文件,每天凌晨统计论坛用户的积分排名,每隔30分钟执行对锁定过期的用户进行解锁.以上都是以时间为关注点的调度,事实上 ...

  5. 为ListView添加头和脚

      转自:https://software.intel.com/zh-cn/blogs/2014/12/15/android-listview-addheaderview-addfooterview ...

  6. Oracle批量加注释,并生成html

    excel连接列名生成oracle注释 notes: A2为列名,B2为注释 ="comment on column ColAgreementHeader."&A2& ...

  7. 《Mysql 公司职员学习篇》 第三章 小A的疑问

    第三章 小A的疑问  ---- 数据类型和自增列 小A拿着鸡腿,回到了房间里面,咬了一嘴油,说:"我有2个疑问,在Excell里面,像列PetAge(宠物年龄)这样的数字,我一般会设置成数值 ...

  8. posix thread概述(示例代码)

    一个简单的alarm实例 errors.h头文件 #ifndef __ERRORS_H #define __ERORRS_H #include<stdio.h> #include<u ...

  9. 条件阻塞Condition的应用

    Condition的功能类似在传统线程技术中的Object.wait和Object.notity的功能.   例子:生产者与消费者 import java.util.Random; import ja ...

  10. latch和DFF的区别和联系

    1.latch的缺点 ①没有时钟端,不受系统同步时钟的控制,无法实现同步操作:和当前我们尽可能采用时序电路的设计思路不符. ②对输入电平敏感,受布线延迟影响较大,很难保证输出没有毛刺产生: ③latc ...