按组在R中按条件计算两个日期时间列之间的行数
创始人
2024-09-03 06:01:12
0

假设我们有以下数据框:

df <- data.frame(group = c('A', 'A', 'A', 'B', 'B', 'B'), 
                 start_time = c('2022-10-01 10:00:00', '2022-10-01 11:00:00', '2022-10-01 12:00:00', '2022-10-01 10:00:00', '2022-10-01 11:00:00', '2022-10-01 12:00:00'), 
                 end_time = c('2022-10-01 10:30:00', '2022-10-01 11:30:00', '2022-10-01 12:30:00', '2022-10-01 11:00:00', '2022-10-01 12:00:00', 'NA'))

其中group为分类变量,start_timeend_time为日期时间变量。

要按组计算start_timeend_time之间的行数,可以使用data.tablelubridate库。具体代码如下:

library(data.table)
library(lubridate)

setDT(df)[, row_count := sum(between(ymd_hms(start_time), ymd_hms(end_time), ymd_hms(df$start_time)) & !is.na(df$end_time)), by = group]

这里使用setDT()将数据框转换为data.table类型,然后使用between()函数计算start_timeend_time之间的行数。ymd_hms()函数将字符型的日期时间变量转换为lubridate库中的日期时间格式。最后,使用sum()函数计算行数并使用by参数将计算结果按组汇总,并将结果存储在新列row_count中。

相关内容

热门资讯

三分钟了解!嫩江和和麻将真有挂... 三分钟了解!嫩江和和麻将真有挂吗,吉祥联盟是不是有挂,揭秘教程(有挂教学);1、每一步都需要思考,不...
四分钟了解!创思维激k,欢乐斗... 四分钟了解!创思维激k,欢乐斗地主有挂吗app,系统教程(有挂透明);1、打开软件启动之后找到中间准...
三分钟了解!微信小程序赣牌圈辅... 三分钟了解!微信小程序赣牌圈辅助器,云南星悦麻将到底有没有挂,必备教程(有挂秘籍);1、起透看视 云...
6分钟了解!心悦麻将看牌工具,... 6分钟了解!心悦麻将看牌工具,中至景德镇辅助,规律教程(有挂方法)1、用户打开应用后不用登录就可以直...
3分钟了解!中至万年麻将有脚本... 3分钟了解!中至万年麻将有脚本吗,八闽十三水好牌,黑科技教程(有挂透视);运中至万年麻将有脚本吗辅助...
7分钟了解!好友跑得快软件黑科... 7分钟了解!好友跑得快软件黑科技,八闽十三水黑科技,AI教程(有挂普及);一、好友跑得快软件黑科技A...
4分钟了解!中至窝龙如何提高自... 4分钟了解!中至窝龙如何提高自己的胜率,天天乐清麻将有挂吗,AI教程(有挂解说)1、操作简单,无需注...
2分钟了解!广东雀神麻将怎么让... 2分钟了解!广东雀神麻将怎么让系统发好牌,情怀麻将,必备教程(有挂脚本);1、下载好广东雀神麻将怎么...
4分钟了解!优乐江西麻将,碣石... 4分钟了解!优乐江西麻将,碣石暗宝怎么破解,2025新版教程(有挂攻略);1、超多福利:超高返利,海...
八分钟了解!雀神开外挂专用辅助... 八分钟了解!雀神开外挂专用辅助器下载安装,南通长牌app有没有挂,靠谱教程(有挂解说)进入游戏-大厅...