R_Language 板


LINE

※ 引述《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 的版本和套件版本资讯, : 让版友更容易找出错误 : : [关键字]: : : 选择性,也许未来有用 : # 概念是我直接算站间时间,然後把停留时间的部分在过滤掉而已 # data.table: library(data.table) library(fasttime) library(pipeR) 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') DT[ , Time := fastPOSIXct(Time)] cumany <- function(x) cumsum(x) >= 1 DT[ , .(timeBetweenStops = tail(Time, length(Time)-1) - head(Time, length(Time)-1), filter = cumany(head(Leave, length(Leave)-1)), NameZhLeave = head(NameZh, length(NameZh)-1), NameZhNext = tail(NameZh, length(NameZh)-1)), by = .(UniqueBusID)] %>>% `[`(i = which(filter)) %>>% `[`(j = cumTimeBetweenStops := cumsum(as.numeric(timeBetweenStops)), by = .(UniqueBusID)) %>>% `[`(NameZhLeave != NameZhNext) %>>% `[`(j = .(UniqueBusID, timeBetweenStops, cumTimeBetweenStops)) # UniqueBusID timeBetweenStops cumTimeBetweenStops # 1: 大兴一街->屯区艺文中心162 7 secs 7 # 2: 大兴一街->屯区艺文中心162 29 secs 48 # 3: 屯区艺文中心->莒光新城163 32 secs 32 # 4: 屯区艺文中心->莒光新城163 5 secs 47 # dplyr的部分,过几天补,先写完了data.table,就先PO了 -- R资料整理套件系列文: magrittr #1LhSWhpH (R_Language) https://goo.gl/72l1m9 data.table #1LhW7Tvj (R_Language) https://goo.gl/PZa6Ue dplyr(上.下) #1LhpJCfB,#1Lhw8b-s (R_Language) https://goo.gl/I5xX9b tidyr #1Liqls1R (R_Language) https://goo.gl/i7yzAz pipeR #1NXESRm5 (R_Language) https://goo.gl/zRUISx --



※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 36.232.188.79
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/R_Language/M.1480695393.A.516.html ※ 编辑: celestialgod (36.232.188.79), 12/03/2016 00:18:05
1F:推 joson4921: 谢谢c大分享,刚消化完另一位c大的写法,换研究这个写法 12/03 17:25







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灯, 水草

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

TOP