按照唯一值进行分组,并找到持续时间,同时满足多个条件(使用R中的dplyr)
创始人
2024-08-25 18:00:04
0

下面是一个使用dplyr包在R中按照唯一值进行分组,并找到持续时间,同时满足多个条件的示例代码:

library(dplyr)

# 创建示例数据框
df <- data.frame(
  group = c("A", "A", "B", "B", "B", "C"),
  time = c("2021-01-01", "2021-01-02", "2021-01-01", "2021-01-02", "2021-01-03", "2021-01-01"),
  condition1 = c(TRUE, TRUE, FALSE, TRUE, FALSE, TRUE),
  condition2 = c(FALSE, TRUE, TRUE, FALSE, TRUE, TRUE)
)

# 将时间列转换为日期类型
df$time <- as.Date(df$time)

# 按照group列进行分组,并计算持续时间
result <- df %>%
  group_by(group) %>%
  arrange(time) %>%
  mutate(duration = difftime(lead(time), time, units = "days")) %>%
  filter(condition1 & condition2)

# 查看结果
print(result)

这段代码首先加载了dplyr包,然后创建了一个示例数据框df。数据框包含group列、time列、condition1列和condition2列。我们要按照group列进行分组,并找到同时满足condition1和condition2的时间段。

接下来,我们将time列转换为日期类型,以便后续计算持续时间。然后使用dplyr中的group_by函数按照group列进行分组。使用arrange函数按照时间排序数据框。然后使用mutate函数计算持续时间,使用lead函数获取下一个时间点,然后使用difftime函数计算两个时间点之间的持续时间。

最后,使用filter函数筛选出同时满足condition1和condition2的行。

最后,我们打印出结果result,即按照唯一值进行分组,并找到持续时间,同时满足多个条件的结果。

相关内容

热门资讯

2026版辅助挂!黑科技软件大... 2026版辅助挂!黑科技软件大全(辅助)竟然真的是有辅助攻略(真实有挂)1、黑科技软件大全模拟器是什...
2026版技巧!大众互娱脚本(... 2026版技巧!大众互娱脚本(辅助)切实存在有辅助神器(有挂解惑)1、大众互娱脚本免费脚本咨询教程、...
近日!边锋嘉兴辅助(辅助)切实... 近日!边锋嘉兴辅助(辅助)切实是真的有辅助脚本(有挂规律)所有人都在同一条线上,像星星一样排成一排,...
一直以来!上饶窝龙辅助(辅助)... 一直以来!上饶窝龙辅助(辅助)切实真的是有辅助技巧(有挂分享)1、许多玩家不知道上饶窝龙辅助辅助怎么...
明白辅助挂!开心斗一番破解版(... 明白辅助挂!开心斗一番破解版(辅助)总是真的是有辅助插件(有挂教学)1、在开心斗一番破解版插件功能辅...
无独有偶!花花生活圈怎么开挂(... 无独有偶!花花生活圈怎么开挂(辅助)果然存在有辅助神器(竟然有挂)该软件可以轻松地帮助玩家将花花生活...
2026版软件!山西扣点免费辅... 2026版软件!山西扣点免费辅助(辅助)本来存在有辅助脚本(详细教程)暗藏猫腻,小编详细说明山西扣点...
黑科技攻略!悟空大厅辅助(辅助... 黑科技攻略!悟空大厅辅助(辅助)切实真的是有辅助攻略(真的有挂);1、不需要AI权限,帮助你快速的进...
2026版总结!微信小程序辅助... 2026版总结!微信小程序辅助新天道辅助(辅助)一直是有辅助技巧(有挂功能)1、点击下载安装,微信小...
第三方辅助挂!三哥玩辅助器软件... 第三方辅助挂!三哥玩辅助器软件(辅助)果然是真的有辅助软件(有挂教学)1)三哥玩辅助器软件辅助插件:...