R_Language 板


library(data.table) library(magrittr) dt <- fread('Goback, NameZh, Leave, Time, UniqueBusID 0, 大兴一街, TRUE, 2015/1/1 13:10:32, 大兴一街->屯区艺文中心162 0, 大兴五街, FALSE, 2015/1/1 13:10:39, 大兴一街->屯区艺文中心162 0, 大兴五街, TRUE, 2015/1/1 13:10:51, 大兴一街->屯区艺文中心162 0, 屯区艺文中心, FALSE, 2015/1/1 13:11:20, 大兴一街->屯区艺文中心162 0, 屯区艺文中心, TRUE, 2015/1/1 13:12:32, 大兴一街->屯区艺文中心162 1, 屯区艺文中心, FALSE, 2015/1/1 13:36:50, 屯区艺文中心->莒光新城163 1, 屯区艺文中心, TRUE, 2015/1/1 13:36:56, 屯区艺文中心->莒光新城163 1, 大兴五街, FALSE, 2015/1/1 13:37:28, 屯区艺文中心->莒光新城163 1, 大兴五街, TRUE, 2015/1/1 13:37:38, 屯区艺文中心->莒光新城163 1, 大兴一街, FALSE, 2015/1/1 13:37:43, 屯区艺文中心->莒光新城163', sep=",", header=T) dt[,Time:=as.POSIXct(strptime(Time,"%Y/%m/%d %H:%M:%S"))] %>% .[,c("rid","qid") := list(.I, .I[which(Leave==TRUE)][1L]),by=.(UniqueBusID)] out <- dt[qid==rid | (rid>qid & Leave==FALSE), {.(qid=qid, rid=rid, dif= Time-Time[rid==qid])}, by=.(UniqueBusID)] %>% .[qid!=rid, .(UniqueBusID, dif)] # UniqueBusID dif #1: 大兴一街->屯区艺文中心162 7 secs #2: 大兴一街->屯区艺文中心162 48 secs #3: 屯区艺文中心->莒光新城163 32 secs #4: 屯区艺文中心->莒光新城163 47 secs ※ 引述《joson4921 (特务)》之铭言: : : - 问题: 当你想要问问题时,请使用这个类别。 : : [问题类型]: : : 程式谘询(我想用R 做某件事情,但是我不知道要怎麽用R 写出来) : : [软体熟悉度]: : : 入门(写过其他程式,只是对语法不熟悉) : : [问题叙述]: : 请简略描述你所要做的事情,或是这个程式的目的 : 各位先进大家好,为了方便叙述问题,先节录以下资料方便说明: : Goback NameZh Leave Time UniqueBusID : 0 大兴一街 TRUE 2015/1/1 13:10:32 大兴一街->屯区艺文中心162 : 0 大兴五街 FALSE 2015/1/1 13:10:39 大兴一街->屯区艺文中心162 : 0 大兴五街  TRUE  2015/1/1 13:10:51 大兴一街->屯区艺文中心162 : 0 屯区艺文中心 FALSE 2015/1/1 13:11:20 大兴一街->屯区艺文中心162 : 0 屯区艺文中心 TRUE 2015/1/1 13:12:32 大兴一街->屯区艺文中心162 : 1 屯区艺文中心 FALSE 2015/1/1 13:36:50 屯区艺文中心->莒光新城163 : 1 屯区艺文中心 TRUE 2015/1/1 13:36:56 屯区艺文中心->莒光新城163 : 1 大兴五街 FALSE 2015/1/1 13:37:28 屯区艺文中心->莒光新城163 : 1 大兴五街 TRUE 2015/1/1 13:37:38 屯区艺文中心->莒光新城163 : 1 大兴一街 FALSE 2015/1/1 13:37:43 屯区艺文中心->莒光新城163 :   当 Leave = TRUE 代表车辆离站 : 当 Leave = FALSE 代表车辆到站 : 我想做资料处理问题如下所述: : 1、列与列之间的时间运算(同一班车计算站间旅行时间) : 前一班车: 大兴一街(TRUE,第1笔) -> 大兴五街(FALSE,第2笔) 00:00:07 : 大兴一街(TRUE,第1笔) -> 屯区艺文中心(FALSE,第4笔) 00:00:48 :   後一班车:屯区艺文中心(TRUE,第7笔) -> 大兴五街(FALSE,第8笔) 00:00:32 :        屯区艺文中心(TRUE,第7笔) -> 大兴一街(FALSE,第10笔) 00:00:47 : 之前曾经来板上问过,知道对UniqueBusID用groupby下去, : 就可以把不同班车的资料切分开来处理,以资料为例,前5笔和後5笔分别是不同班车 : 而我想求的是站间旅行时间,因此必须计算列与列之间的时间差, : 但是这边我希望程式可以自动判断 : (1) 当上下两列的UniqueBusID一样的时候才计算站间旅行时间 : (2) 第5笔资料其实是无用的,因为终点站只需要到达时间(Leave=FALSE) : 所以希望程式跳过不执行 : (3) 当上下两列的UniqueBusID不同时,则计算时间的基准改为新的资料 : 以前一班车为例,站间旅行时间计算基准是第1笔资料(Leave = TRUE,车辆离站) : 但是第6笔资料开始UniqueBusID改变了(不同车班) : 故後一班车的站间旅行时间计算基准改为第7笔资料(Leave = TRUE,车辆离站) : 试了好几天试不出来想要的结果,可能是我对R的函数不熟悉的关系 : 有请板上各位先进指点迷津,非常感谢!! : [程式范例]: : : [环境叙述]: : : 请提供 sessionInfo() 的输出结果, : 里面含有所有你使用的作业系统、R 的版本和套件版本资讯, : 让版友更容易找出错误 : : [关键字]: : : 选择性,也许未来有用 : --



※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 140.112.65.48
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/R_Language/M.1480658003.A.539.html ※ 编辑: cywhale (140.112.65.48), 12/02/2016 13:54:16
1F:推 joson4921: 谢谢C大分享qid和rid来处理指定列运算的想法,不过看了 12/03 17:20
2F:→ joson4921: 老半天暂时还没搞懂list那一列在做啥,可能要再研究 12/03 17:21
3F:→ cywhale: 你执行看看 or library(data.table); ? .I 有.I[1]的介绍 12/03 18:16
4F:→ cywhale: .I[1],by=xx 就是根据by分类只选列编号的的第一个元素 12/03 18:24
5F:→ cywhale: 但因你的时间差要根据Leave第一笔来算所以多了which() 12/03 18:25
6F:→ cywhale: 所以有了qid你就知道谁是分类(BusID)的第一笔,再用rid 12/03 18:27
7F:→ cywhale: rid=.I 就是整体的列编号去减,就得到你要的时间差.. 12/03 18:28
8F:→ cywhale: 其实是很简单的想法,就是要抓到分类第一笔,和我要比对 12/03 18:29
9F:→ cywhale: 的每一笔的index,有了index就可以做正确的运算 12/03 18:29







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草
伺服器连线错误,造成您的不便还请多多包涵!
「赞助商连结」






like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:Tech_Job站内搜寻

TOP