按组返回下一个出现的值,并从数据子集中返回(有条件的lead/lag)
创始人
2024-09-02 21:05:40
0

我们可以使用dplyr包中的lead和lag函数来实现此目的。

例如,假设我们有一个数据集“df”,其中有两列“group”和“value”。我们想按组返回“value”的下一个出现值,并且该值必须满足某些条件。

下面是一个示例代码:

library(dplyr)

# 创建一个示例数据集
df <- data.frame(group = c(1, 1, 1, 2, 2, 2),
                 value = c(10, 20, 30, 100, 200, 300))

# 按组返回下一个出现的值,并从数据子集中返回(有条件的lead/lag)
df %>%
  group_by(group) %>%
  mutate(next_value = lead(value),
         next_value_subset = ifelse(next_value > 100, next_value, NA))

上面的代码将数据集按“group”分组,并在每个组中为“value”列创建两个新列:“next_value”和“next_value_subset”。

“next_value”列包含组内“value”列的下一个值。如果在组中的最后一个行中没有下一个值,则“next_value”列中的值将为NA。

“next_value_subset”列是“next_value”列的子集。它仅包含大于100的“next_value”值。如果“next_value”小于或等于100,则“next_value_subset”列中的值将为NA。

上述代码中使用了ifelse函数来实现子集条件过滤。该函数的语法为:

ifelse(condition, true_value, false_value)

如果“condition”评估为TRUE,则返回“true_value”,否则返回“false_value”。

在这个示例中,我们使用了ifelse函数来检查“next_value”是否大于100。如果是,则返回“next_value”,否则返回NA。

相关内容

热门资讯

安卓换鸿蒙系统会卡吗,体验流畅... 最近手机圈可是热闹非凡呢!不少安卓用户都在议论纷纷,说鸿蒙系统要来啦!那么,安卓手机换上鸿蒙系统后,...
app安卓系统登录不了,解锁登... 最近是不是你也遇到了这样的烦恼:手机里那个心爱的APP,突然就登录不上了?别急,让我来帮你一步步排查...
安卓系统拦截短信在哪,安卓系统... 你是不是也遇到了这种情况:手机里突然冒出了很多垃圾短信,烦不胜烦?别急,今天就来教你怎么在安卓系统里...
安卓系统要维护多久,安卓系统维... 你有没有想过,你的安卓手机里那个陪伴你度过了无数日夜的安卓系统,它究竟要陪伴你多久呢?这个问题,估计...
windows官网系统多少钱 Windows官网系统价格一览:了解正版Windows的购买成本Windows 11官方价格解析微软...
安卓系统如何卸载app,轻松掌... 手机里的App越来越多,是不是感觉内存不够用了?别急,今天就来教你怎么轻松卸载安卓系统里的App,让...
怎么复制照片安卓系统,操作步骤... 亲爱的手机控们,是不是有时候想把自己的手机照片分享给朋友,或者备份到电脑上呢?别急,今天就来教你怎么...
安卓系统应用怎么重装,安卓应用... 手机里的安卓应用突然罢工了,是不是让你头疼不已?别急,今天就来手把手教你如何重装安卓系统应用,让你的...
iwatch怎么连接安卓系统,... 你有没有想过,那款时尚又实用的iWatch,竟然只能和iPhone好上好?别急,今天就来给你揭秘,怎...
iphone系统与安卓系统更新... 最近是不是你也遇到了这样的烦恼?手机更新系统总是失败,急得你团团转。别急,今天就来给你揭秘为什么iP...