R数据科学-1(dplyr)

简介: R数据科学-1(dplyr)

R数据科学(dplyr)

如今数据分析如火如荼,R与Python大行其道。你还在用Excel整理数据么,你还在用spss整理数据么。

 

数据分析的基础:Data Clean

数据清洗是数据处理的必备工作,而且往往需要花费大量时间去整理,去提取想要的数据,因为画图,报表都需要特定格式的数据。

EXCEL缺点:

· 数据粘贴复制,导致存在很多副本,更改都不知道原来数据有没有被改动

· 数据排序,计算,鼠标点击,容易误操作。

· 忘记保存,白费时间

· 效率低,时间长

现在,我们将学习对处理数据有用的两个软件包:

1. dplyr是用于简化表格数据操作的软件包。

2. tidyr使您可以在不同的数据格式之间快速转换。

两个软件包中的命令都可以与管道函数(%>%)很好地配合使用,这可以使代码更具可读性。详细内容可参考Cheatsheet手册

image.png

image.png

image.png

1.数据框格式(DataFrame

一般,我们的excel包括行(col)与列(row),在R语言中,经常对excel操作的对象称之为Dataframe,那么在进行数据查看时候,R语言可以看到数据结构。但是往往会打印出来很长,tidyr中的tibble就解决了此问题,直接简单的看到数据结构及变量类型。

class(mtcars)可以查看数据的类型,为"data.frame";mtcars就可以看到全部的数据了。但是如果数据太多,那么就很不方便。

head(mtcars),可以看到数据的前面6行,属于数据的一个预览。但是看不到各个列的属性。

%>%管道函数,其实就是将f()写在了数据的后面,下面示例的两个操作,都得到df,效果一样。只不过 %>%看起来更简单,将mtcars赋予新的tibble。

df以后的输出,很简洁,能看到32*11的数据行与列,也能看到各列的属性。一目了然

image.png

image.png

2.数据-变量提取及产生

我们经常会用到,只需要里面的几个变量,不是所有的变量都输出。那么就涉及到变量的提取。就会用到select函数,可以提取需要的变量。有一个好处就是,不修改原是数据。

那如果新产生一个变量mpg1=mpg,或者new=mpg*cyl,就用到mutate函数,产生新变量。

image.png

3.数据-变量条件筛选

dplyr::filter()函数对上述新产生的变量的数据df,进行筛选。只要符合am=1给提取出来,或者对符合am=1,gear=4条件的输出。

image.png

5.数据分组计算

有时候,需要分组计算均值标准差,或者看gear不同水平下的最大值最小值,那么就用到group_by()summarise() 函数。
譬如,对不同gear计算mpg的均值及标准差。或者根据am及gear分组计算mpg均值标注差。

image.png

6.数据转换

有时候,处理数据时候,需要对变量类型进行转换,譬如字符串,因子及数值类型相互转换,上述数据里面dbl 意思是数值类型(double class)我们现在产生新的字符串chr及因子fct。使用mutate函数。可以看到mpg1与new都变成了chr与fct。

提取new,看一下。

image.png

有时候,会需要将连续性的变量,转换成分类变量。这时候就需要用到ifelse函数(转换成二分类变量),或者cut函数转换成多类别变量。代码如下 image.png

目录
相关文章
go语言中遍历映射(map)
go语言中遍历映射(map)
304 8
|
12月前
|
Kubernetes 网络协议 API
OpenAI全球宕机思考:谈谈可观测采集稳定性建设
文章探讨了为什么大规模集群中的可观测性服务会产生大量API请求、API服务器为何对DNS解析至关重要以及故障恢复过程为何缓慢的原因。
372 12
|
11月前
|
人工智能 前端开发 架构师
2025年前端局势分析,我该不该转行?
2024年,前端领域经历了快速变化,AIGC的兴起和市场HC减少使得前端工程师面临挑战。尽管AI工具如通义灵码和Cursor能高效生成代码,但AI无法完全取代前端工程师,因其缺乏逻辑、沟通和创新能力。前端工作不仅限于编码,还包括需求分析、代码评审等。未来,前端不会“死亡”,而是持续演变。面对大环境的压力,提升综合能力、拥抱变化、持续学习和保持身心健康是关键。转型方向包括升管理、做架构师或转讲师等。稳住2025年,需适应变化、不断学习并探索更多可能性。
1897 16
|
算法 定位技术 数据库
深入理解CMake:优化构建过程,提升开发效率(下)
深入理解CMake:优化构建过程,提升开发效率
|
数据可视化 数据挖掘
R实战 | 置换多元方差分析(以PCoA的PERMANOVA分析为例)
R实战 | 置换多元方差分析(以PCoA的PERMANOVA分析为例)
1503 0
|
SQL 安全 Linux
Web安全——命令注入漏洞详解
Web安全——命令注入漏洞详解
887 0
|
索引 Python
Data Science | Pandas基础(二)
Data Science | Pandas基础(二)
206 0
|
网络协议 网络架构 Python
【Python】局域网多播技术简单实现
一、前言 之前在写工具的时候,产生了一个实现局域网协作功能的想法,刚开始准备采用TCP协议实现C/S模式的局域网广播通信方式。后来经过一番的搜索后发现可以使用局域网多播技术实现,这个技术上手不难,经过几天的捣鼓,最后顺利完成,因此分享给大家。
946 0
【Python】局域网多播技术简单实现
|
编解码 Linux Go
嵌入式linux之go语言开发(二)c动态库驱动调用
嵌入式linux之go语言开发(二)c动态库驱动调用
天猫精灵开发平台AliGenie - 打造孩子专属的暖心小伙伴
在天猫精灵陪伴孩子的过程中,除了监督学习、讲故事、听儿歌,我更希望它可以成为孩子倾诉的对象,当孩子遇到困难或者在学校被欺负,它可以化身为精灵,给予孩子更多的鼓励和说些更暖心话语,温暖一个个幼小的心灵。
777 0
天猫精灵开发平台AliGenie - 打造孩子专属的暖心小伙伴

热门文章

最新文章