【数据挖掘】实验2:R入门2

实验2:R入门2

一:实验目的与要求

1:熟悉和掌握R数据类型。

2:熟悉和掌握R语言的数据读写。

二:实验内容

1:R数据类型

【基本赋值】

Eg.1代码:

x <- 8

x

 

Eg.2代码:

a = 'city'

a

【缺省值】

Eg.1代码:(1)生成向量z;(2)返回z的结果;(3)识别z的值是否有缺失值。

z <- c(1:5,NA)

z

is.na(z)

【查看对象类型】

Eg.1代码:创建3个不同类型的数据,展示3个辨别函数的区别,即mode<class<typeof。

df <- data.frame(c1 = letters[1:3], c2 = 1:3, c3 = c(1,-1,3.0), stringsAsFactors = F)

sapply(df, mode)

sapply(df, class)

sapply(df, typeof)

【向量赋值】

Eg.1代码:用c()构建向量(左箭头)。

x <- c(1,3,5,7,9)

x

Eg.2代码:将c()生成的数值向量赋值给y(右箭头)。

c(1,3,5,7,9) -> y

y

Eg.3代码:将c()生成的字符向量赋值给z。

z <- c("Male","Female","Female","Male","Male")

z

Eg.4代码:将c()生成的逻辑向量赋值给u。

u=c(TRUE,FALSE,TRUE,FALSE,FALSE)

u

Eg.5代码:同时创建不同类型的向量。

x1 <- c(1, 2, 3, 4)

x2 <- c("a", "b","c","d")

x3 <- c(TRUE, FALSE, FALSE, TRUE)

x1

x2

x3

Eg.6代码:相同类型元素的向量创建。

w <- c(1,3,4,5,6,7)

length(w)

mode(w)

Eg.7代码:相同类型元素的向量创建。

w1 <- c('张三','李四','王五')

length(w1)

mode(w1)

Eg.8代码:相同类型元素的向量创建。

w2 <- c(T,F,T)

length(w2)

mode(w2)

Eg.9代码:不同类型元素的向量创建(强制执行类型转换)。

w4 <- c(w,w1)

w4

mode(w4)

w5 <- c(w1,w2)

w5

mode(w5)


Eg.10代码:字符向量的paste()。

v <- paste("x",1:5,sep="")

v

Eg.11代码:向量赋值的assign()。

assign("w",c(1,3,5,7,9))

w

【向量运算】

Eg.1代码:向量的乘法、除法、乘方运算。

x <- c(1,3,5,7,9)

c(1,3,5,7,9) -> y

x*y

x/y

x^2

y^x

Eg.2代码:向量的加法运算。

c(1,3,5)+c(2,4,6,8,10)

【产生有规则序列】

Eg.1代码:产生正则序列。

(t <- 1:10)

(r <- 5:1)

2*1:5

Eg.2代码:seq()产生有规则的各种序列。

seq(1,10,2)

seq(1,10)

seq(10,1,-1)

Eg.3代码:seq()产生规定长度数列。

seq(1,by=2,length=10)

Eg.4代码:rep()重复一个对象。

rep(c(1,3),4)

rep(c(1,3),each=4)

rep(1:3,rep(2,3))

【向量的常见函数】

Eg.1代码:

x <-c(1,3,5,7,9)

length(x)

min(x)

range(x)

【索引向量】

Eg.1代码:取出向量的某一个元素,通过赋值语句来改变一个或多个元素的值。

x <- c(1,3,5)

x[2]

(c(1,2,3)+4)[2]

x[2] <- 10

x

x[c(1,3)] <- c(9,11)

x

Eg.2代码:以对向量进行逻辑运算。

x <- c(1,3,5)

x < 4

x[x<4]

z <- c(-1,1:3,NA)

z

z[is.na(z)] <- 0

z

z <- c(-1,1:3,NA)

y <- z[!is.na(z)]

y

Eg.3代码:

x <- c(2,4,6,8,1)

x[c(1,3,5)]

x[c(-2,-4)]

x[c(TRUE,FALSE,TRUE,FALSE,TRUE)]

Eg.4代码:

names(x) <- c('one','two','three','four','five')

x[c('one','three','four')]

x[c(1,-1)]

Eg.5代码:which函数,返回逻辑向量中为TRUE的位置。

x <- c(2,4,6,8,1)

which(x>3)

Eg.6代码:which(min(x))和which(max(x))。

which.min(x)

which.max(x)

【向量编辑】

Eg.1代码:向量编辑和向量扩展。

x <- c(1, 2, 3, 4)

(x <- c(x, c(5, 6, 7)))


Eg.2代码:单个元素的删除和多个元素的删除。

(x <- x[-1])

(x <- x[c(3:5)])

【矩阵创建】

Eg.1代码:

matrix(data=NA,nrow=1,ncol=1,byrow=FALSE,dimnames=NULL)

Eg.2代码:使用dimnames参数设置行和列的名称。

(w <- seq(1:10))

(a <- matrix(w,nrow = 5,ncol = 2,byrow = T,dimnames = list(paste('r',1:5),paste('l',1:2))))

 

【矩阵转化成向量】

Eg.1代码:as.vector函数和转置矩阵t函数。

x <- c(1:10)

a <- matrix(x,ncol=2,nrow=5,byrow=T,dimnames = list(paste('r',1:5),paste('l',1:2)))

b <- as.vector(a)

(c <- t(a))

【矩阵索引】

Eg.1代码:

x <- c(1:10)

a <- matrix(x,ncol=2,nrow=5,byrow=F,dimnames = list(c("r1","r2","r3","r4","r5"),c("c1","c2")))

a

a[2,1]

a["r2","c1"] # 根据行列名称索引

a[1,] # 检索某行

a[,1] # 检索某列

a[c(3:5),] # 向量索引,检索多行

【矩阵编辑】

Eg.1代码:删除元素。

(a5 <- a[-c(1:2),])

(a6 <- a[,-1])

【矩阵的行、列和维度】

Eg.1代码:dim函数返回维度。

a_matrix <- matrix(1:10,nrow=5,ncol=2)

dim(a_matrix)

Eg.2代码:nrow函数返回行数,ncol函数返回列数。

nrow(a_matrix)

ncol(a_matrix)

【数组创建】

Eg.1代码:

arr <- array(data=NA,dim=c(1,2,3),dimnames=NULL)

arr

【数组索引】

Eg.1代码:

x <- c(1:30)

dim1 <- c("A1","A2","A3")

dim2 <- c("B1","B2","B3","B4","B5")

dim3 <- c("C1","C2")

a <- array(x,dim=c(3,5,2),dimnames=list(dim1,dim2,dim3))

a[2,4,1]

a["A2","B4","C1"]

dim(a)

【数据框创建】

Eg.1代码:向量组成数据框。

my.datasheet <- data.frame(site=c('A','B','A','A','B'),season=c('winter','summer','summer','spring','fall'),pH=c(7.4,6.3,8.6,7.2,8.9))

my.datasheet

Eg.2代码:矩阵转化成为数据框。

(data_matrix <- matrix(1:8,c(4,2)))

(data.frame(data_matrix))

【数据框索引】

Eg.1代码:列名称和列下标索引。

iris$Sepal.Length

iris[["Sepal.Length"]]

iris[[2]]

iris[,2]

Eg.2代码:行下标检索。

iris[1:2,]

【数据框变量名称编辑】

Eg.1代码:names函数读取并编辑列名称。

my.datasheet <- data.frame(site=c('A','B','A','A','B'),season=c('winter','summer','summer','spring','fall'),pH=c(7.4,6.3,8.6,7.2,8.9))

names(my.datasheet)

names(my.datasheet)[1] <- 'type'

names(my.datasheet)

【数据框数据编辑】

Eg.1代码:rbin函数增加样本数据,cbin函数增加新的属性。

data_iris <- data.frame(Sepal.Length=c(5.1,4.9,4.7,4.6),Sepal.Width=c(3.5,3.0,3.2,3.1),Petal.Length=c(1.4,1.4,1.3,1.5),Petal.Width=rep(0.2,4))

data_iris

data_iris <- rbind(data_iris,list(5.0,3.6,1.4,0.2))

data_iris <- cbind(data_iris,Species=rep("setosa",5))

data_iris[,-1]

data_iris[-1,]

【列表创建】

Eg.1代码:

(my.list <- list(stud.id=34453,stud.name='张三',stud.marks=c(14.3,12,15,19)))

length(my.list)

unlist(my.list)

【列表索引】

Eg.1代码:

x <- c(1,1,2,2,3,3,3)

y <- c("女","男","男","女","女","女","男")

z <- c(80,85,92,76,61,95,83)

LST <- list(class=x,sex=y,score=z)

LST$class

names(LST)

LST["sex"]

LST[1]

LST[2]

LST[[2]][1:3]

LST$score

【因子】


Eg.1代码:factor函数创建因子。

(ff <- factor(substring("statistics",1:10,1:10),levels=letters))

(f. <- factor(ff))

ff[,drop=TRUE]

Eg.2代码:

factor(letters[1:20],labels="letter")

z <- factor(LETTERS[3:1],ordered=TRUE)

z

【txt数据读入】

操作1:在environment下的import dataset下读入文件。

操作2代码:

a1 = read.table("design.txt",header=T,sep="\t")

a2 = read.table("C:\\Users\\86158\\Desktop\\design.txt",header=T)

【csv数据读入】

Eg.1代码:

b <- read.csv("mtcars.csv",header = T,sep = ",")

head(b)

tail(b)

 【excel数据读入】

Eg.1代码:使用openxlsx包。

install.packages("openxlsx")

library(openxlsx)

(c <- read.xlsx("C:\\Users\\86158\\Desktop\\CO2.xlsx",sheet=1,startRow=1,colNames=T,rowNames=F,rows=1:60,cols=1:5))

【修改读入数据】

【quantmod案例】

Eg.1代码:

install.packages("quantmod")

library(quantmod)

getSymbols("AAPL", src = "av", api.key ="ESLSN43SQCZO9ZUG")

tail(AAPL)

Eg.2代码:主绘图函数。

chartSeries(AAPL,theme='white')

Eg.3代码:条形图。

barChart(AAPL,theme='white')

Eg.4代码:蜡烛图。

candleChart(AAPL,theme='white')

Eg.5代码:线图。

lineChart(AAPL,theme='white')

Eg.6代码:技术分析图。

chartSeries(AAPL,theme='white')

require(TTR)

addADX()

addATR()

addBBands()

addCCI()

addEMA()

【XML包举例】

Eg.1代码:

install.packages("XML")

library(XML)

strurl <- 'http://sports.163.com/zc'

tables <- readHTMLTable(strurl,header=FALSE,stringAsFactors=FALSE)

四:课堂练习

【练习1】PPT-02,第24页

练习1代码:创建一个向量x,内含等差数列:首位为1.7,等差为0.1,长度为5。

x <- seq(1.7,by=0.1,length=5)

x

练习1代码:创建向量y,y为重复序列:元素为“red”、“orange”、“green”,各元素重复两次,序列长度为5。

y <- rep(c("red","orange","green"),2,length=5)

y

若为先重复再组成向量,则代码如下:

y <- rep(c("red","orange","green"),each=2,length=5)

y

【练习2】PPT-02,第38页

练习2代码:使用matrix()函数,以向量形式输入矩阵中的全部元素,使用ncol和nrow设置矩阵的行和列数。

(w <- seq(1:10))

(a <- matrix(w,nrow=5,ncol=2))

若为按行填充,则代码如下:

(a <- matrix(w,nrow=5,ncol=2,byrow=T))

 【练习3】PPT-02,第46页

练习3代码:建立如图所示的矩阵,对第2行、第3列进行索引。

(w1 <- seq(1:6))

(w2 <- seq(7,by=1,length=6))

(a <- matrix(w1,nrow=3,ncol=2,byrow=T,dimnames=list(paste('u',1:3),paste('v',1:2))))

(b <- matrix(w2,nrow=3,ncol=2,dimnames=list(paste('u',1:3),paste('v',3:4))))

cbind(a,b)

cbind(a,b)[2,]

cbind(a,b)[,3]

cbind(a,b)[2,3]


【练习4】PPT-03,第39页

代码1:在R中读入design.txt文件。

(a <- read.table("C:\\Users\\86158\\Desktop\\design.txt",header=T,sep="\t"))

 代码2:在R中读入mtcars.csv文件。

(b <- read.csv("C:\\Users\\86158\\Desktop\\mtcars.csv",header=T,sep=","))

head(b)

tail(b)

names(b)

代码3:在R中读入biomass.xlsx文件的sheet1中前60行、5列数据。

( c <- read.xlsx("C:\\Users\\86158\\Desktop\\biomass.xlsx", sheet = 2, startRow = 1, colNames = TRUE, rowNames = FALSE, rows = 1:60, cols = 1:5))

代码4:将example.xls文件的数据读入R。

(d <- read.xlsx("C:\\Users\\86158\\Desktop\\example.xlsx",sheet=1,startRow=1,colNames=T,rowNames=F,rows=1:12,cols=1:12))

四:实验总结

1:常见的辨别和转换对象类型的函数。

2:R用于存储数据的对象类型,包括向量、矩阵、数组、数据框、列表。

3:seq函数产生等距间隔数列的基本形式。

4:向量常见函数。

5:索引向量的常见形式。

6:向量排序的形式。

7:矩阵计算的常用函数。

8:矩阵编辑(合并、删除)的常用函数。

五:遇到的问题和解决方案


问题1:矩阵创建时,出现以下报错。

解决1:dimnames输入错误,修改拼写后运行正确。

问题2:按照PPT03-第12页的代码执行时,出现以下报错。

解决2:出现拼写错误,需要将data.iris改为data_iris。

问题3:PPT03-第33页,关于getSymbols('AAPL',src=’yahoo’)代码的内容无法爬虫,会出现以下HTTP报错。

解决3:更换source,经过查询后得到可在网站(Free Stock APIs in JSON & Excel | Alpha Vantage.)上注册免费的API。

问题4:PPT03-第37页的url1网站无法打开,Rcurl举例无法复现。

解决4:暂无。

问题5:使用excel读取时,出现以下报错。

Error in read.xlsx("C:\\Users\\86158\\Desktop\\biomass.xlsx", sheet = 2,  :

  没有"read.xlsx"这个函数

解决5:安装openxlsx依赖包。

install.packages("openxlsx")

library(openxlsx)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/452961.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

碳实践 | 基于“界、源、算、质、查”五步法,实现企业组织碳核算

碳排放核算是夯实碳排放统计的基础&#xff0c;提高碳排放数据质量的关键&#xff0c;同时&#xff0c;将推动能耗“双控”向碳排放“双控”转变。总体来看&#xff0c;碳核算分为区域层面、组织层面和产品层面的碳核算&#xff0c;这三个层面的意义和计算方法完全不同。本文将…

【高通camera hal bug分析】高通自带相机镜像问题

首先打了两个log&#xff0c;一个是开启镜像的log&#xff0c;还有一个是没有开启镜像的log&#xff0c;如果我们开启镜像以后&#xff0c;观察开启镜像log发现 , 这段代码走的没有任何问题&#xff0c;因为Flip的值等于1了。 关闭镜像log如下&#xff1a; 如果我们不开启镜像…

<机器学习初识>——《机器学习》

目录 一、人工智能概述 1 人工智能应用场景 2 人工智能发展必备三要素 3 人工智能、机器学习和深度学习 二、人工智能发展历程 1 人工智能的起源 1.1 图灵测试 1.2 达特茅斯会议 2 发展历程 三、 人工智能主要分支 1 主要分支介绍 1.1 分支一&#xff1a;计算机视觉…

STM32点亮LED灯与蜂鸣器发声

STM32之GPIO GPIO在输出模式时可以控制端口输出高低电平&#xff0c;用以驱动Led蜂鸣器等外设&#xff0c;以及模拟通信协议输出时序等。 输入模式时可以读取端口的高低电平或电压&#xff0c;用于读取按键输入&#xff0c;外接模块电平信号输入&#xff0c;ADC电压采集灯 GP…

基于Springboot的驾校预约学习系统(有报告)。Javaee项目,springboot项目。

演示视频&#xff1a; 基于Springboot的驾校预约学习系统&#xff08;有报告&#xff09;。Javaee项目&#xff0c;springboot项目。 项目介绍&#xff1a; 采用M&#xff08;model&#xff09;V&#xff08;view&#xff09;C&#xff08;controller&#xff09;三层体系结构…

ubuntu2004桌面系统英伟达显卡驱动安装方法

#如何查看显卡型号 lspci | grep -i vga#----output------ 01:00.0 VGA compatible controller: NVIDIA Corporation Device 1f06 (rev a1)根据 Device 后的 值 进入网站查询 pci-ids.ucw.cz/mods/PC/10de?actionhelp?helppci #根据显卡型号&#xff0c;下载对应系统的驱动…

C++ 作业 24/3/12

1、自己封装一个矩形类(Rect)&#xff0c;拥有私有属性:宽度(width)、高度(height),定义公有成员函数: 初始化函数:void init(int w, int h)更改宽度的函数:set_w(int w)更改高度的函数:set_h(int h) 输出该矩形的周长和面积函数:void show() #include <iostream>using …

一劳永逸的方法解决:LNK1168无法打开 xxx.exe 进行写入 报错问题

这种错误的产生原因&#xff1a; 运行程序退出不是按正常流退出&#xff0c;是按窗口右上角的 “X” 来关闭程序&#xff0c;但是后台的xxx.exe控制台程序还在运行&#xff1b;修改程序的代码后再运行&#xff0c;就会报LNK1168的错误&#xff1b; 报错示例&#xff1a; 解决方…

【嵌入式学习】C++day03.12

一、思维导图 二、练习 #include <iostream>using namespace std;class Rect {int width;int height; public:void init(int w,int h){widthw;heighth;}void set_w(int w){widthw;}void set_h(int h){heighth;}void show(){int per2*(widthheight);int areawidth*height;…

通过el-select选择器和el-tree树形结构二次封装(vue2+elementUI),开发element-plus的TreeSelect树形选择器

需求&#xff1a; 领导看我在另一个vue3项目的el-tree-select挺好的&#xff0c;叫我移入vue2的项目中。 但是vue2版本的elementUI&#xff0c;并没有这个组件&#xff0c;所以只能自己找&#xff0c;找半天找不到和它差不多的&#xff0c;通过网友写的组件改写的 参考链接&…

手势学习

1. 点击手势 Composable fun ClickableSample() {val number remember {mutableStateOf(0)}Text(text number.value.toString(),textAlign TextAlign.Center,modifier Modifier.wrapContentSize().clickable {number.value}.background(Color.LightGray).padding(horizonta…

软件I2C读写MPU6050

文章目录 前言本次线路图封装I2C时序封装MPU6050,配置寄存器最后在主函数进行显示 前言 本片文章开始进行I2C在STM32的直接操作&#xff0c;理解时序的代码实现&#xff0c;理解对寄存器的配置&#xff0c;使用I2C读写MPU6050&#xff0c;读取MPU6050的各轴数据。 MPU6050详解…

vue 自定义组件绑定model+弹出选择支持上下按键选择

参考地址v-modelhttps://v2.cn.vuejs.org/v2/guide/components-custom-events.html#%E8%87%AA%E5%AE%9A%E4%B9%89%E7%BB%84%E4%BB%B6%E7%9A%84-v-model 原文代码 Vue.component(base-checkbox, {model: {prop: checked,event: change},props: {checked: Boolean},template: `…

Java异常分类(二)

RuntimeException 运行时异常&#xff1a; 派生于 RuntimeException 的异常&#xff0c;如被 0 除、数组下标越界、空指针等&#xff0c;其产生比较频繁&#xff0c;处理麻烦&#xff0c;如果显式的声明或捕获将会对程序可读性和运行效率影响很大。因此由系统自动检测并将它们交…

Caffeine缓存

本地缓存基于本地环境的内存&#xff0c;访问速度非常快&#xff0c;对于一些变更频率低、实时性要求低的数据&#xff0c;可以放在本地缓存中&#xff0c;提升访问速度 使用本地缓存能够减少和Redis类的远程缓存间的数据交互&#xff0c;减少网络 I/O 开销&#xff0c;降低这…

使用EasyRec快速构建推荐模型

随着移动app的普及&#xff0c;个性化推荐和广告成为很多app不可或缺的一部分。他们在改善用户体验和提升app的收益方面带来了巨大的提升。深度学习在搜广推领域的应用也已经非常深入&#xff0c;并且给各种场景的效果带来了巨大的提升。针对推荐流程的各个阶段&#xff0c;业界…

基于YOLOv8/YOLOv7/YOLOv6/YOLOv5的石头剪刀布手势识别系统详解(深度学习模型+UI界面代码+训练数据集)

摘要&#xff1a;本篇博客深入探讨了使用深度学习技术开发石头剪刀布手势识别系统的过程&#xff0c;并分享了完整代码。该系统利用先进的YOLOv8、YOLOv7、YOLOv6、YOLOv5算法&#xff0c;并对这几个版本进行性能对比&#xff0c;如mAP、F1 Score等关键指标。文章详细阐述了YOL…

【算法题解】Java算法题目解析

1. 数字三角形 import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner scan new Scanner(System.in);int n scan.nextInt();int[][] dp new int[n 1][n 1];int max 0;for (int i 1; i < dp.length; i) {for (int j 1; j &l…

Android 生成SO - 基础工程创建

最近需要给小伙伴扫盲一下如何使用Android Studio 生成一个SO文件&#xff0c;网上找了很多都没有合适的样例&#xff0c;那只能自己来写一个了。 原先生成SO是一个很麻烦的事情&#xff0c;现在Android Studio帮忙做了很多的事情&#xff0c;基本只要管好自己的C代码即可。 …

第2篇【Docker项目实战】使用Docker部署Raneto知识库平台(转载)

【Docker项目实战】使用Docker部署Raneto知识库平台 一、Raneto介绍 1.1 Raneto简介 Raneto是一个免费、开放、简单的 Markdown 支持的 Node.js 知识库。 1.2 知识库介绍 知识库 知识库是指存储和组织知识的系统或库&#xff0c;它包括了各种类型的信息和知识&#xff0c;如…
最新文章