首页 > 其他分享 >R语言之数据框的合并

R语言之数据框的合并

时间:2023-08-26 16:00:44浏览次数:34  
标签:wide 函数 合并 格式 数据 变量 语言

文章和代码已经归档至【Github仓库:<https://github.com/timerring/dive-into-AI> 】或者公众号【AIShareLab】回复 R语言 也可获取。

有时数据集来自多个地方,我们需要将两个或多个数据集合并成一个数据集。合并数据框的操作包括纵向合并、横向合并和按照某个共有变量合并。

1.纵向合并:rbind( )

要纵向合并两个数据框,可以使用 rbind( )函数。被合并的两个数据框必须拥有相同的变量,这种合并通常用于向数据框中添加观测。例如:

data1 <- data.frame(id = 1:5, 
                    sex = c("female", "male", "male", "female", "male"),
                    age = c(32, 46, 25, 42, 29))
data1

R语言之数据框的合并_数据集

data2 <- data.frame(id = 6:10, 
                    sex = c("male", "female", "male", "male", "female"),
                    age = c(52, 36, 28, 34, 26))
data2

R语言之数据框的合并_数据_02

rbind(data1, data2)

2. 横向合并:cbind ( )

要横向合并两个数据框,可以使用 cbind( ) 函数。用于合并的两个数据框必须拥有相同的行数,而且要以相同的顺序排列。这种合并通常用于向数据框中添加变量。例如:

data3 <- data.frame(days = c(28, 57, 15, 7, 19),
                    outcome = c("discharge", "dead", "discharge", "transfer", "discharge"))
data3

cbind(data1, data3)

3. 按照某个共有变量合并:merge( )

有时我们有多个相关的数据集,这些数据集有一个或多个共有变量,我们想把它们按照共有变量合并成一个大的数据集。函数 merge( ) 可以实现这个功能,例如:

data4 <- data.frame(id = c(2, 1, 3, 5, 4), 
                    outcome = c("discharge", "dead", "discharge", "transfer", "discharge"))
data4

mydata <- merge(data1, data4, by = "id")
mydata

R语言之数据框的合并_数据集_03

full\_join( )

dplyr 包中的 full\_join( ) 函数也能实现上述功能上面的命令等价于:

options(warn=-1) # 清爽显示
library(dplyr)
mydata <- full_join(data1, data4, by = "id")
mydata

dplyr 包提供了多种用于合并数据框的函数,例如 bind\_rows( )、bind\_cols( )、left\_join( )、right\_join( ) 等,你可以查看这些函数的帮助文档了解它们的用法。

4. 数据框的长宽格式的转换

基本包里的函数 reshape( ) 可以对数据进行长宽格式之间的转换。

下面以 datasets 包里的数据集 Indometh 为例进行说明。该数据集是关于药物吲哚美辛(indometacin)的药物代谢动力学数据,一共有 6 名试验对象,每名试验对象在连续的 8 小时内定时测定了血液中的药物浓度,共有 11 次的测定值。该资料是长格式,下面将其转换为宽格式。

data(Indometh)
head(Indometh,12) # 这里增加一行,预览数据前 12 行,方便对比

R语言之数据框的合并_ide_04

wide <- reshape(Indometh, v.names = "conc", idvar = "Subject", timevar = "time", direction = "wide")
wide
  • Indometh:这是一个数据框或数据集,表示要进行重塑操作的原始数据。
  • v.names:这是一个字符串,表示要重塑的值变量的名称。在这种情况下,"conc"表示原始数据中的浓度变量。
  • idvar:这是一个字符串或向量,表示标识变量的名称或变量列表。在这种情况下,"Subject"表示原始数据中的主体标识变量。
  • timevar:这是一个字符串,表示时间变量的名称。在这种情况下,"time"表示原始数据中的时间变量。
  • direction:这是一个字符串,表示重塑的方向。在这种情况下,"wide"表示要将数据从长格式重塑为宽格式。

R语言之数据框的合并_数据_05

我们还可以将宽格式数据 wide 重新转换为长格式:

long <- reshape(wide, idvar = "Subject", varying = list(2:12),
        v.names = "conc", direction = "long")
head(long, 12)

R语言之数据框的合并_ide_06

函数 reshape( ) 功能强大,但里面的参数很多,使用起来略显不便。

tidyr 包以一种比较简洁统一的格式实现数据长宽格式的转换,其中,函数 pivot_wider( ) 用于把长格式数据转换为宽格式,而函数 pivot_longer( ) 用于把宽格式数据转换为长格式。上面的结果也可以用下述命令得到:

library(tidyr)
wide <- pivot_wider(as.data.frame(Indometh),
                    names_from = time,
                    values_from = conc)
wide

R语言之数据框的合并_数据_07

注意在上面的函数 pivot\_wider( ) 中,我们用函数 as.data.frame( ) 将数据 Indometh 转换成了数据框,这是因为其默认类型不是数据框。数据框 wide 也能重新转换为长格式:

long <- pivot_longer(wide, -Subject, 
                     names_to = "time", values_to = "conc")
long

R语言之数据框的合并_数据_08

一个“整洁”的数据集(tidy data)应该满足:每一行代表一个观测,每一列代表一个变量。在对医学数据进行分析之前,通常情况下应先把数据集转换为长格式,因为 R 中的大多数函数都支持这种格式的数据。

tidyr 包中的 gather()spread() 同样可以用于长型、宽型数据类型转换,详见 Cookbook for R

标签:wide,函数,合并,格式,数据,变量,语言
From: https://blog.51cto.com/u_15736437/7245128

相关文章

  • C语言实现顺序表
    顺序表本质上是数组,但是在数组的基础上,还要求数据是从头开始连续存储的,不能跳跃间隔。顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构,一般情况下采用数组存储。在数组上完成数据的增删查改。顺序表分为静态顺序表和动态顺序表两种静态顺序表使用定长数组存储元素......
  • 2023-08-26:请用go语言编写。开心一下的智力题: 有一个村庄,一共250人, 每一个村民要么一
    2023-08-26:请用go语言编写。开心一下的智力题:有一个村庄,一共250人,每一个村民要么一定说谎,要么只说真话,村里有A、B、C、D四个球队,且每个村民只会喜欢其中的一支球队,但是说谎者会不告知真实喜好,而且会说是另外三支球队的支持者。访问所有的村民之后,得到的访谈结果如下:A的支持者有90......
  • 2023-08-26:请用go语言编写。开心一下的智力题: 有一个村庄,一共250人, 每一个村民要么一
    2023-08-26:请用go语言编写。开心一下的智力题:有一个村庄,一共250人,每一个村民要么一定说谎,要么只说真话,村里有A、B、C、D四个球队,且每个村民只会喜欢其中的一支球队,但是说谎者会不告知真实喜好,而且会说是另外三支球队的支持者。访问所有的村民之后,得到的访谈结果如下:A的支......
  • 数据共享方法
    全局变量:使用全局变量可以在整个应用程序中共享数据。但是,过度使用全局变量可能导致代码难以维护和测试。静态类:静态类中的静态成员可以在整个应用程序中访问和共享数据。静态类适用于不需要实例化的数据和功能。单例模式:单例模式允许创建一个类的唯一实例,这个实例可以在......
  • 项目工程云平台源码 智慧工地管理 劳务管理、质量安全数据预警、施工现场视频实时监控
    5G智慧工地管理项目工程云平台源码通过运用物联网、大数据、云计算、BIM、5G等技术,搭建由劳务管理、质量安全数据预警、施工现场视频实时监控、重大危险源和绿色文明施工监控等板块构成的模块化、一站式的信息化管理平台。平台可实现施工现场数据采集、数据综合统计及分析、手机A......
  • 【MySQL 8.0】通过pt-table-checksum校验从库与主库的数据一致性
    通过yum安装percona-toolkit[root@node01~]#wgethttps://repo.percona.com/yum/percona-release-latest.noarch.rpm[root@node01~]#rpm-ivhpercona-release-latest.noarch.rpm[root@node01~]#yuminstall-ypercona-toolkit[mysql@node01~]$pt-table-checksum--......
  • redis的五大数据类型
    String(字符串)string是redis最基本的类型,你可以理解成与Memcached一模一样的类型,一个key对应一个value。string类型是二进制安全的。意思是redis的string可以包含任何数据。比如jpg图片或者序列化的对象。string类型是Redis最基本的数据类型,一个redis中字符串value最多可以是512M......
  • 【MySQL 8.0】透明数据加密(TDE)
    [mysql@node01~]$vim/etc/my.cnf[mysqld]early-plugin-load=keyring_file.sokeyring_file_data=/usr/local/mysql/data/keyring(root@node01)>selectplugin_name,plugin_statusfrominformation_schema.pluginswhereplugin_namelike'keyring%';......
  • 树上启发式合并
    与其说树上启发式合并是一种算法,不如说是一种思想。它在于通过”小的并入大的“保证复杂度,从而解决很多看似无法做的问题。论纯用树上启发式合并的题很少,但是很多题却可以用树上启发式合并去解决。模板求解的问题往往具有如下性质:每颗子树都有要记录的信息,信息的数量和子树大......
  • GEO数据结构
    概念GEO就是Geolocation的简写形式,代表地理坐标。Redis在3.2版本中加入了对GEO的支持,允许存储地理坐标信息,帮助我们根据经纬度来检索数据。常用命令常见的命令有:GEOADD:添加一个地理空间信息,包含:经度(longitude)、纬度(latitude)、值(member)GEOADDkeylongitudelatitudememb......