当前位置:   article > 正文

R语言入门看这一章就够了(上)_rstudio零基础入门

rstudio零基础入门

目录

一、R的基础

1.1、R的安装

1.2、牛刀小试

1.3、线性关系实例

1.4、工作空间

1.5、R包的使用

包的安装

结果的重用

二、R数据集

2.1、向量

2.2、矩阵

2.3、数组

2.4、数据框

2.5、列表

三、R的常用命令

四、list列表详解

五、数据源导入方法

5.1、键盘输入

5.2、从文本文件导入

5.3、导入Excel数据

六、访问MYSQL数据库


一、R的基础

1.1、R的安装

提示:想要R语言和RStudio安装包的私信我。

第一步:双击安装包

第二步:一直下一步,选择安装路径

这里最好不要放到C盘,也不要有中文路径,空格路径。

第三步:一直无脑下一步,等待安装即可

第四步:双击桌面R图标

1.2、牛刀小试

我们来编写一段代码:

  1. x <- rnorm(3)
  2. x

第一句代码表示随机生成3个数字赋值给变量x。

第二句代码表示获取变量x。

1.3、线性关系实例

  1. > age <- c(1,3,5,2,11,9,3,9,12,3) # 年龄数据集
  2. > weight <- c(4.4,5.3,7.2,5.2,8.5,7.3,6.0,10.4,10.2,6.1) # 体重数据集
  3. >
  4. > mean(weight) # 体重平均数
  5. [1] 7.06
  6. > sd(weight) # 体重标准差
  7. [1] 2.077498
  8. > cor(age,weight) # 年龄和体重的线性关系
  9. [1] 0.9075655
  10. > plot(age,weight) # 画图表示关系
  11. >

1.4、工作空间

就是代码和文档都放在哪个目录下了,最好一个项目一个工作空间。

  1. > getwd() # 获取你所在的工作空间
  2. [1] "C:/Users/DELL/Documents"

如果你不喜欢这个目录,你可以通过setwd("c:/Users/')去修改。

1.5、R包的使用

R自带了一系列默认包(包括base、datasets、graphics、methods等等),它们提供了种类繁多的默认函数和数据集

包的安装

比如我想安装名为car的包,使用如下命令:

install.packages("car")

这时他会提示你使用哪个镜像来下载,我们当然要选国内的镜像了,这样下载速度会快。

下载完需要把car包绑定到我们的环境下:

library(car)

我们输入一行命令测试一下:

> head(mtcars)

出现这个结果就代表安装car包成功了。

结果的重用

R语言的结果可以很好的保存,并且可以作为下一次使用的参数传进去。

比如:

  1. > result <- lm(mpg~wt, data=mtcars) # 做线性拟合
  2. > plot(result)

二、R数据集

按照某种格式来创建数据集,是任何数据分析的第一步。

(1)选择一种数据结构来存储。

(2)将数据输入或导入到这个数据结构中。

R拥有许多用于存储数据的对象类型,包括向量、矩阵、数组、数据框和列表

2.1、向量

其实就是一个一维数组,而且里面的元素必须是相同类型的。

比如:

  1. > a <- c(1,2,3,4,5,6) # 创建一个向量数据集,里面都是相同类型的
  2. > a
  3. [1] 1 2 3 4 5 6
  4. >
  5. > a[2] # 通过下标取出相应的元素
  6. [1] 2
  7. > a[5]
  8. [1] 5
  9. >

2.2、矩阵

是二维数据,并且元素类型必须一致。

比如:

  1. > y <- matrix(5:24, nrow=4, ncol=5) #创建5-24位数字,4行5列的矩阵数据集
  2. > y
  3. [,1] [,2] [,3] [,4] [,5]
  4. [1,] 5 9 13 17 21
  5. [2,] 6 10 14 18 22
  6. [3,] 7 11 15 19 23
  7. [4,] 8 12 16 20 24
  8. >
  1. > x <- c(2,45,68,94)
  2. > rnames <- c("R1","R2") # 创建矩阵行名
  3. > cnames <- c("C1","C2") # 创建矩阵列名
  4. > newMatrix <- matrix(x, nrow=2, ncol=2, byrow=TRUE, dimnames=list(rnames,cnames))
  5. > newMatrix
  6. C1 C2
  7. R1 2 45
  8. R2 68 94
  9. >

2.3、数组

与矩阵相似,但它的维度是大于2的。

比如:

  1. > dim1 <- c("A1","A2","A3")
  2. > dim2 <- c("B1","B2")
  3. > dim3 <- c("C1","C2","C3","C4")
  4. > d <- array(1:24, c(3,2,4), dimnames=list(dim1,dim2,dim3)) # 生成4个矩阵,每一个都是3*2的格式
  5. > d
  6. , , C1
  7. B1 B2
  8. A1 1 4
  9. A2 2 5
  10. A3 3 6
  11. , , C2
  12. B1 B2
  13. A1 7 10
  14. A2 8 11
  15. A3 9 12
  16. , , C3
  17. B1 B2
  18. A1 13 16
  19. A2 14 17
  20. A3 15 18
  21. , , C4
  22. B1 B2
  23. A1 19 22
  24. A2 20 23
  25. A3 21 24
  26. >

获取数组里的元素:

  1. > d[1,2,3] # 取第3个矩阵里的第1行,第二列的数据
  2. [1] 16
  3. >

2.4、数据框

数据框中,可以存在不同类型的数据,比如下面的列表:

病人编号、入院时间、年龄都是数值类型的,后面糖尿病类型和病情都是字符串类型。

比如:

  1. > patientID <- c(1,2,3,4) # 创建病人编号(第一列数据)
  2. > age <- c(25,34,28,52) # 创建年龄(第二列数据)
  3. > diabetes <- c("Type1", "Type2", "Type3", "Type2") # 创建糖尿病类型(第三列数据)
  4. > status <- c("poor", "Improved", "Excllent", "poor") # 创建病情(第四列数据)
  5. > patientsData <- data.frame(patientID, age, diabetes, status) # 创建数据框数据集
  6. > patientsData # 打印
  7. patientID age diabetes status
  8. 1 1 25 Type1 poor
  9. 2 2 34 Type2 Improved
  10. 3 3 28 Type3 Excllent
  11. 4 4 52 Type2 poor
  12. >
  13. > patientsData[1:2] # 获取patientsData变量的第一列到第二列数据
  14. patientID age
  15. 1 1 25
  16. 2 2 34
  17. 3 3 28
  18. 4 4 52
  19. >
  20. > patientsData[c("age")] # 获取patientsData变量的age那列数据
  21. age
  22. 1 25
  23. 2 34
  24. 3 28
  25. 4 52
  26. >
  27. > patientsData$age # 获取patientsData变量的age那列数据
  28. [1] 25 34 28 52
  29. >
  30. > attach(patientsData) # 将变量绑定,以后就可以直接使用列名打印了,就不用$符号了
  31. The following objects are masked _by_ .GlobalEnv:
  32. age, diabetes, patientID, status
  33. > age
  34. [1] 25 34 28 52
  35. >

2.5、列表

创建列表:

  1. > g <- "My first list" # 创建字符串
  2. > h <- c(12, 45, 43, 90) #创建向量数据集,里面是数值类型
  3. > j <- matrix(1:10, nrow=2) # 创建矩阵数据集,1-10,两行
  4. > k <- c("A", "B", "C") # 创建向量数据集,里面是字符串类型
  5. > mylist <- list(g, h, j, k) # 创建列表数据集
  6. > mylist
  7. [[1]]
  8. [1] "My first list"
  9. [[2]]
  10. [1] 12 45 43 90
  11. [[3]]
  12. [,1] [,2] [,3] [,4] [,5]
  13. [1,] 1 3 5 7 9
  14. [2,] 2 4 6 8 10
  15. [[4]]
  16. [1] "A" "B" "C"
  17. >
  18. > mylist[[2]] # 获取列表里第二个元素
  19. [1] 12 45 43 90
  20. >
  21. > mylist[[3]] # 获取列表里第三个元素
  22. [,1] [,2] [,3] [,4] [,5]
  23. [1,] 1 3 5 7 9
  24. [2,] 2 4 6 8 10
  25. >

三、R的常用命令

(1)查询所有的变量

ls()
  1. > ls()
  2. character(0)
  3. > data <- c(1,2,3)
  4. > ls()
  5. [1] "data"

(2)移除某个变量

rm(变量名)
  1. > rm(data)
  2. > ls()
  3. character(0)

(3)获取向量长度

length(变量名)
  1. > v <- c(1, 2, 3)
  2. > length(v)
  3. [1] 3

(4)获取变量所属类型

mode(变量名)
  1. > v <- c(1, 2, 3)
  2. > mode(v)
  3. [1] "numeric"

(5)各种方式形成向量

seq(1, 10, 2)  # 生成一个从1开始到10结束,步长为2的向量
  1. > x <- seq(1, 10, 2)
  2. > x
  3. [1] 1 3 5 7 9
rep(5, 10)  # 生成10个5的向量
  1. > x <- rep(5, 10)
  2. > x
  3. [1] 5 5 5 5 5 5 5 5 5 5
  1. > x <- rep(1:3, 3)
  2. > x
  3. [1] 1 2 3 1 2 3 1 2 3
  1. > x <- c(1, 20, 50, -5, -35, -80)
  2. > x
  3. [1] 1 20 50 -5 -35 -80
  4. > x[x > 0] # 获取大于0的向量
  5. [1] 1 20 50
  6. > x[x < -10 | x > 0] # 获取小于-10或者大于0的向量
  7. [1] 1 20 50 -35 -80
  8. >

四、list列表详解

  1. > mylist <- list(stud.id=1234, stud.name="Tom", stud.marks=c(12, 3, 14, 25, 19)) # 创建一个列表
  2. > mylist # 打印列表
  3. $stud.id
  4. [1] 1234
  5. $stud.name
  6. [1] "Tom"
  7. $stud.marks
  8. [1] 12 3 14 25 19
  9. > mylist[[1]] # 获取列表mylist的第一个元素值
  10. [1] 1234
  11. > mylist[[3]] # 获取列表mylist的第三个元素值
  12. [1] 12 3 14 25 19
  13. > mylist[1] # 获取列表mylist的第一个整元素值
  14. $stud.id
  15. [1] 1234
  16. > mode(mylist[[1]]) # 获取列表mylist第一个元素的类型
  17. [1] "numeric"
  18. > mode(mylist[1]) # 获取列表mylist第一个整元素的类型
  19. [1] "list"
  20. > mylist$stud.id # 和mylist[[1]]同理
  21. [1] 1234
  22. > names(mylist) # 获取列表mylist的所有元素名
  23. [1] "stud.id" "stud.name" "stud.marks"
  24. > names(mylist) <- c("id", "name", "marks") # 列表mylist里的元素改名
  25. > mylist
  26. $id
  27. [1] 1234
  28. $name
  29. [1] "Tom"
  30. $marks
  31. [1] 12 3 14 25 19
  32. > mylist$parents <- c("Mna", "Jutice") # 为列表mylist增加新元素parents
  33. > mylist
  34. $id
  35. [1] 1234
  36. $name
  37. [1] "Tom"
  38. $marks
  39. [1] 12 3 14 25 19
  40. $parents
  41. [1] "Mna" "Jutice"
  42. > mylist <- mylist[-4] # 列表mylist删除第四个元素
  43. > mylist
  44. $id
  45. [1] 1234
  46. $name
  47. [1] "Tom"
  48. $marks
  49. [1] 12 3 14 25 19
  50. > other <- list(age=19, sex="male") # 创建列表赋值给other变量
  51. > lst <- c(mylist, other) # 将列表mylist和列表other合并成一个列表赋值给lst
  52. > lst
  53. $id
  54. [1] 1234
  55. $name
  56. [1] "Tom"
  57. $marks
  58. [1] 12 3 14 25 19
  59. $age
  60. [1] 19
  61. $sex
  62. [1] "male"
  63. > unlist(lst) # 将列表转为向量形式,方便循环遍历
  64. id name marks1 marks2 marks3 marks4 marks5 age sex
  65. "1234" "Tom" "12" "3" "14" "25" "19" "19" "male"

解释一下unlist()函数:

比如向量我们很容易遍历,就是从1遍历到100,但是list的元素是可以多类型的,比如说list列表中第一个元素是向量,向量里又有1,2,3,4,5元素,那list列表第二个元素是矩阵,矩阵又包含二维数据,那么我们遍历就很麻烦,所以使用unlist函数先转为向量模式,再遍历就方便多了。

五、数据源导入方法

5.1、键盘输入

  1. > mydata <- data.frame(age=numeric(0), gender=character(0), weight=numeric(0)) # 创建数据框,但里面元素只是定义了名字和类型,却没有数据
  2. > mydata <- edit(mydata) # edit的意思是我们要手动键盘录入数据

fix(mydata)和mydata <- edit(mydata)是等价的。

5.2、从文本文件导入

先看看数据,是一个叫person.txt的文件,内容是:

  1. id,name,age,school
  2. 1,李白,20,哈尔滨工业大学
  3. 2,杜甫,30,哈尔滨工程大学
  4. 3,白居易,19,哈尔滨理工大学
  5. 4,杜牧,23,东北林业大学
  6. 5,李清照,27,东北农业大学
  1. > mydata <- read.table("D:/Java/R/resources/person.txt", header=TRUE, sep=",", encoding="UTF-8")
  2. > mydata
  3. id name age school
  4. 1 1 李白 20 哈尔滨工业大学
  5. 2 2 杜甫 30 哈尔滨工程大学
  6. 3 3 白居易 19 哈尔滨理工大学
  7. 4 4 杜牧 23 东北林业大学
  8. 5 5 李清照 27 东北农业大学

5.3、导入Excel数据

这个不能直接用read.table去读取Excel文件,得先把我们的Excel文件先另存为csv格式,这样就可以读取了。

我们的数据是这样的:

  1. > mydata <- read.table("D:/Java/R/resources/student.csv", header=TRUE, sep=",", encoding="UTF-8")
  2. > mydata
  3. ID 姓名 年龄 学校
  4. 1 1 李白 20 南京大学
  5. 2 2 杜甫 30 东南大学
  6. 3 3 白居易 40 南京理工大学

六、访问MYSQL数据库

install.packages("RODBC")
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/羊村懒王/article/detail/66126
推荐阅读
相关标签
  

闽ICP备14008679号