R语言4.3.0安装及使用教程(非常详细),从零基础入门到精通,看完这一篇就够了(附安装包))

一、软件下载

软件:R语言
版本:4.3.0
语言:简体中文
大小:77.74M
安装环境:Win7及以上版本,64位操作系统
硬件要求:[email protected] 内存@4G(或更高)
下载通道①百度网盘丨64位下载链接:

https://pan.baidu.com/s/1RuQKDCdhNrTTPVmkFmRBkQ?pwd=6789

提取码:6789

软件介绍

R for Windows是一个免费的用于统计计算和统计制图的优秀工具,是R语言开发工具。它拥有数据存储和处理系统、数组运算工具(其向量、矩阵运算方面功能尤其强大)、完整连贯的统计分析工具、优秀的统计制图等功能。提供的图形界面,可以在其中访问控制台、创建脚本或安装其他软件包。

二、特点

R语言是用于统计分析,图形表示和报告的编程语言和软件环境。 以下是R语言的重要特点:

  • R语言是一种开发良好,简单有效的编程语言,包括条件,循环,用户定义的递归函数以及输入和输出设施。

  • R语言具有有效的数据处理和存储设施,

  • R语言提供了一套用于数组,列表,向量和矩阵计算的运算符。

  • R语言为数据分析提供了大型,一致和集成的工具集合。

  • R语言提供直接在计算机上或在纸张上打印的图形设施用于数据分析和显示。

  • R语言是彻底面向对象的统计编程语言。

三、安装

3.1安装R

官网:R: The R Project for Statistical Computing

3.2安装Rstudio

RGUI是R 默认的图形化界面,功能不多且图形界面比较简陋,使用起来不是很友好,所以这时就需要一款集成开发环境——studio软件,使用Rstudio可以更加容易的使用R软件,Rstudio是第三方开发的很好用的集成开发环境,也是一款免费的软件,相比较与R默认的RGUI,Rstudio具有更丰富的功能,使用时更加人性化,例如,软件将R控制台,控制窗口,帮助窗口集成到同一个界面下,并且支持代码高亮,自动补齐,可以补齐对象名,函数名等,非常的方便,避免输入的错误。

官网:RStudio | Open source & professional software for data science teams - RStudio

3.3linux安装R

yum -y install gcc glibc-headers gcc-c++ gcc-gfortran readline-devel libXt-devel bzip2-devel xz-devel perl* pcre* zlib-devel libcurl-devel

wget https://cran.r-project.org/src/base/R-4/R-4.2.1.tar.gz

tar -zxvf R-4.2.1.tar.gz

mkdir /etc/R

./configure --enable-R-shlib --prefix=/etc/R  --with-readline=no --with-libpng --with-jpeglib


–enable-R-shlib 【必须写】

–prefix=/etc/R这个参数是用来定义R的安装位置的,一定要保证这个目录存在,如果没有这个目录,请先建立这个目录,不指定这个目录的话会安装到解压目录即/home/007/R-3.1.2中,不建议这样,请指定一个空的目录

–with-x=no表示不使用X-Windows系统,也就是类Unix操作系统的GUI,一般不会使用这个,但默认为yes,如果你没有安装libx的话会报错的,所以我们直接设置为no

–with-readline=no表示不使用系统的readline库,如果系统上没有libreadline,此选项填“no“,默认是yes,但是我的系统下没有安装readline库,而且我也不会在RedHat的命令终端中一行一行的写R程序,我将其设置了为no,其结果是我们无法使用上下左右键来查找使用过的命令了,呵呵,也罢,反正我也不会写在终端中写多少行R命令,如果你要用的话,建议你先查找下你的机器上是否安装了readline,如果没有的话我的安装包中有,将其安装上之后再设置为yes,执行上面的命令即可


【如果报错请按一下方法解决】提示错误:

yum install gcc-gfortran

然后运行继续报错:


yum install gcc-c++

然后运行:

错误描述:–with-readline=yes(默认)和头文件/库不可用
解决办法:安装头文件和库,记得连续选中Y,否则该错误无法避


yum install readline-devel

然后运行:

 解决办法:安装头文件和库,记得连续选中Y,否则该错误无法避免


yum install libXt-devel

然后运行:


yum -y install xz-devel.x86_64

运行:


yum install libcurl-devel.x86_64 libcurl.x86_64

运行:


make

make install

vi /etc/profile

添加一行:

大功告成:

查看版本:R --version

3.4在线安装

yum install epel-release

yum install R

3.5卸载

R.home() ## 查看R的安装目录
R.Version()[13] ## 查看R版本
Sys.getenv(“R_HOME”)
.Library ##查看lib位置
.libPaths() ##查看lib位置

yum list installed | grep R
R.x86_64 2.15.2-1.el5 installed
R-core.x86_64 2.15.2-1.el5 installed
R-devel.x86_64 2.15.2-1.el5 installed
yum remove R.x86_64
yum remove R-core.x86_64

3.6修改Rstudio工作目录

默认的为:

修改:

1.找到R的安装路径

在第一行添加:

重新进入Rstudio:

四、基础知识

4.1数据类型

R语言基本的数据类型有:数值、逻辑型(TRUE,FALSE)、文本(字符串)。

R语言数据结构包括:向量、矩阵和数据框、多维数组、列表、对象等。

最基本的是向量类型。

4.2数值型向量及其运算

4.2.1数值型向量

向量是将若干个基础类型相同的值存储在一起,各个元素可以按序号访问。如果将若干个数值存储在一起可以用序号访问,就叫做一个数值型向量。

c()函数:把多个元素或向量组合成一个向量。
: x = c(10,6,4,7,8)
length(x)可以求x的长度
numeric()函数可以用来初始化一个指定元素个数而元素都等于0的数值型向量,如numeric(10)会生成元素为10个0的向量。

4.2.2运算

**标量与标量运算:**R中四则运算用+ - * / ^(加、减、乘、除、乘方)%/%表示整除,%%表示求余。

向量与标量运算 、等长向量运算、不等长向量运算

4.3向量化的相关函数

R中的函数一般都是向量化的。


**一元函数:**在R中,如果普通的一元函数以向量为自变量,一般会对每个元素计算。这样的函数包括sqrt,log10,log,exp,sin,cos,tan等许多。

排序函数:sort(x)返回排序结果。rev(x)返回把各元素排列次序反转后的结果。order(x)返回排序用的下标。

统计函数:sum(求和),mean(求平均值) ,var(求样本方差),sd(求样本标准差),min(求最小值),max(求最大值),range(求最小值和最大值)等函数称为统计函数,把输入向量看作样本,计算样本统计量。prod求所有元素的乘积。comsum和cumprod计算累加和累乘积。

生成规则序列的函数

seq函数时冒号运算符的推广。比如,seq(5)等同于1:5,seq(11,15,by=2)产生11,13,15
rep函数用来产生重复数值。rep(c(1,3),2)把第一个自变量重复两次,结果相当于c(1,3,1,3)。
rep(c(1,3),c(2,4))相当于c(1,1,3,3,3,3)。
rep(c(1,3),each=2))结果相当于c(1,1,3,3)

4.3逻辑型向量及其运算

4.3.1比较运算

is.na()函数:判断向量每个元素是否NA。is.na(c(1,NA,3)>2)

is.finite()函数:判断向量每个元素是否Inf值,比较运算符包括 < <= > >= == != %in%

注:%in%是比较特殊的比较, x %in% y的运算把向量y看成集合,运算结果是一个逻辑型向量。

c(1,3) %in% c(NA,3,4)

## [1] FALSE TRUE

函数match(x,y)起到和x %in% y 运算类似的作用,但是其返回结果不是找到与否,而是对x的每个元素,找到其在y中首次出现的下标,找不到时取缺失值,如:

match(c(1,3),c(2,3,4,3))

## [1] NA 2

4.3.2逻辑运算

逻辑运算符为&,|和!,分别表示“同时成立”、“两者至少其一成立”、“条件的反面”

4.3.3逻辑运算函数

若c是逻辑向量,用**all©测试c的所有元素为真;用any©**测试c至少一个元素为真

all(c(1, NA, 3) > 2)

## [1] FALSE

any(c(1, NA, 3) > 2)

## [1] TRUE

函数**which()**返回真值对应的所有下标。如:

which(c(FALSE, TRUE, TRUE, FALSE, NA))

## [1] 2 3

which((11:15) > 12)

## [1] 3 4 5

函数**identical(x,y)**比较两个R对象x和y的内容是否完全相同,结果只会取标量TRUE与FALSE两种。如:

identical(c(1,2,3), c(1,2,NA))

## [1] FALSE

函数**duplicated()**返回每个元素是否为重复值的结果,如:

duplicated(c(1,2,1,3,NA,4,NA))

## [1] FALSE FALSE TRUE FALSE FALSE FALSE TRUE

用函数**unique()**可以返回去掉重复值的结果。

4.4字符型数据及其处理

4.4.1字符型向量

字符型向量是元素为字符串的向量

4.4.2常用函数

**paste():**连接两个字符型向量,元素一一对应连接,默认用空格连接。如paste(c(“ab”,“cd”),c(“ef”,“gh”))结果相当于c(“ab ef”,“cd gh”),其中:sep= 指定分隔符,用collapse= 参数可以把字符型向量的各个元素连接成一个单一的字符串。如paste(c(“a”,“b”,“c”),collapse=“”)结果相当于“abc”

toupper():把字符型向量内容转为大写

tolower():把字符型向量转为小写

nchar(x,type=‘bytes’):计算字符型向量x中每个字符串的以字节为单位的长度。

nchar(x,type=‘chars’):计算字符型向量x中每个字符串的以字符个数为单位的长度。

substr(x,start,stop):从字符串x中取出从第start个到第stop个的子串

substring(x,start):从字符串x中取出从第start个到末尾的子串

substring(c(‘JAN07’, ‘MAR66’), 4)

## [1] “07” “66”

4.5类型转化

as.numeric():把内容是数字的字符型值转换为数值。

as.numeric():是向量化的,可以转换一个向量的每个元素为数值型。

as.character():把数值型转换为字符型

sprintf():用指定的格式数值型转换为字符型,其用法与C语言的sprintf()函数相似,只不过是向量化的。

sprintf(‘file%03d.txt’, c(1, 99, 100))

## [1] “file001.txt” “file099.txt” “file100.txt”

strsplit():把一个字符串按照某种分隔符拆分开

x <- ‘10,8,7’

strsplit(x, ‘,’, fixed=TRUE)[[1]]

## [1] “10” “8” “7”

gsub():替换字符串中的子串,这样的功能经常用在数据清理中。比如,把数据中的中文标点改为英文标点,去掉空格等等。

x <- ‘1, 3; 5’

gsub(‘;’, ‘,’, x, fixed=TRUE)

## [1] “1, 3, 5”

4.6向量下标和子集

4.6.1正整数下标

从1开始

x[0]是一种少见的做法,结果返回类型相同、长度为零的向量,如numeric(0)。相当于空集。

4.6.2负整数下标

负下标表示扣除相应的元素后的子集

4.6.3空下标和零下标

取x的全部元素作为子集。

4.7条件函数

which():用来找到满足条件的下标

which.min()、which.max()求最小值的下标和最大值的下标,不唯一时只取第一个

4.8元素名

用unname(x)返回去掉了元素名的x的副本
用names(x) <- NULL 可以去掉x的元素名

4.9集合元素

unique(x):可以获得x的所有不同值

a %in% x :判断a的每个元素是否属于向量x

match(x,table):对向量x的每个元素,从向量table中查找其首次出现位置并返回这些位置。没有匹配到的元素位置返回NA_integer_

intersect(x,y):求交集,结果中不含重复元素

union(x,y):求并集,结果中不含重复元素

setdiff(x,y):求差集,即x的元素中不属于y的元素组成的集合,结果中不含重复元素

setequal(x,y):判断两个集合是否相等

4.10数据类型的性质

4.10.1基本类型

typeof():返回一个变量或表达式的类型

typeof(1:3)
## [1] “integer”
typeof(c(1,2,3))
## [1] “double”
typeof(factor(c(‘F’, ‘M’, ‘M’, ‘F’)))
## [1] “integer”

注意:因子的结果是integer而不是因子
R还有两个函数mode()和storage.mode()起到与typeof()类似的作用
R中数据的最基本的类型包括:logical,integer,double,character,complex,raw
为了判断某个向量x保存的基本类型,可以用is.xxx()类函数
在R语言中数值一般看作double,如果需要明确表明某些数值是整数,可以再数值后面附加字母L

is.integer(c(1, -3))
## [1] FALSE
is.integer(c(1L, -3L))
## [1] TRUE

4.10.2类型转换

四则运算中数值会被统一转换为double类型,逻辑运算中运算元素会被统一转换为logical类型。

在用c()函数合并若干元素时,如果元素基本类型不同,将统一转换成最复杂的一个,复杂程度从简单到复杂依次为:logical < integer < double < character

4.11因子类型

4.11.1因子

用factor()函数把字符型向量转换成因子

4.11.2 table()函数

用table()函数统计因子各水平的出现次数(称为频数或频率)。也可以对一般的向量统计每个不同元素的出现个数。

4.12列表类型

4.12.1列表

R中列表(list)类型来保存不同类型的数据。一个主要目的是提供R分析结果输出包装:输出一个变量,这个变量包括回归系数、预测值、残差、检验结果等等一系列不能放到规则形状数据结构中的内容。实际上,数据框也是列表的一种,但是数据框要求各列等长,而列表不要求。列表可以有多个元素,但是与向量不同的是,列表的不同元素的类型可以不同,比如,一个元素是字符串,一个元素是标量,一个元素是另一个列表。

用typeof()函数判断一个列表,返回结果是list。可以用is.list()函数判断某个对象是否列表类型

如果是创建的元素为数值类型,可:

4.12.2列表元素访问

4.12.3列表类型转换

用as.list()把一个其它类型的对象转换成列表;用unlist()函数把列表转换成基本向量。

4.13R矩阵和数组

4.13.1R矩阵

矩阵用matrix函数定义,实际存储成一个向量,根据保存的行数和列数对应到矩阵的元素,存储次序为按列存储。
用nrow()和ncol()函数可以访问矩阵的行数和列数。

4.13.2矩阵子集

colnames()函数可以给矩阵每列命名
rownames()函数可以给矩阵每行命名

4.13.3行列向量转换

若x是向量,cbind(x)把x变成列向量,rbind(x)把x变成行向量

4.13.4apply()函数

apply(A,2,FUN)把矩阵A的每一列分别输入到函数FUN中,得到对应于每一列的结果,如:

D <- matrix(c(6,2,3,5,4,1), nrow=3, ncol=2); D
##      [,1] [,2]
## [1,]    6    5
## [2,]    2    4
## [3,]    3    1
apply(D, 2, sum)
## [1] 11 10

4.14数据库

函数data.frame()可以生成数据框。

d <- data.frame(
    name=c(“李明”, “张聪”, “王建”), 
    age=c(30, 35, 28), 
    height=c(180, 162, 175),
    stringsAsFactors=FALSE)
print(d)
##   name age height
## 1 李明  30    180
## 2 张聪  35    162
## 3 王建  28    175

data.frame()函数会将字符型列转换成因子,加选项stringsAsFactors=FALSE可以避免这样的转换。
nrow(d)求d的行数,ncol(d)或length(d)求d的列数。数据框每列叫做一个变量,每列都有名字,称为列名或变量名,可以用names()函数和colnames()函数访问。

4.15R语言中的索引

“[“, $和@都可以根据索引取值,但是它们使用范围不一样。

4.15.1 “[”

"**[**":是按索引取值,或者名称取值,返回结果不改变数据类型

"["(x,n)

参数介绍:
x: 具有索引值的对象,如vector,list
n: 是一个整数或者字符串

h=data.frame(abc=c(5,6))

'['(h,'abc')
#    abc
# 1   5
# 2   6

'['(h,1)
#    abc
# 1   5
# 2   6

4.15.2 $和[[]]的用法

[[]]也是根据索引或者名称取值,和KaTeX parse error: Undefined control sequence: \[ at position 10: 使用的对象一样,X\̲[̲\[‘a’,exact=FAL…a是等价的。

$采用模糊配合的模式从对象中取值

x <- list(abc = 1)
x$a
# [1] 1

h=data.frame(abc=c(5,6))
h$a
# [1] 5 6

h[['a',exact=FALSE]]
# [1] 5 

注意从大数据的计算效率来看,[[]]的运算效率更高

4.15.3 @的用法

@是针对S4对象进行取值的。

library(ROCR)
data(ROCR.simple)
pred <- prediction( ROCR.simple$predictions, ROCR.simple$labels)
performance(pred,'auc')@y.values
# [[1]]
# [1] 0.8341875

题外话

初入计算机行业的人或者大学计算机相关专业毕业生,很多因缺少实战经验,就业处处碰壁。下面我们来看两组数据:

2023届全国高校毕业生预计达到1158万人,就业形势严峻;

国家网络安全宣传周公布的数据显示,到2027年我国网络安全人员缺口将达327万。

一方面是每年应届毕业生就业形势严峻,一方面是网络安全人才百万缺口。

6月9日,麦可思研究2023年版就业蓝皮书(包括《2023年中国本科生就业报告》《2023年中国高职生就业报告》)正式发布。

2022届大学毕业生月收入较高的前10个专业

本科计算机类、高职自动化类专业月收入较高。2022届本科计算机类、高职自动化类专业月收入分别为6863元、5339元。其中,本科计算机类专业起薪与2021届基本持平,高职自动化类月收入增长明显,2022届反超铁道运输类专业(5295元)排在第一位。

具体看专业,2022届本科月收入较高的专业是信息安全(7579元)。对比2018届,电子科学与技术、自动化等与人工智能相关的本科专业表现不俗,较五年前起薪涨幅均达到了19%。数据科学与大数据技术虽是近年新增专业但表现亮眼,已跻身2022届本科毕业生毕业半年后月收入较高专业前三。五年前唯一进入本科高薪榜前10的人文社科类专业——法语已退出前10之列。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-tDfulYHk-1691741819438)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20230809162658551.png)]

“没有网络安全就没有国家安全”。当前,网络安全已被提升到国家战略的高度,成为影响国家安全、社会稳定至关重要的因素之一。

网络安全行业特点

1、就业薪资非常高,涨薪快 2021年猎聘网发布网络安全行业就业薪资行业最高人均33.77万!

img

2、人才缺口大,就业机会多

2019年9月18日《中华人民共和国中央人民政府》官方网站发表:我国网络空间安全人才 需求140万人,而全国各大学校每年培养的人员不到1.5W人。猎聘网《2021年上半年网络安全报告》预测2027年网安人才需求300W,现在从事网络安全行业的从业人员只有10W人。
img

行业发展空间大,岗位非常多

网络安全行业产业以来,随即新增加了几十个网络安全行业岗位︰网络安全专家、网络安全分析师、安全咨询师、网络安全工程师、安全架构师、安全运维工程师、渗透工程师、信息安全管理员、数据安全工程师、网络安全运营工程师、网络安全应急响应工程师、数据鉴定师、网络安全产品经理、网络安全服务工程师、网络安全培训师、网络安全审计员、威胁情报分析工程师、灾难恢复专业人员、实战攻防专业人员…

职业增值潜力大

网络安全专业具有很强的技术特性,尤其是掌握工作中的核心网络架构、安全技术,在职业发展上具有不可替代的竞争优势。

随着个人能力的不断提升,所从事工作的职业价值也会随着自身经验的丰富以及项目运作的成熟,升值空间一路看涨,这也是为什么受大家欢迎的主要原因。

从某种程度来讲,在网络安全领域,跟医生职业一样,越老越吃香,因为技术愈加成熟,自然工作会受到重视,升职加薪则是水到渠成之事。

黑客&网络安全如何学习

今天只要你给我的文章点赞,我私藏的网安学习资料一样免费共享给你们,来看看有哪些东西。

1.学习路线图

行业发展空间大,岗位非常多

网络安全行业产业以来,随即新增加了几十个网络安全行业岗位︰网络安全专家、网络安全分析师、安全咨询师、网络安全工程师、安全架构师、安全运维工程师、渗透工程师、信息安全管理员、数据安全工程师、网络安全运营工程师、网络安全应急响应工程师、数据鉴定师、网络安全产品经理、网络安全服务工程师、网络安全培训师、网络安全审计员、威胁情报分析工程师、灾难恢复专业人员、实战攻防专业人员…

职业增值潜力大

网络安全专业具有很强的技术特性,尤其是掌握工作中的核心网络架构、安全技术,在职业发展上具有不可替代的竞争优势。

随着个人能力的不断提升,所从事工作的职业价值也会随着自身经验的丰富以及项目运作的成熟,升值空间一路看涨,这也是为什么受大家欢迎的主要原因。

从某种程度来讲,在网络安全领域,跟医生职业一样,越老越吃香,因为技术愈加成熟,自然工作会受到重视,升职加薪则是水到渠成之事。

黑客&网络安全如何学习

今天只要你给我的文章点赞,我私藏的网安学习资料一样免费共享给你们,来看看有哪些东西。

1.学习路线图

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-CMEPwgLU-1691741819439)(C:\Users\Administrator\Desktop\网安思维导图\享学首创年薪40W+网络安全工程师 青铜到王者技术成长路线V4.0.png)]

攻击和防守要学的东西也不少,具体要学的东西我都写在了上面的路线图,如果你能学完它们,你去就业和接私活完全没有问题。

2.视频教程

网上虽然也有很多的学习资源,但基本上都残缺不全的,这是我自己录的网安视频教程,上面路线图的每一个知识点,我都有配套的视频讲解。

内容涵盖了网络安全法学习、网络安全运营等保测评、渗透测试基础、漏洞详解、计算机基础知识等,都是网络安全入门必知必会的学习内容。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-x8pfusUn-1691741819441)(C:\Users\Administrator\Desktop\网安资料截图\视频课件.jpeg)]

(都打包成一块的了,不能一一展开,总共300多集)

因篇幅有限,仅展示部分资料,需要点击下方链接即可前往获取

如果你对网络安全入门感兴趣,那么你需要的话可以点击这里网络安全重磅福利:入门&进阶全套282G学习资源包免费分享!

3.技术文档和电子书

技术文档也是我自己整理的,包括我参加大型网安行动、CTF和挖SRC漏洞的经验和技术要点,电子书也有200多本,由于内容的敏感性,我就不一一展示了。

![挖掘文档 (1)](C:\Users\Administrator\Desktop\网安资料截图\挖掘文档 (1).png)

因篇幅有限,仅展示部分资料,需要点击下方链接即可前往获取

如果你对网络安全入门感兴趣,那么你需要的话可以点击这里网络安全重磅福利:入门&进阶全套282G学习资源包免费分享!

4.工具包、面试题和源码

“工欲善其事必先利其器”我为大家总结出了最受欢迎的几十款款黑客工具。涉及范围主要集中在 信息收集、Android黑客工具、自动化工具、网络钓鱼等,感兴趣的同学不容错过。

还有我视频里讲的案例源码和对应的工具包,需要的话也可以拿走。

因篇幅有限,仅展示部分资料,需要点击下方链接即可前往获取
如果你对网络安全入门感兴趣,那么你需要的话可以点击这里网络安全重磅福利:入门&进阶全套282G学习资源包免费分享!

最后就是我这几年整理的网安方面的面试题,如果你是要找网安方面的工作,它们绝对能帮你大忙。

这些题目都是大家在面试深信服、奇安信、腾讯或者其它大厂面试时经常遇到的,如果大家有好的题目或者好的见解欢迎分享。

参考解析:深信服官网、奇安信官网、Freebuf、csdn等

内容特点:条理清晰,含图像化表示更加易懂。

内容概要:包括 内网、操作系统、协议、渗透测试、安服、漏洞、注入、XSS、CSRF、SSRF、文件上传、文件下载、文件包含、XXE、逻辑漏洞、工具、SQLmap、NMAP、BP、MSF…

img

因篇幅有限,仅展示部分资料,需要点击下方链接即可前往获取

如果你对网络安全入门感兴趣,那么你需要的话可以点击这里网络安全重磅福利:入门&进阶全套282G学习资源包免费分享!

你可能感兴趣的:(r语言,开发语言)